docker-compose.yaml示例

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这部分,这里把常用的两种方式都已经介绍了。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值