# 經過link指令創建鏈接
$ docker run --name <Name> -d -p <path1>:<path2> --link <containerName>:<alias> <containerName:tag/imageID>
複製代碼
- --link 容器鏈接指令
- < containerName > : < alias >
- < 被鏈接容器名稱 > : < 容器訪問別名 >
- 注:別名在主動創建鏈接的容器中訪問被鏈接容器使用
- 如下指令在容器檢測鏈接狀態
$ curl <alias>
複製代碼
一、構建mongo容器
二、構建node容器並與mongo容器創建鏈接
三、構建nginx容器並與node容器創建鏈接javascript
$ docker pull mongo:latest
複製代碼
$ docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
mongo latest 05b3651ee24e 2 weeks ago 382MB
複製代碼
$ docker run --name mock-mongo -d -p 27017:27017 mongo:latest --auth
# 須要與本地創建文件共享,則使用一下-v指令
# -v /data/db:/data/db
複製代碼
--auth 指令開啓了mongo的鏈接身份校驗 開啓校驗 是因爲 node 跨容器鏈接時 不設置身份校驗 開啓服務端沒法鏈接上mongo數據庫前端
```
nodejs.MongoError: [egg-mongoose]Authentication failed.
```
複製代碼
$ docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
0d440be90935 mongo "docker-entrypoint.s…" 14 hours ago Up 14 hours 0.0.0.0:27017->27017/tcp mock-mongo
複製代碼
$ docker exec -it mock-mongo /bin/bash
$ mongo admin
# 建立manager user
$ db.createUser({user:"admin", pwd:"admin",roles:[{role:"dbAdmin",db:"admin"}]})
# 帳號受權
$ db.auth('admin','admin')
複製代碼
如今咱們的mongo數據庫已經跑起來了,接下來咱們就要創建node容器了vue
在開始構建node容器前咱們要先約定好mongo容器別名,端口號以及登陸帳號密碼java
咱們先修改node服務端的配置node
文件配置 dockerfile/api-mocker/server/config/config.default.js 修改mongo鏈接配置,db爲預先設定的mock-mongo容器的別名nginx
mongoose: {
url: 'mongodb://admin:admin@db:27017/api-mock?authSource=admin'
},
複製代碼
如今咱們編寫一個Dockerfile文件來構建鏡像git
# 指定基礎鏡像
FROM node:latest
# 維護者
MAINTAINER qiushiyuan1994@qq.com
# 工做目錄
WORKDIR /www
# 將本地文件添拷貝到容器中,不會解壓
COPY api-mocker node-server/api-mocker
EXPOSE 7001
WORKDIR /www/node-server/api-mocker/server
RUN npm install
WORKDIR /www/node-server/api-mocker
# 構建容器後調用,在容器啓動時才進行調用
CMD ["make", "prod_server"]
複製代碼
咱們使用編寫好的dockerfile文件構建鏡像github
$ docker build -t="mock-server:1.0.0" .
複製代碼
讓咱們查看一下鏡像mongodb
$ docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
mock-server 1.0.0 957ad2aa1f97 8 minutes ago 674MB
mongo latest 05b3651ee24e 2 weeks ago 382MB
複製代碼
如今就到了關鍵的一步,咱們將mocker-server鏡像運行起來,並創建服務器與數據庫的鏈接docker
$ docker run -d -i -t -p 7001:7001 --name mock-server1 --link mock-mongo:db mock-server:1.0.0 /bin/bash
複製代碼
讓咱們再看看如今正在運行的容器
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
ee780b903c64 mock-server:1.0.0 "/bin/bash" About a minute ago Up 11 seconds 0.0.0.0:7001->7001/tcp mock-server
0d440be90935 mongo "docker-entrypoint.s…" 16 hours ago Up 16 hours 0.0.0.0:27017->27017/tcp mock-mongo
複製代碼
$ docker exec -it mock-server /bin/bash
$ curl db
複製代碼
如今咱們的服務端和數據庫已經創建起了鏈接,接下來咱們要開始部署咱們的客戶端
在創建nginx前,咱們要先約定好,node容器別名,nginx轉發的端口號以及客戶端訪問nginx域名及端口號
咱們先拉取nginx鏡像並創建容器
$ docker pull nginx:latest
$ docker run -p 90:80 --link mock-node:node nginx:latest --name mock-nginx
# 查看容器鏈接狀態
$ docker exec -it mock-nginx /bin/bash
$ env
# 看到如下數據則表示鏈接成功了
NODE_PORT_7001_TCP=tcp://172.17.0.3:7001
NODE_PORT_7001_TCP_PORT=7001
NODE_ENV_YARN_VERSION=1.9.4
複製代碼
如今咱們在看看已經運行中的容器
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
09644025d148 nginx "nginx -g 'daemon of…" 5 hours ago Up 5 hours 0.0.0.0:90->80/tcp mock-nginx
ee780b903c64 mock-server:1.0.0 "/bin/bash" About a minute ago Up 11 seconds 0.0.0.0:7001->7001/tcp mock-server
0d440be90935 mongo "docker-entrypoint.s…" 24 hours ago Up 24 hours 0.0.0.0:27017->27017/tcp mock-mongo
複製代碼
因爲前端獨立部署的緣由,咱們須要修改nginx的配置,修改nginx的配置的方式有如下幾種
咱們當前操做環境是17版 15寸macbook pro,掛載須要特殊配置,所以我採用了第二種方式
配置文件修改
$ docker cp mock-nginx:/etc/nginx/conf.d/default.conf ~/nginx/default.conf
複製代碼
server {
location /mock-api/ {
# node 爲指令服務端容器別名
proxy_pass http://node:7001/;
}
location /mock {
autoindex on;
alias /root/dist;
}
}
複製代碼
$ docker cp ~/nginx/default.conf mock-nginx:/etc/nginx/conf.d/default.conf
# 進入容器
$ docker exec -it mock-nginx /bin/bash
# 重啓nginx,看到如下提示則表示重啓成功
$ nginx -s reload
2018/11/03 17:23:14 [notice] 68#68: signal process started
複製代碼
接下來就到了咱們的最後激動人心的最後一步
修改咱們前端項目請求的網絡域名並打包上傳
// api-mocker/client/config
// module.exports > build > serverRoot
module.exports = {
build: {
serverRoot: '127.0.0.1:90/mock-api'
}
}
複製代碼
$ docker cp ~/Sites/api-mocker/client/dist mock-nginx:/root
複製代碼
> 固然nginx的容器構建也能夠編寫一個dockfile文件來實現,這裏咱們就不詳細說明了,掛載配置文件和日誌至本地主機有興趣的能夠本身嘗試一下
複製代碼
全部驚心動魄的配置咱們都已經完成,如今咱們來測試一下
訪問前端項目: http://127.0.0.1:90/mock 咱們會看到,如下界面說明咱們前端項目部署成功
咱們嘗試註冊一個帳號,看到成功提示,那就說明咱們整個項目部署成功了
至此咱們的部署就已經大功告成了,能夠開心的mock接口寫項目了,撒花~~~
第一次寫文章、第一次這樣部署都是艱難的,本身整理了一下思路,也但願能給你們帶來一些幫助
最後附上本身整理的docker經常使用命令以及該項目使用配置文件
segmentfault連接 以爲有用的能夠star下咯