上一节我们构建了一个Node镜像。
这里我有一台已经安装了docker的Linux主机,比如 IP 是154.8.100.124。
我只需在主机上执行 docker run -d -p 3000:3000 finleyma/express
,就会部署并运行项目
然后浏览器中输入154.8.100.100:3000 就可以访问了。
这里牵涉到两个问题:
每次修改了项目代码需要重新构建新的镜像,然后push到仓库。
每次还得登录服务器从仓库拉最新的镜像重新运行 ,这样才能反映出变化。
持续集成就能帮我们做到自动化。
不过有几个条件:
需要一个提供持续集成服务的平台,这里我使用国内的 daocloud
他可以接入我们的主机,提供在线 web 的方式管理运行在主机上面的容器。需要一台能访问的且安装了docker的主机(最好是Linux)。
代码要部署到 github,coding 等 daocloud 支持的代码托管商。
下面介绍下流程:
去daocloud绑定仓库,和主机
根据仓库构建镜像
配置
image.png
查看主机上运行的 docker相关的信息
在主机上我们得敲 docker info, docker inspect 等。这里直观的多。
image.png
添加应用
image.png
添加项目,需要绑定 github 或 coding代码源
代码源就是上节的express项目,仓库地址是:https://coding.net/u/finley/p/docker-express-demo。
里面有Dockerfile。我们让daocloud帮忙构建,并且发布到主机上面。
image.png
在流程定义中构建阶段后面添加发布阶段,选择发布到自有主机
image.png
这个过程就是push代码之后,daocloud要根据Dockerfile去构建镜像,构建之前可以要运行测试脚本,构建成功之后可能要发送提醒。
默认是图形化的配置,也可以切换到yaml形式,编写流程定义 daocloud.yml 文件。
这里有个细节,如果你切换到了yaml格式,内容为空。push代码不会触发自动构建的。
稍微吐槽下daocloud做的不够人性化,流程定义没有帮助提示。比如匹配分支,满足条件那块,我不知道能填哪些,你弄个问号,鼠标指上去显示几行描述也好啊
image.png
这样就实现了,每当本地push代码到仓库,daocloud会重新构建镜像然后发布到主机。
image.png
有很多细节没有讲到,请自行查看提供的文档。
作者:飞凡的陀螺
链接:https://www.jianshu.com/p/cadc95184dc3
共同学习,写下你的评论
评论加载中...
作者其他优质文章