美文网首页docker
基于Docker-Compose 部署前后端分离单体项目(一)

基于Docker-Compose 部署前后端分离单体项目(一)

作者: 怪诞140819 | 来源:发表于2020-07-21 15:28 被阅读0次

    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 其他想说的话

    想要表达清楚一键事情是非常不容易的事情,特别是通过文字,既不想废话连篇,又想表达清楚真的很难,因为细节比较多!然而我觉得弄清楚大方向是非常必要的,然后再进行分解,希望能说的明白,我会加油的,如果写的不好也希望大家原谅!

    相关文章

      网友评论

        本文标题:基于Docker-Compose 部署前后端分离单体项目(一)

        本文链接:https://www.haomeiwen.com/subject/qqrikktx.html