Docker高级管理
Docker网络通信
Docker单击网络拓扑图
端口映射
- 端口映射机制将容器内的服务提供给外部网络访问
- 可随机或指定映射端口范围
docker run -d -P httpd:centos
docker run -d -p 49880:80 httpd:centos
容器互联
- 在源容器和接受容器间建立一条网络通信隧道
- 使用docker run命令–link选项实现容器间互联通信
实现容器互联
docker run -d -P
docker run -d -P
docker exec -it web2 /bin/bash
ping web1
Docker Compose 容器编排
- Docker Compose 的前身是Fig,他是一个定义及运行多个Docker容器的工具
- 使用Docker Compose不在需要使用shell脚本来启动容器
- Docker Compose非常适合组合使用多个容器进行开发的场景
Docker Compose环境安装
mkdir /root/compose_nginx
mount.cifs
cp docker-compose /usr/local/bin/
chmod +x /usr/local/bin/docker-compose
Docker Compose文件结构
cd /root/compose_nginx/
vim docker-compose.yml
version: '3'
services:
nginx:
hostname: nginx
build:
context: ./nginx
dockerfile: Dockerfile
ports:
- 1216:80
- 1217:443
networks:
- cluster
volumes:
- ./wwwroot:/usr/local/nginx/html
networks:
cluster:
YAML是一种标记语言很直观的数据序列化格式
文件格式及编写注意事项
- 不支持制表符tab键缩进,需要使用空格缩进
- 通常开头缩进2个空格
- 字符后缩进1个空格,如冒号、逗号、横杆
- 用#号注释
- 如果包含特殊字符用但引号引起来
- 布尔值必须用户引号括起来
Docker Compose配置常用字段
字段 | 描述 |
---|
build dockerfile context | 指定Dockerfile文件名构建镜像上下文路径 |
image | 指定镜像 |
command | 执行命令,覆盖默认命令 |
container name | 指定容器名称,由于容器名称是唯一的,如果指定自定义名称,则无法scale |
deploy | 指定部署和运行服务相关配置,只能在Swarm模式使用添加环境变量 |
environment | 添加环境变量 |
networks | 加入网络 |
ports | 暴露容器端口,与-p相同,但端口不能低于60 |
volumes | 挂载宿主机路径或命令卷 |
restart | 重启策略,默认no,always,no-failure,unless-stoped |
hostname | 容器主机名 |