docker-compose.yaml示例
docker提供了一个工具docker-compose命令行,用于批量部署容器,docker-compose需要一个yaml文件(实质为文本文件),默认名字为docker-compose.yaml(docker-compose.yml)。如果熟悉k8s的同学可能对yaml并不是陌生,这里只是做一个笔记方便日后查询。version: '2'services: #服务定义 开始标签con...
·
docker提供了一个工具docker-compose命令行,用于批量部署容器,docker-compose需要一个yaml文件(实质为文本文件),默认名字为docker-compose.yaml(docker-compose.yml)。如果熟悉k8s的同学可能对yaml并不是陌生,这里只是做一个笔记方便日后查询。
version: '2'
services: #服务定义 开始标签
controller-node-192-168-2-2_1516689684: #服务名 只是一个名字而已没有实际意义
hostname: controller-node-192-168-2-2_1516689684 #对应linux系统 hostname 如果支持dns可通过hostname访问主机/容器
container_name: controller-node-192-168-2-2_1516689684 #容器名称
restart: always #启动方式 代表只要容器退出就立刻启动
networks:#网络配置
default:
ipv4_address: 192.168.2.2 #容器默认ip地址
image: sdotn-karaf-distribution:2.1.0-SNAPSHOT #使用镜像 如果本地不存在 将自动从远端拉取
environment: # 环境变量 可通过linux系统中env
- HOST_IP=10.85.160.123
- SERVER_IP=192.168.2.2
- JAVA_MIN_MEM=1G
- JAVA_MAX_MEM=8G
expose: #容器暴露的服务端口
- "8443"
- "8101"
ports: # 端口映射 host主机端口:容器内端口
- "15000:8443"
- "8101:8101"
volumes: #挂载卷
- "/var/run/data:/var/run/data"
volumes: #挂载卷
- "/var/run/tmp:/var/run/tmp"
networks: #网络定义 表示当前容器即将使用的网络为oscp-network
my-docker-network:
driver: bridge
ipam:
config:
- subnet: 192.168.1.0/24
gateway: 192.168.1.1
#如果当前环境中已经存在已经定义好的network,可直接使用
#networks:
# default:
# external:
# name: my-docker-network
我认为yaml文件比较难配置的就是networks这部分,这里把常用的两种方式都已经介绍了。
更多推荐
已为社区贡献3条内容
所有评论(0)