1.单体项目是否需要采用docker进行部署?
2.如果采用docker部署是否有必要采用docker-compose进行服务编排?
答案是也许有必要,也许没必要,docker的优势很多,但是对于垂直架构的项目优势未必那么明显,总之一句你需要根据自己的项目情况去考虑。笔者之所以会写这篇文章,大概率是基于省事的目的去部署一些小的项目。同时也是提供一种前后端分离的项目的部署方案(但绝对不是最有方案),以及在这种模式下的docker如何去工作才能达到我们的目的。
然而最终的目的是为了偷懒,省事。让前后端分离项目的部署方式变的简单。就也许在这种模式下,你只需要5分钟就可以实现部署,或许吧,不妨把这个当作一个目标。
本文目标:
- 环境说明。
- 部署流程说明。
1.环境
1.1 项目情况
- springboot+maven
- redis
- mysql
- nginx
- vue(后台web admin)
- uni-app(H5)
1.2 本地环境
- docker 19.03.2
- 其他开发必备(因为关联不大,所以不交代)
1.3 服务器环境
- 1台 ubuntu 18.04 (基于Centos差异,在后续文章会进行交代)
- docker
- docker-compose
- 当前服务器docker上部署mysql,redis,nginx,java,admin,h5
1.4 镜像仓库
- 阿里云容器镜像服务(免费,个人觉得挺好用的,有需要也可以去试一下)
2 部署流程
上图将部署流程分为三部分,本地开发环境,阿里云容器镜像服务,以及linux服务器。下面分成三个部分对上图进行说明,工欲善其事,必先利其器。先进行说明,后面才能对每部分做的工作比较清晰。
2.1 本地开发环境
本地开发环境分成三个项目
- pitaya-java (springboot+maven)
- pitaya-h5(uni-app)
- pitaya-admin(vue)
三个项目分别打包成三个镜像,对应到阿里云中的是那个镜像仓库,三个镜像名字分别为 - pitaya-java
- pitaya-h5
- pitaya-admin
然而我们版本迭代就设计到了不同的版本问题,对应了镜像不同标签tag。
例如 pitaya-java:1.0.o 就说明是后台1.o.0的版本,版本保留在镜像仓库,这样对于我们后期需要回滚版本也非常好做!
本地环境需要做的事情是需要打包镜像并且推送到镜像仓库
这一点是大家需要记住的,这就是为什么一定要在这里写这么多废话来说明,至于怎样打包镜像推送,在下一片文章会讲到,此处大家只需要记住,镜像是从开发环境推送过去的(或者也可以采用jenkins进行推送,如果有需要也可以在后面再去开专题写用jenkins做持续集成)
2.2 阿里云容器镜像服务说明
先解释一下图中的相关名词
- 命名空间:阿里云容器服务的命名空间我习惯当成一个项目来用,例如我们开发一个crm项目,crm这个项目就相当于我们的命名空间。
- 镜像仓库:镜像仓库属于命名空间,一个命名空间有多个镜像仓库,就相当于我们一个crm项目有后台java端的镜像(如果微服务,就可能拆分出更多的服务,我们可以把每个服务都当成一个镜像仓库),前端项目等。镜像仓库就对应我们每个服务打包的镜像,他存储着这些镜像不同的版本。
- tag: tag其实本身是docker镜像的概念,我们可以理解为一个镜像的不同版本。例如1.0.0,1.0.1等。
针对当前需要完成的目标来说,相当于pitaya-java,pitaya-h5, pitaya-admin都分别拥有自己的镜像仓库,都属于pitaya这个命名空间。
容器镜像服务,分门别类的存储我们的镜像
。这个是镜像服务的唯一用途,就相当于maven的仓库是一样的。
我们也可以搭建自己的私服仓库,例如开源的harbor等,都非常好用,在企业中用私服会比较多。
2.3 Linux服务器
首先我们需要在linux服务器上搭建Docker环境,也就是我们在linux上有一个docker。再将我们的镜像运行在docker上。
从上图我们发现在docker上运行这很多容器,mysql,redis,nginx,pitaya-java,pitaya-admin,pitaya-h5.
然而我们的容器是需要通信的,例如:大家都知道pitaya-java是一个springboot的项目,他需要访问mysql进行数据存储服务,需要访问redis缓存我们的令牌信息等。
也就是说,我们运行的这些容器之间是要相互能通信的。所以我们在docker上创建了一个内部网络叫做pitaya-network,他在172.2.0.0这个网段,我们需要我们的容器都加入pitaya-network这个网络,并且分配固定的IP地址,指定固定端口。
为什么需要分配固定IP地址,指定固定端口?
因为我们的容器也可能会和服务器一样,会挂掉,如果随机分配的话,创建新的容器,IP地址可能会变,我们容器间不能通信,例如java服务访问不了mysql,这样我们的线上就无法提供客户正常服务了。
3 总结
本文我们做一个大概的概述,针对上面的结构以下问题是我们急需解决的?
- 1.如何制作镜?
- 2.是否制作的镜像可以不受环境影响,例如数据库链接等是可以在运行的时候指定的?
- 3.如何推送镜像到阿里云容器镜像服务或者你的私服?
其实针对java项目和vue项目制作镜像方式不同,但是原理一样,原理无非就是基于docker build这个命令制作镜像,但是java的镜像制作和推送可能更加简单,只需要一条命令即可,因为maven提供了制作镜像的插件。这些内容在下一篇文章都会涉及到!
3.1 其他想说的话
想要表达清楚一键事情是非常不容易的事情,特别是通过文字,既不想废话连篇,又想表达清楚真的很难,因为细节比较多!然而我觉得弄清楚大方向是非常必要的,然后再进行分解,希望能说的明白,我会加油的,如果写的不好也希望大家原谅!