Nginx實現(xiàn)端口映射的示例代碼
1. 找到nginx的部署路徑
[root@SH-DB-02 adi]# ps -ef | grep nginx root 53617 1 0 2019 ? 00:00:07 nginx: master process ./nginx nobody 176294 53617 0 12:31 ? 00:00:01 nginx: worker process [root@SH-DB-02 adi]# [root@SH-DB-02 adi]# [root@SH-DB-02 adi]# [root@SH-DB-02 adi]# ls -la /proc/53617/exe lrwxrwxrwx 1 root root 0 6月 20 14:01 /proc/53617/exe -> /opt/nginx/webserver/nginx/sbin/nginx
最終找到的nginx的路徑為“ /opt/nginx/webserver/nginx/sbin/nginx”
2. 備份原來的配置文件
cd /opt/nginx/webserver/nginx/conf/ cp nginx.conf nginx20250620.txt
3. 編輯nginx.conf文件
nano nginx.conf
4. 在http塊中添加新的server配置
在現(xiàn)有的server塊(8080端口那個)后面,在http塊的最后一個 } 之前添加:
server {
listen 8083;
server_name 本機IP;
# 只代理特定路徑
location /xizangott/C2callback {
proxy_pass http://127.0.0.1:8081;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
# 設置超時時間
proxy_connect_timeout 60s;
proxy_send_timeout 60s;
proxy_read_timeout 60s;
}
# 其他請求返回404
location / {
return 404;
}
}
5. 完整的nginx.conf應該是這樣的:
user nobody;
worker_processes 8;
#error_log logs/error.log;
#error_log logs/error.log notice;
error_log logs/error.log info;
pid logs/nginx.pid;
worker_rlimit_nofile 51200;
events {
use epoll;
worker_connections 51200;
}
http {
include mime.types;
default_type application/octet-stream;
#log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" $http_x_forwarded_for "$request_time"';
access_log logs/access.log main;
sendfile on;
tcp_nopush on;
keepalive_timeout 65;
autoindex_exact_size off;
autoindex_localtime on;
autoindex on;
gzip on;
server {
listen 8080;
server_name 本機IP;
index index.html index.htm;
root /data/pic;
autoindex off;
if (-d $request_filename)
{
rewrite ^/(.*)([^/])$ http://$host/$1$2/ permanent;
}
location /ngx_status {
stub_status on;
access_log off;
allow 127.0.0.1 ;
deny all;
}
}
server {
listen 8083;
server_name 本機IP;
# 只代理特定路徑
location /xizangott/C2callback {
proxy_pass http://127.0.0.1:8081;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
# 設置超時時間
proxy_connect_timeout 60s;
proxy_send_timeout 60s;
proxy_read_timeout 60s;
}
# 其他請求返回404
location / {
return 404;
}
}
}
6. 保存文件并退出nano
按 Ctrl + X,然后按 Y,最后按 Enter
7. 測試配置文件語法
cd /opt/nginx/webserver/nginx/sbin/ ./nginx -t
8. 重新加載nginx配置
./nginx -s reload
9. 驗證配置是否生效
# 檢查8083端口是否在監(jiān)聽 netstat -tulpn | grep :8083 # 檢查nginx進程 ps -ef | grep nginx
10. 測試代理功能
# 測試目標路徑 curl -I http://本機ip:8083/xizangott/C2callback # 測試其他路徑(應該返回404) curl -I http://本機ip:8083/test
11. 查看日志(如果有問題)
# 查看錯誤日志 tail -f /opt/nginx/webserver/nginx/logs/error.log # 查看訪問日志 tail -f /opt/nginx/webserver/nginx/logs/access.log
按照以上步驟操作即可。配置完成后,訪問 http://本機IP:8083/xizangott/C2callback 就會被代理到你的8081端口的Java應用了。
這樣訪問http://本機ip:8083/xizangott/C2callback會映射到“http://本機ip:8081/xizangott/C2callback”
到此這篇關(guān)于Nginx實現(xiàn)端口映射的示例代碼的文章就介紹到這了,更多相關(guān)Nginx 端口映射內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
nginx php-fpm中啟用慢日志配置(用于檢測執(zhí)行較慢的PHP腳本)
這篇文章主要介紹了nginx php-fpm中啟用慢日志配置,php-fpm慢日志slowlog設置可以讓我們很好的看見哪些php進程速度太慢而導致的網(wǎng)站問題,可以讓我們方便的找到問題的所在,需要的朋友可以參考下2014-05-05
實現(xiàn)Nginx中使用PHP-FPM時記錄PHP錯誤日志的配置方法
最近在本地搭建的LNMP的開發(fā)環(huán)境。為了開發(fā)的時候不影響前端的正常開發(fā)就屏蔽的PHP里面php.ini中的一些錯誤提示。但是這樣一來,就影響到了后端開發(fā)的一些問題比如不能及時調(diào)試開發(fā)中的一些問題2014-05-05
nginx加php-fpm出現(xiàn)502 bad gateway錯誤的5種解決方法
這篇文章主要介紹了nginx加php-fpm環(huán)境中出現(xiàn)502 bad gateway錯誤的5種解決方法,總結(jié)歸納服務器出現(xiàn)502錯誤的原因多數(shù)為連接過多和腳本超時,本文總結(jié)了5種解決方法,需要的朋友可以參考下2014-05-05

