分类 Docker 下的文章

[TOC]

一、docker-compose.yml 示例

编写文件 docker-compose.yml

目录结构如下

docker-compose.yml
--eureka
----Dockerfile
----microservice-eureka-server-0.0.1-SNAPSHOT.jar

在docker-compose.yml文件添加内容

version: '2' #docker-compose.yml的文件格式版本
services:
  eureka: #指定服务名,随便取
    build: ./eureka #指定Dockerfile文件所在目录
    ports:
      - "8761:8761" #指定端口映射
    expose:
      - 8761 # 容器提供服务端口

docker-compose build

重新构建镜像

docker-compose up

运行所有容器。加上-d参数表示后台运行容器,加上--build参数表示运行容器前先重新构建镜像

docker-compose up -d --build

二、docker-compose.yml 常用指令

image

指定镜像名称或者镜像id,如果该镜像在本地不存在,Compose会尝试pull下来

示例:

image: java

container_name

指定容器的名称

build

指定Dockerfile文件的路径。若用此指令,则每次执行docker-compose up都会构建镜像。

可以是一个路径,例如:

build: ./dir

也可以是一个对象,用以指定Dockerfile和参数,例如:

build:
  context: ./dir
  dockerfile: Dockerfile
  args:
    buildno: 1

command

覆盖容器启动后默认执行的命令

示例:

command: bundle exec thin -p 3000

也可以是一个list,类似于Dockerfile总的CMD指令,格式如下:

command: [bundle, exec, thin, -p, 3000]

links

链接到其他服务中的容器。可以指定服务名称和链接的别名使用SERVICE:ALIAS的形式,或者只指定服务名称,示例:

web:
  links:
    - db
    - db:database
    - redis

external_links

表示链接到docker-compose.yml外部的容器,甚至并非Compose管理的容器,特别是对于那些提供共享容器或共同服务。格式跟links类似CONTAINER:ALIAS,示例:

external_links:
  - redis_1
  - project_db_1:mysql
  - project_db_1:postgresql

ports

暴露端口信息。使用宿主端口:容器端口的格式,或者仅仅指定容器的端口(此时宿主机将会随机指定端口),类似于docker run -p ,示例:

ports:
  - "3000"
  - "3000-3005"
  - "8000:8000"
  - "9090-9091:8080-8081"
  - "49100:22"
  - "127.0.0.1:8001:8001"
  - "127.0.0.1:5000-5010:5000-5010"

expose

暴露端口,只将端口暴露给连接的服务,而不暴露给宿主机,示例:

expose:
  - "3000"
  - "8000"

restart

容器的启动策略,有如下值可选:

  • no:默认策略,在容器退出时不重启容器
  • on-failure:容器非正常退出时(退出状态非0),才会重启容器
  • on-failure:3,在容器非正常退出时重启容器,最多重启3次
  • always:在容器退出时总是重启容器

volumes

卷挂载路径设置。可以设置宿主机路径 (HOST:CONTAINER) 或加上访问模式 (HOST:CONTAINER:ro)。示例:

volumes:
  # Just specify a path and let the Engine create a volume
  - /var/lib/mysql
 
  # Specify an absolute path mapping
  - /opt/data:/var/lib/mysql
 
  # Path on the host, relative to the Compose file
  - ./cache:/tmp/cache
 
  # User-relative path
  - ~/configs:/etc/configs/:ro
 
  # Named volume
  - datavolume:/var/lib/mysql

volumes_from

从另一个服务或者容器挂载卷。可以指定只读或者可读写,如果访问模式没有指定,则默认是可读写。示例:

volumes_from:
 - service_name
 - service_name:ro
 - container:container_name
 - container:container_name:rw

environment

设置环境变量。可以使用数组或者字典两种方式。只有一个key的环境变量可以在运行Compose的机器上找到对应的值,这有助于加密的或者特殊主机的值。示例:

environment:
  RACK_ENV: development
  SHOW: 'true'
  SESSION_SECRET:
 
environment:
  - RACK_ENV=development
  - SHOW=true
  - SESSION_SECRET

env_file

从文件中获取环境变量,可以为单独的文件路径或列表。如果通过 docker-compose -f FILE 指定了模板文件,则 env_file 中路径会基于模板文件路径。如果有变量名称与 environment 指令冲突,则以envirment 为准。示例:

env_file: .env
 
env_file:
  - ./common.env
  - ./apps/web.env
  - /opt/secrets.env

extends

继承另一个服务,基于已有的服务进行扩展。

network_mode

设置网络模式。采用与docker--network参数相同的值,添加了特殊格式service:[service name]

network_mode: "bridge"
network_mode: "host"
network_mode: "none"
network_mode: "service:[service name]"
network_mode: "container:[container name/id]"

networks

指定要加入的网络

services:
  some-service:
    networks:
     - some-network
     - other-network

