带有 docker 的 Nginx:反向代理不起作用



我最近想设置一个反向代理服务器。我提取了一个nginx docker映像,并使用以下命令运行docker容器:

docker run -d --name ngtest -p 4080:80 nginx

然后我更新了/etc/nginx/nginix.conf,如下所示:

user  nginx;
worker_processes  1;
error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;

events {
worker_connections  1024;
}

http {
include       /etc/nginx/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"';
access_log  /var/log/nginx/access.log  main;
sendfile        on;
#tcp_nopush     on;
keepalive_timeout  65;
#gzip  on;
include /etc/nginx/conf.d/*.conf;
server{
listen 80;
location /nexus/ {
proxy_pass    http://192.168.0.30:8081/;
}
}
}

容器在重新启动后工作,当我试图打开页面时http://192.168.0.30:4080,我得到了默认的Nginx页面。

然而,当我尝试这个网址时:http://192.168.0.30:4080/nexus,我得到了一个404页的错误。

从日志中可以看出,nginx并没有将url转发到我在nginx.conf中设置的页面,而是尝试在本地目录中查找页面:

2020/03/11 16:10:34 [error] 6#6: *251 open() "/usr/share/nginx/html/nexus" failed (2: No such file or directory), client: 192.168.0.153, server: localhost, request: "GET /nexus HTTP/1.1", host: "192.168.0.30:4080"
192.168.0.153 - - [11/Mar/2020:16:10:34 +0000] "GET /nexus HTTP/1.1" 404 555 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.132 Safari/537.36" "-"

我的脚步有什么毛病吗?

谢谢,

Alex

问题是,即使更新了配置,您仍在执行:

include/etc/nginx/conf.d/*.conf;

如果未找到服务器名称,则根据确定要使用的服务器的规则,如果未提供服务器名称,将加载默认服务器/etc/nginx/conf.d/default.conf

你应该做一些类似的事情:

将您的服务器定义保存到配置文件中:

server{
listen 80;
location /nexus/ {
proxy_pass    http://192.168.0.30:8081/;
}
}

然后运行

docker run -d -p 4080:80 -v (path_to_your_config):/etc/nginx/conf.d/default.conf nginx

这将用您的配置替换默认配置。然后,如果您需要进行更改,只需进行更改并重新启动容器即可。

最新更新