Docker容器——compose

news/2024/7/5 13:16:10

文章目录

  • Docker Compose
    • 简介
    • YAML格式
    • 使用步骤
    • Docker compose配置常用字段
    • Docker compose常用命令
    • docker compose 命令参数详解
  • 编排实验
    • 环境部署
    • 构建nginx

Docker Compose

简介

Docker Compose前身是Fig,Fig被Docker收购之后正式更名为Compose,Compose向下兼容Fig

Docker Compose是一个用于定义和运行多容器Docker应用的工具,只需要一个Compose的配置文件和一个简单的命令就可以创建并运行应用所需的所有容器,而不再需要使用shell脚本来启动容器

Docker Compose 非常适合组合使用多个容器进行开发的场景

Docker Compose 的文件结构:

vim docker-compose.yml

YAML格式

① 不支持制表符Tab 建缩进,需要使用空格缩进
② 通常开头缩进2个空格
③ 字符后缩进1个空格,如:冒号,逗号,横杆
④ 用井号注释
⑤ 如果包含特殊字符用单引号引起来
⑥ 布尔值必须用单引号括起来

使用步骤

① 使用Dokcerfile 定义应用程序的环境
② 使用docker-compose.yml 定义构成应用程序的服务,这样它们就可以再隔离环境中一起运行
③ 最后执行 docker-compose up 命令来启动并运行整个应用程序

Docker compose配置常用字段

字段描述
build docker context指定Dockerfile文件名构建镜像上下文路径
image指定镜像
command执行命令,覆盖默认命令
container name指定容器名称,由于容器名称是唯一的,如果指定自定义名称,则无法scale
environment添加环境变量
networks加入网络
ports暴露容器端口,与-p相同,但不能低于60
volumes挂载宿主机路径或命令卷
restart重启策略,默认no,always,no-failure,unless-stoped
hostname容器主机名

Docker compose常用命令

命令描述
build重新构建服务
ps列出容器
up创建和启动容器
exec在容器里面执行命令
scale指定一个服务容器启动数量
top显示容器进程
logs查看容器输出
down删除容器、网络、数据卷和镜像
stop/start/restart停止/启动/重启服务

docker compose 命令参数详解

–verbose 输出更多调试信息
–version 打印版本并退出
-f,–file FILE 使用特定的compose 模板文件,默认位docker-compose.yml
-p,–project-name NAME 指定项目名称,默认使用目录名称

编排实验

环境部署

部署安装docker环境

yum install -y docker-ce 

docker–compose安装包
在这里插入图片描述

构建nginx

构建工作目录,将nginx拷贝到该目录

[root@bogon ~]# mkdir compose_nginx
[root@bogon ~]# cd compose_nginx/
[root@bogon ~/compose_nginx]# mkdir nginx
[root@bogon ~/compose_nginx]# cd nginx/
[root@bogon ~/compose_nginx/nginx]# rz -E
rz waiting to receive.
[root@bogon ~/compose_nginx/nginx]# ls
nginx-1.12.2.tar.gz
[root@bogon ~/compose_nginx/nginx]# vim run.sh

#!/bin/bash
/usr/local/nginx/sbin/nginx

在这里插入图片描述
编写Dockerfile

[root@bogon ~/compose_nginx/nginx]# vim dockerfile 

FROM centos:7
RUN yum -y update
RUN yum -y install gcc gcc-c++ pcre-devel zlib-devel make
RUN useradd -M -s /sbin/nologin nginx
ADD nginx-1.12.2.tar.gz /usr/local/src
WORKDIR /usr/local/src/nginx-1.12.2
RUN ./configure \
--prefix=/usr/local/nginx \
--user=nginx \
--group=nginx \
--with-http_stub_status_module && make && make install
ENV PATH /usr/local/nginx/sbin:$PATH
EXPOSE 80
EXPOSE 443
RUN echo "daemon off;" >> /usr/local/nginx/conf/nginx.conf
ADD run.sh /run.sh
RUN chmod 755 /run.sh
CMD ["/run.sh"]

编写nginx首页

[root@bogon ~/compose_nginx/nginx]# cd ..
[root@bogon ~/compose_nginx]# mkdir wwwroot
[root@bogon ~/compose_nginx]# cd wwwroot/
[root@bogon ~/compose_nginx/wwwroot]# vim index.html

<h1>this is chen web!</h1>

