前言
情況是這樣的,我借了朋友的阿里雲服務器 用docker 部署一下自己的網站(方便管理)。他的服務器自身也用nginx掛了一個網站,端口也用的是默認的80端口。服務器有域名,keep999.cn
我的是docker裏面添加的nginx容器,代理的靜態網頁。docker映射的是8080端口出來,所以,訪問的話,需要
keep999.cn:8080
來訪問。現在的話,我不想加端口訪問了,就想用域名(懶得寫端口),於是乎,就要開始想辦法解決這個問題了。
[TOC]
收穫
學習完這篇文章你將收穫:
- docker創建nginx容器
- nginx映射配置文件 網頁目錄 log目錄
- docker部署多個web網站
- 二級域名轉發到不同web網站
- 阿里雲設置雲解析
正題
具體做法:
一、使用二級域名+轉發來訪問我的網站
二、使用域名解析
一、使用二級域名+轉發來訪問我的網站
大致方法:
docker容器3個nginx容器
1、mynginx 我的網站部署的nginx 端口8080
2、web_nginx 朋友的網站部署的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/ [email protected]:/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://47.108.59.73:8080 或 http://keep999.cn:8080就能訪問網站了
2) 按照跟1)一樣的方法,新建/mydockerdata/web_nginx目錄來管理朋友的網站
由於朋友的網站路徑是在/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://47.108.59.73:8081來訪問他的網站了
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://47.108.59.73: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://47.108.59.73:8081;
}
}
把 a.keep999.cn 轉發到我的項目,我的項目訪問是http://47.108.59.73:8080
把 keep999.cn 轉發給他的項目,他的項目訪問是http://47.108.59.73:8081
修改了之後,docker restart proxy_nginx就可以咯
整個目錄樹結構/mydockerdata/下的
│─── mynginx 我的項目
| ├──- dist
| ├── log
| │ ├── access.log
| │ └── error.log
| └── nginx.conf
├── proxy_nginx 代理
│ ├── dist
│ ├── log
│ │ ├── access.log
│ │ └── error.log
│ └── nginx.conf
└── web_nginx 朋友的項目
├── dist
├── log
│ ├── access.log
│ └── error.log
└── nginx.conf
二、使用域名解析
第二種的話就很簡單了,直接使用aliyun的雲解析。
首先還是跟(一)的一些步驟一樣,生成我的項目的nginx容器,並使得keep999.cn:8080可以訪問到我的項目
然後就添加雲解析,【隱性url】
這樣的話,就可以通過b.keep999.cn來訪問的的項目了。
但是呢,爲啥沒有推薦這種寫法呢?因爲本身朋友的服務器 nginx和docker倆同級的,按道理應該全部交給docker來創建容器,方便管理,也不佔用80端口,可操作性更強。也是能夠更好的去了解和掌握docker與容器的關係,docker與本機的關係。去學習docker及其微服務方面的更多的知識。
總結
nginx還是很強大的,功能遠不止我們用到的這些。
其三大功能:反向代理、負載均衡、靜態資源服務器,我們這裏用到了反向代理、靜態網站,還沒有用到負載均衡。負載均衡,簡單點說,就是當有多臺服務器的時候,會根據設置的策略分散請求到不同的服務器上,分擔各個服務器的壓力。有興趣的可以自己去嘗試一下。
關於作者
作者是一個熱愛學習、開源、分享,傳播正能量,喜歡打籃球、頭髮還很多的程序員-。-
熱烈歡迎大家關注、點贊、評論交流!
簡書:https://www.jianshu.com/u/d234d1569eed
github:https://github.com/fly7632785