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

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

 docker pull nginx 
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退出容器的终端 
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;#} } 
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
mkdir -p /nginx/conf mkdir -p /nginx/conf.d mkdir -p /nginx/html mkdir -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和doc.lightmap.com,分别创建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:端口}} 

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

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>去掉。 

通过域名访问:成功!!

借鉴此博文,感谢。

原文链接:http://www.taodudu.cc/news/show-5136365.html

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享