使用二级域名+转发来访问网站
大致方法:
docker容器3个nginx容器
1、mynginx 1网站部署的nginx 端口8080
2、web_nginx 2网站部署的nginx 端口8081
3、proxy_nginx 用于代理转发的nginx 端口80
统一使用nginx来做入口的代理和转发。
需要注意的是,proxy_nginx的端口,必须是80,不是其他的。
因为你浏览器访问域名,默认不写端口,就是80端口。
1、首先要阿里云配置一个二级域名。
配置安全组,开放了80【proxy_nginx】、8080-8100【部署多个网站】多个端口
2、docker创建容器,并且映射配置文件等
1)docker创建mynginx 部署我的网站
新建一个nginx去把配置文件拷出来供映射的时候使用
docker run nginx
自己新建一个目录管理nginx,比如我这里是/mydockerdata/nginx 用这个目录来管理,并创建dist log目录
mkdir log
mkdir dist
docker ps 查看container 的ID
拷贝配置文件到自己的管理目录下面
nginx docker cp 【CONTAINER ID】 :/etc/nginx/nginx.conf /mydockerdata/nginx/
拷贝完成之后,可以把新建的nginx删了,重新创建自己的
docker rm nginx -f
上传静态网站的到/mydockerdata/nginx/dist下面(这个目录就是存放网页的)
scp -r /Users/jafir/Documents/myadmin/dist/ root@keep999.cn:/mydockerdata/nginx/
创建nginx容器
docker run
-p 8080:80 映射端口本机8080到容器80
--name mynginx container的名字mynginx
-v /mydockerdata/nginx/log/:/var/log/nginx 映射log文件目录
-v /mydockerdata/nginx/nginx.conf:/etc/nginx/nginx.conf 映射配置文件
-v /mydockerdata/nginx/dist/:/usr/share/nginx/html 映射网页存放目录
-d 后台运行
nginx 镜像
注意这里本机的ip是8080,容器内是80(多个容器内的80端口是不会相互冲突影响的,因为docker的容器就是隔离的),外界访问是通过8080
修改本机nginx.conf的配置即可修改容器里面的nginx.conf配置(因为做了映射)
vim /mydockerdata/nginx/nginx.conf
http节点下添加 server
server {
listen 80; #监听的端口
server_name keep999.cn; #监听的URL
root /usr/share/nginx/html; #项目路径
index index.html;
# Any route that doesn't have a file extension (e.g. /devices)
location / {
try_files $uri $uri/ /index.html;
}
}
按esc,:wq 保存成功 重启mynginx就可以了
docker restart mynginx
这样就成功了,访问http://xxxxxx:8080 或
http://keep999.cn:8080就能访问网站了
2) 按照跟1)一样的方法,新建/mydockerdata/web_nginx目录来管理2网站
由于2网站路径是在/var/www/html下,所以创建容器的时候网站路径映射要改一下
docker run -p 8081:80 --name web_nginx -v /mydockerdata/web_nginx/log/:/var/log/nginx -v /mydockerdata/web_nginx/nginx.conf:/etc/nginx/nginx.conf -v /var/www/html:/usr/share/nginx/html -d nginx
server {
listen 80; #监听的端口
server_name keep999.cn; #监听的URL
root /usr/share/nginx/html; #项目路径
index index.html;
# Any route that doesn't have a file extension (e.g. /devices)
location / {
try_files $uri $uri/ /index.html;
}
}
配置文件也是一样的,两个项目的配置文件最好分开
创建好了之后,就能通过http://xxxxx:8081来访问2网站了
3)创建proxy_nginx来代理和二级域名转发
创建nginx的管理目录也是一样的,/mydockerdata/proxy_nginx目录来管理
不过80原来是被朋友的nginx给占用了,可以先把它给杀掉,kill -9 pid,再创建我们的容器
docker run -p 80:80 --name proxy_nginx -v /mydockerdata/proxy_nginx/log/:/var/log/nginx -v /mydockerdata/proxy_nginx/nginx.conf:/etc/nginx/nginx.conf -v /mydockerdata/proxy_nginx/dist/:/usr/share/nginx/html -d nginx
这里的配置文件就比较重要了
server {
listen 80; #监听的端口
server_name a.keep999.cn; #监听的URL
location / {
proxy_redirect off;
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_pass http://xxxxxx:8080;
}
}
server {
listen 80; #监听的端口
server_name keep999.cn; #监听的URL
location / {
proxy_redirect off;
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_pass http://xxxxxx:8081;
}
}
把 a.keep999.cn 转发到我的项目,我的项目访问是http://xxxxxx:8080
把 keep999.cn 转发给他的项目,他的项目访问是http://xxxxxx:8081
修改了之后,docker restart proxy_nginx就可以咯
要是不会用vim,推荐一个editplus
评论区