接着上一節沒有演示完的繼續,連接:Docker學習筆記之-部署.Net Core 3.1項目到Docker容器,並使用Nginx反向代理(CentOS7)(一)html
演示步驟:nginx
1,獲取nginx鏡像,並運行Nginx容器docker
2,根據上傳的項目生成鏡像文件,並運行項目容器vim
3,配置Nginx反向代理相關映射,並映射到項目容器,實現反向代理centos
4,最終展現效果api
第一步:獲取nginx鏡像,並運行 nginx容器安全
要運行容器,首先須要有相應的鏡像,使用下面的命令拉取Nginx鏡像:若是不指定版本號,默認拉取最新版本bash
docker pull nginx
獲取Nginx鏡像以後,就能夠根據鏡像來運行Nginx容器,使用下邊命令運行容器服務器
docker run --name=nginx -d -p 4043:80 nginx
上面命令的解釋以下:ide
上圖表示Nginx容器已經在運行,經過外部訪問4043端口,顯示以下,表示成功
第二步: 生成項目鏡像文件,並運行項目容器
首先找到項目文件目錄,並進入項目根目錄當中,而後使用以下命令生成鏡像
ls --查看本地文件列表 cd netcoredemo --進入到項目根目錄 docker build -t myapidemo . --生成項目鏡像文件
上面命令的解釋:
經過命令 docker images 查看當前運行的鏡像,能夠看到上邊的鏡像已經建立成功,而且自動建立相關依賴鏡像。
建立完鏡像後, 使用下邊命令運行容器
docker run --name=myapidemo -d -p 9020:80 myapidemo
解釋:
1,容器名:myapidemo
2,對外開放端口:9020
上圖能夠看到,容器已經成功運行,到如今,就能夠遠程經過 9020端口直接訪問項目了,以下:調用API項目接口:
可是爲了安全,生產環境是不容許這樣直接訪問容器的,因此須要使用Nginx來代理訪問!
第三步:配置Nginx相關映射,並映射到項目容器,實現反向代理
首先進入Nginx容器,查看Nginx默認配置都是神馬內容,使用下面的命令進入容器裏面
docker exec -it nginx /bin/bash
解釋說明:
若是你看到上圖錯誤,說明你的Nginx容器沒有運行,使用命令 docker start nginx 啓動便可!
正常狀況下你會看到以下圖所示,你會發現,終端帳戶名稱變了,從原來的 @centos7 變成了 @xxxxxx5b,說明已經進入到容器當中了
使用命令 exit 能夠退出容器
Nginx默認會安裝在etc目錄下面,經過命令 ls 和命令 cd 結合,一層層往下找!
使用vim命令編輯 nginx.conf 文件,這時候邦德一下,發現居然報錯了!
緣由是由於 vim命令須要安裝一下,系統自己是沒有安裝的,直接執行以下命令進行更新安裝:
apt-get update --先更新來源 apt-get install -y vim --安裝 vim
注意:上邊兩個命令,不是用 yum命令安裝,而是用 apt-get 命令!
再次使用vim命令編輯 nginx.conf 文件
看最後紅框裏面的內容 include /etc/nginx/conf.d/*.conf,表示默認使用的是conf.d目錄下面的conf文件進行配置。
那麼接下來,咱們的映射內容也將會針對 conf.d目錄展開,能夠看到conf.d目錄下有個 default.conf文件!
所謂映射的目的就是隱藏服務器上真實的本地目錄,使用自定義的別名對外開放,供外部訪問!
首先在服務器上建立nginx的一些自定義文件存儲目錄,用於去隱藏真實目錄或文件!
執行以下命令,建立三個文件目錄 www、logs、conf
mkdir -p /root/nginx/www /root/nginx/logs /root/nginx/conf
查看nginx容器id
將nginx容器中,conf.d目錄下的配置文件copy到本地,cp 表示複製
docker cp ea37c8eaef5b:/etc/nginx/conf.d/default.conf /root/nginx/conf
上圖表示已經成功複製過來了!
要給netcore容器配置反向代理,首先須要知道netcore項目容器的IP地址,因此在修改配置以前,首先須要獲取myapidemo容器的IP地址。
docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' 容器名 or 容器Id
而後使用vim命令編輯 default.conf 文件(這個目錄下:/root/nginx/conf),將文件內容設置以下:
server{ listen 80; charset utf-8; server_name 172.17.0.3; location / { proxy_pass http://172.17.0.3:80; proxy_redirect default; } }
由於容器是內部訪問,因此設置的端口是80,而不是運行容器時設置的對外的9020端口。 修改完成以後,:wq 保存退出
如今從新建立一個新的nginx容器,名稱爲:nginxapi,並將www,logs,conf目錄映射到本地,對外端口設置爲:4030
docker run -d -p 4030:80 --name nginxapi \ -v /root/nginx/www:/usr/share/nginx/html \ -v /root/nginx/conf/default.conf:/etc/nginx/conf.d/default.conf \ -v /root/nginx/logs:/var/log/nginx \ nginx
上圖能夠看到,新的容器成功建立並運行,而且對外設置的端口爲:4030,
如今咱們經過4030端口在訪問咱們上邊的項目接口,以下圖所示,訪問成功!
而用未設置映射的Nginx容器,4043端口訪問接口,則返回的是 <404 Not found>