100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > docker部署nginx 并实现反向代理 配置多个域名多个端口

docker部署nginx 并实现反向代理 配置多个域名多个端口

时间:2020-08-17 04:03:25

相关推荐

docker部署nginx 并实现反向代理 配置多个域名多个端口

文章目录

docker部署nginx 并实现反向代理 配置多个域名多个端口1. 安装nginx:2. 以终端的方式打开镜像容器default.conf:nginx.conf:3. 在linux中创建挂载配置文件和文件夹反向代理:4. 创建容器并挂载文件和文件夹这一步:如果挂载之后容器运行正常却依然不能通过域名访问可尝试以下操作注意:每一次更改配置文件都需要重启容器解决nginx将css文件解析为text/plain

docker部署nginx 并实现反向代理 配置多个域名多个端口

1. 安装nginx:

docker pull nginx

2. 以终端的方式打开镜像容器

docker run -i -t docker.io/nginx /bin/bash

这里pull的nginx镜像为docker.io/nginx(关键)查看nginx镜像里面配置文件、日志等文件的具体位置,只有找到镜像配置文件的路径,后面挂载文件和文件夹才能覆盖这些路径:找到镜像中nginx.conf配置文件路径: /etc/nginx/nginx.conf用命令:cat /etc/nginx/nginx.conf查看nginx.conf文件内容然后拷贝出来找到default.conf配置文件的路径: /etc/nginx/conf.d/default.conf用命令:cat /etc/nginx/conf.d/default.conf 查看default.conf文件内容然后拷贝出来找到默认首页文件夹html路径: /usr/share/nginx/html找到日志文件路径: /var/log/nginx然后输入exit退出容器的终端

default.conf:

server {listen 80;server_name localhost;#charset koi8-r;#access_log /var/log/nginx/host.access.log main;location / {root /usr/share/nginx/html;index index.html index.htm;}#error_page 404 /404.html;# redirect server error pages to the static page /50x.html#error_page 500 502 503 504 /50x.html;location = /50x.html {root /usr/share/nginx/html;}# proxy the PHP scripts to Apache listening on 127.0.0.1:80##location ~ \.php$ {# proxy_pass http://127.0.0.1;#}# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000##location ~ \.php$ {# root html;# fastcgi_pass 127.0.0.1:9000;# fastcgi_index index.php;# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;# include fastcgi_params;#}# deny access to .htaccess files, if Apache's document root# concurs with nginx's one##location ~ /\.ht {# deny all;#}}

nginx.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_nopushon;keepalive_timeout 65;#gzip on;include /etc/nginx/conf.d/*.conf;}

3. 在linux中创建挂载配置文件和文件夹

mkdir -p /nginx/confmkdir -p /nginx/conf.dmkdir -p /nginx/htmlmkdir -p /nginx/logs

在conf文件夹创建nginx.conf: 并拷贝内容粘贴到文件中,:wq退出保存vi nginx.conf在conf.d文件夹创建default.conf,并拷贝内容粘贴到文件中,:wq退出保存vi default.conf

反向代理:

如创建light4d.top.conf, 其他的域名代理相同,只要改server_name和proxy_pass代理端口,配置文件需以.conf结尾,

在这里我配置了www.light4d.top.conf和,分别创建light4d.top.conf,doc.lightmap.conf文件,反向代理端口分别为8002,8052

light4d.top.conf添加以下配置信息:server {listen 80;server_name www.light4d.top; # 域名location / {proxy_set_header Host $http_host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_pass http://39.98.226.118:8002; # 代理ip:端口}}

doc.lightmap.conf添加以下配置信息:server {listen 80;server_name doc.lightmap.top; # 域名location / {proxy_set_header Host $http_host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_pass http://39.98.226.118:8052; # 代理ip:端口}}

4. 创建容器并挂载文件和文件夹

这里所挂载的文件和文件夹路径必须和以上所创建的配置文件路径一致

docker run --name nginx -d -p 80:80 -v /nginx/html:/usr/share/nginx/html -v /nginx/conf/nginx.conf:/etc/nginx/nginx.conf -v /nginx/conf.d:/etc/nginx/conf.d -v /nginx/logs:/var/log/nginx docker.io/nginx

这一步:如果挂载之后容器运行正常却依然不能通过域名访问可尝试以下操作

向名称为nginx的容器发送脚本命令docker exec -it nginx /bin/bash重新加载配置命令cd /etc/nginx/conf.dservice nginx reload检查配置文件路径是否正确

注意:每一次更改配置文件都需要重启容器

docker restart nginx // 重启nginx容器docker ps // 查看容器状态docker logs -t nginx // 如果挂载失败,查看nginx容器log,显示错误信息,根据错误信息 更改配置文件等

以上配置完成之后能够通过域名访问网站,但是css样式却被nginx解析成text/plain,打开控制台可看到warn信息

解决nginx将css文件解析为text/plain

方法一:来自网上的普遍解决办法

ngin.conf中http添加:include /etc/nginx/mime.types;default_type application/octet-stream;

注:此办法并不能使我网站的css正确解析,因为在拷贝nginx镜像中的原配置文件时,就已经添加mime.types了。却依然不能正确解析。

方法二:解析成功,原因未知

将index.html中<!DOCTYPE html>去掉。

通过域名访问:成功!!

借鉴此博文,感谢。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。