Docker Compose 部署服务

[toc]

Docker Compose 部署服务

需求分析:

假如现在我们手里有很多容器,每个容器对应每个服务,有nginx容器,redis容器,mysql容器等。现在我们需要批量化的去管理,批量启动,停止,重启等操作!

docker compose可以方便我们快捷高效地管理容器的启动、停止、重启等操作,它类似于linux下的shell脚本,基于yaml语法,在该文件里我们可以描述应用的架构,比如用什么镜像、数据卷、网络模式、监听端口等信息。我们可以在一个compose文件中定义一个多容器的应用(比如jumpserver),然后通过该compose来启动这个应用。

安装compose方法如下

下载的文件放在/usr/local/bin/下方便启动使用

curl -L https://github.com/docker/compose/releases/download/1.17.0-rc1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose

chmod 755 !$

docker-compose version 查看版本信息

Compose区分Version 1和Version 2(Compose 1.6.0+,Docker Engine 1.10.0+)。

Version 2支持更多的指令。Version 1没有声明版本默认是"version 1"。Version 1将来会被弃用。

[root@xavi ~]# docker-compose version
-bash: /usr/local/bin/docker-compose: 权限不够
[root@xavi ~]# chmod 777 /usr/local/bin/docker-compose
[root@xavi ~]# docker-compose version
docker-compose version 1.17.0-rc1, build a0f95af
docker-py version: 2.5.1
CPython version: 2.7.13
OpenSSL version: OpenSSL 1.0.1t  3 May 2016

定义一个docker compose 管理器

[root@xavi ~]# vim docker-compose.yml

version: "2"
services:
  app1:
    image: centos6_x64
    ports:
      - "8080:80"
    networks:
      - "net1"
    volumes: //数据卷
      - /data/:/data
  app2:
    image: centos_nginx_n
    networks:
      - "net2"
    volumes:
      - /data/:/data1
    entrypoint: tail -f /etc/passwd
networks:
  net1:
    driver: bridge
  net2:
    driver: bridge

详解:

version: "2"    //使用2版本
services:       //相关容器或者镜像操作
  app1:         //app1对应的是容器1的信息
    image: centos     //images的名字,必须是已经存在的镜像
    ports:          //映射端口
      - "8080:80"       //映射宿主机8080对应容器的80端口
    networks:       //网络(默认是bridge模式)
      - "net1"      //下面定义的net1(要是需要使用pipwork怎么办? 定义none即可)
    volumes:        //-v的参数指定
      - /data/:/data        //目录映射,本地的data目录和容器的目录映射
  app2:         //定义第2个容器信息
    image: centos_nginx //docker images中已经存在的images
    networks:
      - "net2"
    volumes:
      - /data/:/data1
    entrypoint: tail -f /etc/passwd     //还是老问题BUG 为了不让执行后关闭,我们使用这条命令
networks:
  net1:     //如上定义的
    driver: bridge      //定义网络模式
  net2:
    driver: bridge

检查测试:启动容器

[root@xavi ~]# docker-compose up -d
Creating network "root_net2" with driver "bridge"
Creating network "root_net1" with driver "bridge"
Pulling app2 (centos_nginx_n:latest)...
ERROR: pull access denied for centos_nginx_n, repository does not exist or may require 'docker login'

报错,镜像不存在,修改元编辑文件

mark

[root@xavi ~]# docker-compose up -d
Creating root_app2_1 ... 
Creating root_app1_1 ... 
Creating root_app2_1
Creating root_app1_1 ... done

查看docker-compose 帮助

docker-compose --help

mark

关于docker-compose语法的参考文档 http://www.web3.xin/index/article/182.html

[root@xavi ~]# docker-compose ps
   Name             Command         State    Ports 
---------------------------------------------------
root_app1_1   /bin/bash             Exit 0         
root_app2_1   tail -f /etc/passwd   Up       80/tcp

定义一个docker compose 管理器,也就是编辑yml文件,
可以把LNMP的服务nginx,php,mysql分三个容器出来,

mark

mark

nginx下的links:做了别名,方便访问php

mark

mark

转载于:https://blog.51cto.com/12995218/2140503

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值