编写yml文件(注意编写目录)

[root@bogon ~/compose_nginx]# vim docker-compose.yml

version: '3'
services:
  nginx:
    hostname: nginx
    build:
      context: ./nginx
      dockerfile: dockerfile
    ports:
      - 1216:80
      - 1217:443
    network:
      - cluster
    volumes:
      - ./wwwroot:/usr/local/nginx/html
networks:
  cluster:

构建镜像

[root@localhost compose_nginx]# docker-compose -f docker-compose.yml up -d

查看容器

[root@bogon ~/compose_nginx]# docker ps -a
CONTAINER ID   IMAGE                 COMMAND     CREATED         STATUS         PORTS                                                                            NAMES
7346c3ca2573   compose_nginx_nginx   "/run.sh"   2 minutes ago   Up 2 minutes   0.0.0.0:1216->80/tcp, :::1216->80/tcp, 0.0.0.0:1217->443/tcp, :::1217->443/tcp   compose_nginx_nginx_1

访问192.168.80.10:1216
在这里插入图片描述


http://www.niftyadmin.cn/n/3652474.html

相关文章

HTTP:错误码

1xx-信息提示 表示临时的响应。客户端在收到常规响应之前&#xff0c;应准备接收一个或多个1xx响应。  100-继续。  101-切换协议。  2xx-成功 表明服务器成功地接受了客户端请求。  200-确定。客户端请求已成功。  201-已创建。  202-已接受。  203-非权威性信息。  2…

Docker----Consul介绍与安装

文章目录consul简介特点实验搭建server部署 192.168.80.10client部署 192.168.80.20配置template模块自动更新配置template测试测试访问代理服务器再添加一个节点consul简介 Consul是一个分布式、高可用的系统&#xff0c;是一个为了解决在生产环境中服务注册&#xff0c;服务…

某著名门户网站搜索部门笔试中的逻辑题

某著名门户网站搜索部门笔试中的逻辑题&#xff0c;如果能够做出来&#xff0c;我想逻辑思维和数学水平应该都不错。&#xff08;做题前不要去搜索答案&#xff0c;不然就不能考验出自己的逻辑能力了&#xff0c;呵呵&#xff09;1. 打牌&#xff0c;没有大小王&#xff0c;只有…

[转]MySQL5.1新特性翻译系列 - 通过分区(Partition)提升MySQL性能

来源&#xff1a;http://phpv.net/article.php/1514MySQL5.1新特性翻译系列 - 通过分区&#xff08;Partition&#xff09;提升MySQL性能几年前&#xff0c;俺写过一篇题为“The Foundation of Excellent Performance”的文章(现在仍然可以在http://www.tdan.com/i016fe03.htm看…

[转]Berkeley DB 数据库的优缺点

Berkeley DB 数据库的优缺点来源&#xff1a;http://www.nowboy.com/main/archives/52BDB官方网站&#xff1a;http://www.sleepycat.com/Sleepycat软件公司出品的Berkeley DB是一种在特定的数据管理应用程序中广泛使用的数据库系统,在世界范围内有超过两亿的用户支持.许多世界…

Docker----Harbor的介绍和安装

文章目录简介Harbor架构即组件介绍Harbor配置文件以及相关参数搭建Harbor私有仓库1、搭建环境2、下载Harbor安装程序3、配置Harbor参数文件4、启动Harbor5、浏览器访问UI界面创建项目6、在本地测试仓库功能7、客户端上传镜像维护管理Harbor1、停止Harbor实例2、修改Harbor.cfg配…

[转]MySQL 4.1 字符集支持的原理

MySQL 4.1 字符集支持的原理摘于&#xff1a; http://jjgod.3322.org/2005/07/31/a-mysql-41-story/ 下面要写的是一篇非常无聊的东西&#xff0c;充斥了大量各式各样的编码、转换、客户端、服务器端、连接……呃&#xff0c;我自己都不愿意去看它&#xff0c;但想一想&#…

Docker------Cgroup 简介和安装

文章目录Cgroup使用stress工具测试权重 --cpu-sharesCPU周期限制 --cpu-period、--cpu-quotaCPU Core控制 --cpuset-spusCPU配额控制参数的混合使用内存配额Block IO的限制bps和iops的限制Cgroup Docker通过Cgroup来控制容器使用的资源配额&#xff0c;包括cpu、内存、磁盘三个…