docker-compose

docker-compose

容器一键化部署的工具,针对Dockerfile,可以按照定制化的模式一键部署dockerfile创建容器。

[root@docker1 opt]# rz -E
rz waiting to receive.
[root@docker1 opt]# ls
docker-compose-linux-x86_64
[root@docker1 opt]# mv docker-compose-linux-x86_64 /usr/local/bin/docker-compose[root@docker1 opt]# chmod 777 /usr//local/bin/docker-compose 
[root@docker1 opt]# docker-compose --version
Docker Compose version v2.18.0
​

定制:yaml配置文件格式

#yaml是一种标记语言,直观的展示数据序列化的格式,可读性高。
#数据格式的结构是通过缩进来进行表示的。
#1、大小写严格区分
#2、通过缩进表示层级关系
#3、不能用tab缩进,不许用空格键缩进
#4、#可以注释
#5、符号后必须缩进一格
#6、特殊字符必须要用单引号,字符串用双引号
#数据结构
name: "wbl"
age: 23
isStudent: 'true'/falsea
#字符串,整数,布尔类型,也可以是小数点
#列表结构,表示有序的元素的集合,使用-开头
xy102:
  - wbl
  - dly
  - cyp
#maps(映射),相当于字典或者对象,用键值对表示
man:
  name: wbl
  age: 23
#多行文本块:用|
shuoming: |
  this is xy102
  wbl this first
  ta 23 le
​

docker-compose

ps      基于docker-compose拉取的镜像生成的容器
up      docker-compose 创建和启动容器
scale   创建容器的数量
top     显示容器的进程
logs    看容器的输出日志
stop start  停止、启动、重启
down     删除容器,网络,数据卷,镜像
[root@docker1 opt]# docker-compose -f docker-compose.yaml up -d
docker-compose:使用docker-compose一键编排容器
-f:  使用模板文件,必须是.yml结尾
up:启动
-d:后台运行
​
[root@docker1 opt]# cp -r nginx/ nginx1/
[root@docker1 opt]# ls
docker-compose.yaml  mysql  mysql1  nginx  nginx1  nhtml  php
​
[root@docker1 opt]# vim docker-compose.yaml 
version: '3'
#定义docker-compose文件的版本,2.0之后都是3,顶格写就是全局使用
services:
#定义镜像和容器的配置:
  nginx:
version: '3'
#定义docker-compose文件的版本,2.0之后都是3,顶格写就是全局使用
services:
#定义镜像和容器的配置:
  nginx:
    container_name: web1
#定义容器的名字,web1
    hostname: nginx1
#定义创建好之后,容器的主机名
    build:
#构建的是dockerfile
      context: /opt/nginx1
#声明上下文,上文是构建dockerfile,下文是context,告诉你dockerfile的路径
      dockerfile: Dockerfile
    ports:
#声明宿主机和容器的端口映射    
      - 80:80
      - 443:443
    networks:
#指定容器的ip地址    
      mynet:
        ipv4_address: 172.18.0.10
    volumes:
#创建容器挂载卷    
      - /opt/nhtml:/usr/local/nginx/html/
networks:
  mynet:
    driver: bridge
    ipam:
      config:
        - subnet: 172.18.0.0/16
#创建自定义网络        
[root@docker1 opt]# docker-compose -f docker-compose.yaml up -d
[root@docker1 opt]# ls
docker-compose.yaml  mysql  mysql1  nginx  nginx1  nhtml  php
[root@docker1 opt]# cd nhtml/
[root@docker1 nhtml]# ls
[root@docker1 nhtml]# echo 123 > index.html
[root@docker1 nhtml]# curl 192.168.65.51
123
​

[root@docker1 opt]# vim docker-compose.yml 
version: '3'
services:
  nginx1:
    container_name: web1
    hostname: nginx1
    build:
      context: /opt/nginx
      dockerfile: Dockerfile
    ports:
      - 80:80
      - 443:443
    networks:
      mynet:
        ipv4_address: 172.18.0.10
    volumes:
      - /opt/nhtml:/usr/local/nginx/nhtml/
​
  mysql1:
    container_name: web2
    hostname: mysql1
    build:
      context: /opt/mysql
      dockerfile: Dockerfile
    ports:
      - 3306:3306
    networks:
      mynet:
        ipv4_address: 172.18.0.11
    volumes:
      - /opt/mysql1:/opt/mysql/
​
  php1:
    container_name: web3
    hostname: php1
    build:
      context: /opt/php
      dockerfile: Dockerfile
    ports:
      - 9000:9000
    networks:
      mynet:
        ipv4_address: 172.18.0.12
networks:
  mynet:
    driver: bridge
    ipam:
      config:
        - subnet: 172.18.0.0/16
​
[root@docker1 opt]# docker-compose -f docker-compose.yml up -d
[+] Building 0.0s (0/0)                                                                           
[+] Running 4/4
 ✔ Network opt_mynet  Created                                                  0.1s 
 ✔ Container web3     Started                                                  9.4s 
 ✔ Container web1     Started                                                  9.5s 
 ✔ Container web2     Started                                                  9.4s 

1

  • 15
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`docker-compose`是一个用于管理应用及其依赖环境的强大工具。它允许开发者通过单个YAML文件配置应用程序的所有服务、网络和卷,并使用一个命令启动整个应用环境。以下是关于`docker-compose`的一些基本概述: ### `docker-compose`的主要用途 1. **简化部署**:通过将所有服务、依赖项和配置信息组织在一个地方,`docker-compose`使得应用的部署过程变得简单而统一。 2. **跨平台一致性**:无论您是在本地开发环境中还是在生产服务器上运行应用,`docker-compose`都能提供一致的体验。 3. **便于维护**:对于有多个微服务的应用程序,`docker-compose`帮助保持各个组件之间的相互依赖性和配置的一致性。 4. **快速迭代**:支持快速测试和修改服务配置,无需每次都重启容器。 5. **集成自动化**:可以轻松地将构建、测试、部署等步骤整合到CI/CD流程中。 ### 使用示例 假设有一个简单的Web应用,包含前端(React)和服务端(Node.js)。我们可以创建两个Dockerfile分别构建这两个服务,并编写一个`docker-compose.yml`文件来定义它们以及它们之间的连接。 ```yaml version: '3' services: web: build: . ports: - "8080:80" depends_on: - db db: image: postgres:latest ``` 在这个例子中,我们定义了两个服务:web和服务端数据库。`web`服务使用当前目录下的Dockerfile进行构建,并将其暴露在外部主机的8080端口上。同时,它依赖于名为`db`的服务。这意味着在启动web服务之前,数据库服务会先启动并准备就绪。 ### 安装和运行 通常,您需要安装`docker`和`docker-compose`。然后,只需在包含`docker-compose.yml`文件的项目根目录下执行以下命令即可启动应用: ``` docker-compose up ``` 这个命令将会根据`docker-compose.yml`文件的内容启动所有指定的服务,并自动处理依赖关系。当所有的服务都已准备好时,终端将显示一条确认消息。 ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值