Docker compose单机编排工具
Docker compose单机编排工具
目录
docker-compose介绍
Compose是用于定义和运行多容器 Docker应用工具
通过Compose 可以使用YML文件来配置应用程序所需要的所有服务
Docker Compose使用的三步:
- 1.使用docker file 定义应用程序的环境
- 2.docker-compose定义构成应用程序的服务
- 3.启动Compose,就相当于启动应用
Docker Compose官方版本说明:
docker-compose安装部署
## yum安装docker Compose
yum install -y docker-compose(需要epel源)
## 官方下载方式
[root@db02 ~]$ cd /usr/local/bin/
[root@db02 /usr/local/bin]$ curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
## 加执行权限
[root@db02 /usr/local/bin]$ chmod +x /usr/local/bin/docker-compose
## 查看版本
[root@db02 /usr/local/bin]$ docker-compose version
Docker-compose语法
YAML语法
version: '版本号'
services:
服务名称1:
image: 容器镜像
container_name: 容器名称
environment:
- 环境变量1=值1
- 环境变量2=值2
volumes:
- 宿主机数据目录:容器内数据目录
- 宿主机目录路径:容器目录路径
- 驱动:容器目录路径
ports:
- 宿主机端口:容器内映射端口
networks:
- 自定义网络名称
links:
- namenode
depends_on:
- 依赖服务
command:
- 数据库使用字符集变量时可以用
restart: always
服务名称2:
image: 容器镜像
container_name: 容器名称
environment:
- 环境变量1=值1
- 环境变量2=值2
user: 宿主机用户:容器用户
volumes:
- 宿主机数据目录:容器内数据目录
- 宿主机目录路径:容器目录路径
- 驱动:容器目录路径
ports:
- 宿主机端口:容器内映射端口
networks:
- 自定义网络名称
links:
- namenode
depends_on:
- 依赖服务
restart: always
networks:
default:
externnal: true
name: 自定义网络名称
自动编排zabbix
前面使用了手动部署启动abbix
手动启动zabbix
## 手动启动zabbix
# 开启mysql容器,用于zabbix连接使用
docker run \
--name mysql56 \
-p 3306:3306 \
-e MYSQL_DATABASE=zabbix \ # 创建zabbix库
-e MYSQL_USER=zabbix \ # 创建zabbix用户
-e MYSQL_PASSWORD=zabbix \ # 给用户密码
-e MYSQL_ROOT_PASSWORD=123 \ # 给root用户密码
-d mysql:5.6 \
--character-set-server=utf8 \ # 指定字符集及校验规则
--collation-server=utf8_bin
# 开启zabbix-server容器
docker run \
--name zabbix-server-mysql \ # 定义容器名称
--link mysql56 \ # 与MySQL容器建立单向容器互通
-p 10051:10051 \ # 端口转发,服务端
-e DB_SERVER_HOST="mysql56" \ # 需要连接到的后端数据库容器名
-e MYSQL_USER="zabbix" \ # 连接后端数据库的用户
-e MYSQL_PASSWORD="zabbix" \ # 用户密码
-d zabbix/zabbix-server-mysql
# 开启zabbix前端容器
docker run \
--name zabbix-web-nginx-mysql \ # 定义容器名称
--link mysql56 \ # 与MySQL容器建立单向容器互通
--link zabbix-server-mysql \ # 与zabbix-server容器建立单向容器互通
-p 80:8080 \ # 用宿主机80代理zabbix前端8080端口
-e DB_SERVER_HOST="mysql56" \ # 需要连接到的后端数据库容器名
-e MYSQL_USER="zabbix" \ # 连接后端数据库的用户
-e MYSQL_PASSWORD="zabbix" \ # 用户密码
-e ZBX_SERVER_HOST="zabbix-server-mysql" \ # 指定zabbix服务端容器名称
-e PHP_TZ="Asia/Shanghai" \ # 指定时区
-d zabbix/zabbix-web-nginx-mysql
使用docker compose编排zabbix
[root@db02 /app/zabbix]$ vim docker-compose.yml
version: '3'
services:
mysql5.7: # 服务名称 自定义
image: mysql:5.7 # 使用的镜像
container_name: mysql5.7 # 容器名称
environment: # 变量定义
- MYSQL_ROOT_PASSWORD=123
- MYSQL_DATABASE=zabbix
- MYSQL_USER=zabbix
- MYSQL_PASSWORD=zabbix
volumes: # 文件映射
- /data/mysql/data:/var/lib/mysql
user: 1000:999 # 用户映射,本机的id为1000用户是mysql,容器的mysql用户id为999
ports: # 端口映射
- 3306:3306
command: # 字符集及校验规则
--character-set-server=utf8
--collation-server=utf8_bin
restart: always # 开启开机自启
zabbix-server:
image: zabbix/zabbix-server-mysql
container_name: zabbix-server
environment:
- DB_SERVER_HOST=mysql5.7
- MYSQL_USER=zabbix
- MYSQL_PASSWORD=zabbix
ports:
- 10051:10051
links: # 建立连接的容器名称
- mysql5.7
depends_on: # 依赖的服务名称,必须等被依赖的服务启动完成才能执行
- mysql5.7
restart: always
zabbix-web:
image: zabbix/zabbix-web-nginx-mysql
container_name: zabbix-web
environment:
- DB_SERVER_HOST=mysql5.7
- MYSQL_USER=zabbix
- MYSQL_PASSWORD=zabbix
- ZBX_SERVER_HOST=zabbix-server
- PHP_TZ=Asia/Shanghai
ports:
- 80:8080
links:
- mysql5.7
- zabbix-server
depends_on:
- mysql5.7
- zabbix-server
restart: always
# 启动
## 进入zabbix工作目录
[root@db02 ~]$ cd /app/zabbix
[root@db02 /app/zabbix]$ docker-compose up -d
## 选项:
-d:放后台运行
-f:指定编排的文件
注意事项:
在要编排的项目/服务目录中,最好只有一个docker-compose.yml文件,如果有多个,可以用-f指定文件,但不建议这样做
官方版MySQL compose
version: '3.1'
services:
db:
image: mysql
command: --default-authentication-plugin=mysql_native_password
restart: always
environment:
MYSQL_ROOT_PASSWORD: 123
adminer:
image: adminer
restart: always
ports:
- 8080:8080
links:
- db
访问10.0.0.51:8080
官方es compose
[root@db02 /app/es]$ vim docker-compose.yml
version: '2.2'
services:
es01:
image: docker.elastic.co/elasticsearch/elasticsearch:7.5.2
container_name: es01
environment:
- node.name=es01
- cluster.name=es-docker-cluster
- discovery.seed_hosts=es02
- cluster.initial_master_nodes=es01,es02
- bootstrap.memory_lock=true
- "ES_JAVA_OPTS=-Xms512m -Xmx512m"
ulimits:
memlock:
soft: -1
hard: -1
volumes:
- data01:/usr/share/elasticsearch/data
ports:
- 9200:9200
networks:
- elastic
es02:
image: docker.elastic.co/elasticsearch/elasticsearch:7.5.2
container_name: es02
environment:
- node.name=es02
- cluster.name=es-docker-cluster
- discovery.seed_hosts=es01
- cluster.initial_master_nodes=es01,es02
- bootstrap.memory_lock=true
- "ES_JAVA_OPTS=-Xms512m -Xmx512m"
ulimits:
memlock:
soft: -1
hard: -1
volumes:
- data02:/usr/share/elasticsearch/data
networks:
- elastic
kibana:
image: docker.elastic.co/kibana/kibana:7.5.2
ports:
- 5601:5601
networks: # 所有容器都使用bridge网络模式下的自定义elastic网卡,所以不再需要links模块
- elastic
environment:
SERVER_NAME: kibana.wj.com
ELASTICSEARCH_HOSTS: '["http://es01:9200"]'
volumes:
data01:
driver: local
data02:
driver: local
networks: # 自定义网卡
elastic:
driver: bridge
## 注意:
建议提前准备好elasticsearch和kibana的镜像,因为属实太大
[root@db02 /app/es]$ ll
total 1789124
-rw-r--r-- 1 root root 1344 Nov 19 11:58 docker-compose.yml
-rw-r--r-- 1 root root 790622720 Nov 19 11:32 es.tgz
-rw-r--r-- 1 root root 1041428992 Nov 19 15:36 kibana.tgz
# 利用docker load导入镜像即可
docker-compose常用命令
## 第一次启动
docker-compose up
## 放后台启动
docker-compose up -d
## 指定文件启动
docker-compose -f 文件名.yml up -d
## 查看进程
docker-compose ps
## 查看日志
docker-compose logs
## 查看单个服务日志
docker-compose logs [-f] 容器名称
## 停止
docker-compose stop
## 停止单个服务
docker-compose stop 容器名称
## 启动单个服务
docker-compose start 容器名称
## 重启
docker-compose restart
## 单个服务
docker-compose restart 容器名称