Docker compose学习笔记

1、compose

compose 做用

你的应用可能须要不少个服务,好比web服务,数据库服务,缓存服务等等。咱们能够把这些服务放到单独的容器里面,若是手工去配置这些服务会有些麻烦,docker compose能够帮咱们解决这个问题。 咱们能够建立一个compose文件,在这个文件上面描述你都须要哪些服务,服务使用什么镜像、数据卷、网络等等,而后再用一条命令就能够管理、启动全部的服务。html

compose 文件

compose文件用的yml格式,docker规定了一些指令,使用它们能够去设置对应的东西,它主要分为了3个区域:nginx

  • services:是服务,在它下面能够定义应用须要的一些服务,每一个服务都有本身的名字、使用的镜像、挂载的数据卷、所属的网络、依赖哪些其余服务等等;
  • networks:是应用的网络,在它下面能够定义应用的名字、使用的网络类型等等;
  • volumes:是数据卷,在它下面能够定义的数据卷(名字等等),而后挂载到不一样的服务下去使用;

2、Services

先建立一个文件夹beck-docker,并在里面新建docker-compose.yml文件,而后使用version指定一下compose使用的版本号。web

mkdir sample
cd sample
echo "version: '2'">docker-compose.yml

定义服务

在应用里须要定义的服务,能够放到services下面。好比,咱们去定义一个dog的服务,使用nginx镜像,指定主机上的8080端口映射到容器中得80端口,也就是nginx的http的访问端口。docker

services: 
  dog: 
    image: nginx
    ports: 
      - "8080:80"

以一样的方式,定义一个cat的服务,一样使用nginx镜像,而后指8081端口对应80端口。数据库

services: 
  cat: 
    image: nginx
    ports: 
      - "8081:80"
须要注意的是,cat与dog要在同一个级别,还有ports是个数组,能够指定多个端口映射关系, 每一个端口一行。

启动服务

定义好服务之后,在项目的目录启动这些服务,能够执行:数组

docker-compose up

这样会启动,在compose文件下定义的全部服务。因为这是第一次启动这个服务,因此能够看到它是creating,也就是去建立相关的东西。首先会建立这个服务使用的网络,这里是叫作「sample_default」的网络,而后是dog和cat的服务,这些网络和服务的名字,默认会加上一个前缀,因为在建立应用的时候没有指定名字,因此会默认使用项目目录的名字,后面还有一个数字的后缀。最后会有一个「Attaching to …」,将网络应用到服务上。 启动成功后,在浏览器访问一下。8080对应的是dog的服务,8081是cat的服务。浏览器

回到终端,能够看到服务的访问日志,日志的开头会有服务的名字,标志着日志是从哪一个服务来的。
若是但愿服务在后台运行,可使用-d选项(也就是detach):
docker-compose up -d

服务的生命周期

查看正在运行的服务缓存

docker-compose ps

中止一个服务bash

docker-compose stop [服务名]

若是后面不加服务名,会中止全部的服务网络

启动一个服务

docker-compose start [服务名]

若是后面不加服务名,会启动全部的服务

查看服务运行的log

docker-compose logs -f [服务名]

若是后面不加服务名,会显示全部的服务log

进入服务容器中

docker-compose exec {服务名} bash

删除服务

docker-compose rm [服务名]

若是后面不加服务名,会删除全部的服务

注意这个docker-compose rm不会删除应用的网络和数据卷。查看一下网络,能够看到应用建立的网络「sample_default」,若是要删除全部的这些,可使用:
docker-compose down

3、Networks

网络决定了服务之间以及服务和外界之间如何去通讯,在执行docker-compose up的时候,docker会默认建立一个默认的网络,建立的服务也会默认地属于这个默认网络。服务和服务之间,可使用服务的名字进行通讯。也能够本身建立网络,并将服务属于到这个网络之中,这样服务之间能够相互通讯,而外界就不可以与这个网络中的服务通讯,能够保持隔离性。 经过如下指令查看网络

docker-compose network ls

经过如下执行测试dog和cat服务的网路是否联通

docker-compose exec dog ping cat

自定义网络

一、在networks中先定义一个名为animal,类型为bridge的网络:

networks:
  animal:
    driver: bridge

二、让dog和cat服务使用这个网络:

  dog: 
    image: nginx
    ports: 
      - "8080:80"
    networks:
      - "animal"
  cat: 
    image: nginx
    ports:
      - "8081:80"
    networks:
      - "animal"

三、再增长一个叫pig的服务,使用默认网络,来体现于自定义网络的隔离性:

  pig:
    image: nginx
    ports:
      - "8082:80"
    networks:
      - "default"

四、从新启动应用

docker-compose restart

五、测试cat服务,与dog服务和pig服务的网络连通性:

docker-compose exec cat ping dog
docker-compose exec cat ping pig
由于cat与dog同在animal网络,因此能够经过名字链接,而pig在default网络中,因此不能。

4、Volumes

在compose文件中,还能够指定一些有名字的数据卷,让服务去使用。方法是:在与networks同级的地方,添加volumes,接着是数据卷的名字,下面使用driver去指定数据卷的类型。
volumes:
  nest:
    driver: local
定义好数据卷后,就将这个数据卷交给一个服务去使用。能够用volumes给服务指定须要使用的数据卷,冒号左边是数据卷名称,冒号右边是挂载到的docker对应目录位置。
  dog: 
    image: nginx
    ports: 
      - "8080:80"
    networks:
      - "animal"
    volumes:
      - "nest:/mnt"

  cat: 
    image: nginx
    ports:
      - "8081:80"
    networks:
      - "animal"
    volumes:
      - "nest:/mnt"

回到终端,执行docker-compose restart,下面测试一下数据卷。

docker-compose exec dog bash
cd /mnt
touch data1
ls
exit

docker-compose exec cat bash
cd /mnt
ls

由于cat与dog服务都使用nest的数据卷,因此在dog中/mnt目录下建立的data1,在cat服务的/mnt目录下能够看到。

指定位置的数据卷

dog和cat都是一个web服务,如今我想将主机的某一个位置当作是服务的一个内容,那么咱们能够去创一个指定位置的数据卷。首先能够在当前目录,建立./web文件夹,在里面建立个index.html。

mkdir web
touch index.html

编辑内容:

<html lang="zh-CN">
  <head>
    <meta charset="utf-8">
    <title>sample</title>
  </head>
  <body>
hello~~~~~
  </body>
</html>

 

从新启动一下docker-compose restart, 访问dog服务和cat的服务。

相关文章
相关标签/搜索