# 经过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下咯