推广 热搜: page  音视频  使用  选择  搜索引擎  百度  企业  可以  个数  父亲 

Docker三剑客之Docker-compose

   日期:2024-12-27     作者:bnzi1    caijiyuan   评论:0    移动:http://ww.kub2b.com/mobile/news/13383.html
核心提示:伸手摘星,即使一无所获,亦不致满手污泥。 在实际的生产中,一般都是使用一个docker容器部署一个应用进程&#x

伸手摘星,即使一无所获,亦不致满手污泥

在实际的生产中,一般都是使用一个docker容器部署一个应用进程,这种情况下,当部署多个不同应用或者一个应用部署多个实例的时候,就要运行多个容器。多个容器协同工作需要一个管理者来管理他们,定义这些容器如何相互关联。compose 就是做这件事的。

compose、machine 和 swarm 是docker 原生提供的三大编排工具。简称docker三剑客。

官网地址

 

Docker Compose 是用于定义和运行多容器 Docker 应用程序的工具,能够在 Docker 节点上,以单引擎模式(Single-Engine Mode)进行多容器应用的部署和管理

  • compose 使用 YAML 文件来定义多容器之间的关系(配置应用程序需要的所有服务,然后通过docker-compose up 命令执行一个YAML文件,就可以从 YML 文件配置中创建并启动所有服务,把完整的应用跑起来

  • 本质上, compose 把 YAML 文件解析成 docker 命令的参数,然后调用相应的 docker 命令行接口,基于 Docker 引擎 API 完成应用的部署,从而将应用以容器化的方式管理起来。

    compose 通过解析容器间的依赖关系顺序地启动容器。而容器间的依赖关系由 YAML 文件中的 links 标记指定

  • 下载

    • 可以从 Github 上下载它的二进制包来使用,最新发行的版本地址

        

      下载之后上传到服务器,通过mv或者cp 命令移动到指定文件中

       
    • 也可以通过命令以下载 Docker Compose 的指定版本

       
          

      上述命令是在GitHub会比较慢,可以提前下载或者使用下面的命令,高速安装 Docker Compose。

       
          

      要安装其他版本的 Compose,替换 v2.8.0即可。 /usr/local/bin/docker-compose 是下载存放的目录

      值得注意的是在官网中,已经发布了3个大版本,推荐使用2.x 和 3.x 版本,并且每个版本对应的Docker的版本在逛网中也有指出,按照需要进行下载即可

  • 授权

    上传之后需要对可执行权限应用于二进制文件

     
  • 创建软链

    软链类似Windows中的快捷方式,这一步可以不执行

     
  • 验证是否安装成功

    通过以下命令之一查看docker-compose的版本即可

      
  • 卸载docker-compose

    docker-compose卸载只需要删除二进制文件就可以了。

     

3.1 yml 文件组成简介

  • Docker Compose 使用 YAML 文件来定义多服务的应用。YAML 是 JSON 的一个子集,因此也可以使用JSON。

  • Docker Compose 默认使用文件名 docker-compose.yml。如果名字不是这个可以使用 -f 参数指定具体文件。

    Docker三剑客之Docker-compose

     
  • Docker Compose 的 YAML 文件包含 4 个一级 keyversion、services、networks、volumes

    • version

      version定义了 Compose 文件格式(主要是API)的版本,必须指定,位于文件的第一行

      注意,version 并非定义 Docker Compose 或 Docker 引擎的版本号

    • services

      用于定义不同的应用服务。Docker Compose 会将每个服务部署在各自的容器中

      比如有两个服务:eurekah和mysql ,就会写在services节点下

    • networks

      用于指引 Docker 创建新的网络。默认情况下,Docker Compose 会创建 bridge 网络

      bridge 网络一种单主机网络,只能够实现同一主机上容器的连接。也可以使用 driver 属性来指定不同的网络类型。

    • volumes

      用于指引 Docker 来创建新的数据卷卷

3.2 idea安装docker插件

idea高版本中已经安装docker插件,如果是低版本的idea,可以去下载安装docker插件

 
 

idea安装docker插件后,可以提示补全Dockerfile、docker-compose.yml文件大部分内容信息

此案例以Nginx 反向代理两个Tomcat为例,访问Nginx,以轮训的方式分别请求Tomcat1,Tomcat2。因此我们需要部署一个Nginx,两个Tomcat,最终通过docker-compose来启动这三个容器

  • 基础镜像

      
  • 试运行镜像

    先检查以下是否镜像是否可以正常启动

      

    启动的时候如果报以上的警告,说明IPv4转发已禁用。网络是行不通的,虽然容器启动了,但是外网无法访问,只需要门开只需要开启就可以了。

    • 开启转发配置

        
  • 在宿主机创建目录

     
  • 复制镜像文件

    将两个运行的容器的目录复制到宿主机

     
      

    这里复制镜像文件,只是为了后面做数据卷挂载用的,其实没有必要一定要cp,可以直接在上一步骤直接创建相应的nginx、webapps目录进行挂载就行,之所以这么做,是因为演示过程中实现对webapps下的index.jsp做一些修改,不然后面访问不好区分

  • 进入容器/退出容器

     

#进入容器/退出容器
docker exec -it tomcat sh
#退出容器
exit

 

等会使用docker-compose.yml启动

  • 修改Tomcat的启动页面

    这样就知道Tomcat是访问的那个tomcat1

      
  • 修改nginx.conf

      
  • nginx配置

     
  • 编辑docker-compose.yml

    当我们安装了docker插件之后,在编写docker-compose.yml的时候是有补全的

     

    docker-compose.yml还有很多的节点,因为这里用不上,就没有一一写上去,完整的节点信息可以关注我的公众号【星河之码】,回复【Docker-compose】获取。

  • 上传docker-compose.yml

    编写完docker-compose.yml之后,将其上传到服务器中,然后就可以通过docker-compose.yml来启动Nginx和tomcat

  • 启动服务

     
      

    由于我们的yml文件名是默认的docker-compose.yml,所以直接在docker-compose.yml所在目录下执行以上命令即可,如果不是这个名字,则需要用-f来指定启动的文件名 docker-compose up -f aaaa.yml

  • 查看服务日志

     

    查看Nginx发现还真有一个报错

    这个是因为主机没有开启Ipv6,虽然不影响启动,但是如果想吧这个去掉也很简单,修改一下Nginx的配置就可以了

      
  • 浏览器访问

     

    访问Nginx会以轮询的方式请求两个tomcat,如下

  • 启动服务

     
  • 停止服务

     
  • 列出所有运行容器

     
  • 查看服务日志

     
  • 构建或者重新构建服务

     
  • 启动服务

     
  • 重启服务

     
  • 停止已运行的服务

     
本文地址:http://ww.kub2b.com/news/13383.html     企库往 http://ww.kub2b.com/ ,  查看更多

特别提示:本信息由相关用户自行提供,真实性未证实,仅供参考。请谨慎采用,风险自负。

 
 
更多>同类最新文章
0相关评论

文章列表
相关文章
最新动态
推荐图文
最新文章
点击排行
网站首页  |  关于我们  |  联系方式  |  使用协议  |  版权隐私  |  网站地图  |  排名推广  |  广告服务  |  积分换礼  |  网站留言  |  RSS订阅  |  违规举报  |  鄂ICP备2020018471号