文章目录
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_nopush on;
keepalive_timeout 65;
#gzip on;
include /etc/nginx/conf.d/*.conf;
}
3. 在linux中创建挂载配置文件和文件夹
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:端口
}
}
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.d
service 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>去掉。
通过域名访问:成功!!
借鉴此博文,感谢。