dns

配置dns服务器。可以是一个值,也可以是一个列表。示例:

dns: 8.8.8.8
dns:
  - 8.8.8.8
  - 9.9.9.9

dns_search

配置DNS的搜索域,可以是一个值,也可以是一个列表,示例:

dns_search: example.com
dns_search:
  - dc1.example.com
  - dc2.example.com

三、参考文档

docker-compose文件官方文档

<!--使用Spring Cloud与Docker实战微服务-->

使用Spring Cloud与Docker实战微服务

[TOC]

一、安装

docker 具体安装步骤请参照 官方文档

查看 docker 版本

docker version

二、镜像

1.搜索镜像

docker search <搜索词>

搜索java相关镜像

docker search java

2.获取镜像

从 Docker Registry 获取镜像的命令是 docker pull <镜像名称[:TAG|@digest]>,参数如下:

  • -a, --all-tags:在仓库中下载所有标记的镜像

获取 ubuntu 镜像

# 获取最新的 ubuntu 镜像
docker pull ubuntu:latest
# TAG 默认是 latest
docker pull ubuntu
# 获取 ubuntu 16.04 镜像
docker pull ubuntu:16.04

3.列出镜像

列出已经下载的镜像命令是 docker images,可选参数:

  • -a, --all:列出所有镜像 (默认隐藏中间层镜像)
  • --digests:显示镜像的摘要信息
  • -f, --filter <filter>:显示满足条件的镜像
  • --format <string>:使用 Go 模板语法列出镜像
  • --no-trunc:不截断输出,显示完整镜像信息
  • -q, --quiet:只显示镜像 ID

如:列出本地已下载的镜像

docker images

4.删除镜像

使用 docker rmi <镜像名> 删除镜像

如:删除镜像 ubuntu 16.04

docker rmi ubuntu:16.04

删除所有无名称的镜像(悬空镜像)

docker rmi $(docker images -f "dangling=true" -q)

<!--docker image prune-->

三、容器

1.创建并启动容器

创建并启动容器的命令是 docker run,它的参数有

-t:让Docker分配一个伪终端(pseudo-tty)并绑定到容器的标准输入上

-i:附加到容器的标准输入(进入交互模式)

-d, --detach:在后台启动容器

--name:为容器指定一个名称

-P:随机端口映射

-p:指定端口映射。如 -p 8080:80 表示将宿主机的8080端口映射到容器的80端口

--net:指定网络模式,该选项有以下可选参数

  • --net=brige:默认选项,表示连接到默认的网桥
  • --net=host:容器使用宿主机的网络(该模式下-p参数无效)
  • --net=container:<容器名称或id>:让容器使用已有容器的网络配置
  • --net=none:不使用该容器的网络,用户可以自定义网络配置

下命令表示启动一个nginx容器,容器名称为mynginx,并将宿主机的8080端口映射到容器的80端口

docker run -d -p 8080:80 --name=mynginx nginx

2.停止运行中的容器

使用 docker stop <容器名称或id> 停止一个运行中的容器。参数如下:

  • -t, --time <int>:停止前等待的时间,默认为 10(单位:秒)

如:停止mynginx容器

docker stop mynginx

3.启动终止的容器

使用 docker start <容器名称或id> 启动一个已经停止的容器。参数如下

  • -a, --attach:附加到容器的标准输出
  • -i:附加到容器的标准输入(进入交互模式)

如:再次启动mynginx容器

docker start mynginx

4.重启容器

使用 docker restart <容器名称或id> 重启容器。参数如下:

  • -t, --time <int>:停止前等待的时间,默认为 10(单位:秒)

如:重启mynginx容器

docker restart mynginx

5.进入容器

使用 docker exec -it <容器名称或id> /bin/bash 进入容器并启动bash,示例:

docker exec -it mynginx /bin/bash

6.删除容器

使用 docker rm <容器名称或id> 删除容器。参数如下:

  • -f, --force:强制删除正在运行的容器(使用 SIGKILL)
  • -l, --link:删除指定的链接
  • -v, --volumes:删除与容器关联的卷

如:删除mynginx容器

docker rm mynginx

删除所有处于终止状态的容器

docker rm $(docker ps -a -q)

四、文件传输

  1. 将容器文件拷贝至主机
docker cp <容器名称或id>:<容器中文件路径> <宿主机中目标路径>

如:将mynginx容器的 /tmp/test.json 文件拷贝到主机 ~/Desktop 目录

docker cp mynginx:/tmp/test.json ~/Desktop
  1. 将主机文件拷贝至容器
docker cp <文件路径> <容器名称或id>:<容器中文件目标路径>

如:将主机的 ~/Desktop/foo.txt 文件拷贝至容器 mynginx 的 /var 目录

docker cp ~/Desktop/foo.txt mynginx:/var