赞
踩
目录
1.2 Docker-Compose 用来实现Docker容器快速编排
5.3 浏览器访问:http://192.168.19.101:1216
- Docker-Compose运行目录下的所有文件(docker-compose.yml,
- extends文件或环境变量文件等)组成一个工程,若无特殊指定工程名即为当前目录名。
-
- 一个工程当中可包含多个服务,每个服务中定义了容器运行的镜像、参数、依赖。
-
- 一个服务当中可包括多个容器实例,Docker-Compose并没有解决负载均衡的问题,
- 因此需要借助其它工具实现服务发现及负载均衡,比如Consul。
- 对象: 键值对的字典
- animal: pets
-
- 数组: 一组按次序排列的列表
- - cat
- - dog
- - goldfish
-
- 布尔值
- debug: "true"
- debug: "false"
-
-
- #Yaml示例
- languages: #序列的映射
- - Java
- - Golang
- - Python
- websites: #映射的映射
- Baidu: www.baidu.com
- Wangyi: www.163.com
- Souhu: www.souhu.com
-
-
- #或者
- languages: ["Java","Golong","Python"]
- websites:
- Baidu:
- www.baidu.com
- Wangyi:
- www.163.com
- Souhu:
- www.souhu.com
-
-
- #Json格式
- {
- languages: [
- 'Java',
- 'Golong',
- 'Python',
- ],
- websites: [
- Baidu: 'www.baidu.com',
- Wangyi: 'www.163.com',
- Souhu: 'www.souhu.com',
- ]
- }
字段 | 描述 |
build | 指定Dockerfile文件名(要指定的Dockerfile文件需要在build标签的子级标签中用dockerfile标签指定) |
dockerfile | 构建镜像上下文路径 |
context | 可以是dockerfile路径,或者是执行git 仓库的url地址 |
image | 指定镜像(已存在) |
command | 执行命令,会覆盖容器启动后默认执行的命令(会覆盖Dockerfile的CMD指令) |
container_name | 指定容器名称,由于容器名称是唯一的,如果指定自定义名称,则无法scale指定容器数量 |
deploy | 指定部署和运行服务相关配置,只能在Swarm模式使用 |
environment | 添加环境变量 |
networks | 加入网络,引用顶级networks下条目 |
network-mode | 设置容器的网络模式 |
ports | 暴露容器端口,与-p 相同,但是端口不能低于60 |
volumes | 挂载一个宿主机目录或命令卷到容器,命名卷要在顶级volumes 定义卷名称 |
volumes_from | 从另一个服务或容器挂载卷,可选参数 :ro 和 :rw,(仅版本‘2’支持) |
hostname | hostname |
hostname | 在容器内设置内核参数 |
links | 连接到另一个容器,- 服务名称[ : ] |
privileged | 用来给容器root权限,注意是不安全的,true |
restart | 重启策略,定义是否重启容器;1.no,默认策略,在容器退出时不重启容器。2.on-failure,在容器非正常退出时(退出状态非0),才会重启容器。3.on-failure:3,在容器非正常退出时重启容器,最多重启3次。4.always,在容器退出时总是重启容器。5.unless-stopped,在容器退出时总是重启容器,但是不考虑在Docker守护进程启动时就已经停止了的容器。 |
depends_on | 此标签用于解决容器的依赖,启动先后问题。如启动应用容器,需要先启动数据库容器php:depends_on:- apache- mysql |
字段 | 描述 |
---|---|
build | 重新构建服务 |
ps | 列出容器 |
up | 创建和启动容器 |
exec | 在容器里面执行命令 |
scale | 指定一个服务容器启动数量 |
top | 显示正在运行的容器进程 |
logs | 查看服务容器的输出 |
down | 删除容器、网络、数据卷和镜像 |
stop/start/restart | 停止/启动/重启服务 |
- mkdir -p /opt/compose_nginx/nginx
- cd /opt/compose_nginx/nginx/
- rz
- ls
- docker-compose nginx-1.12.2.tar.gz
-
- chmod +x docker-compose
- cp docker-compose /usr/local/bin
- docker-compose -v
- docker-compose version 1.21.1, build 5a3f1a3
-
-
- #编写dockerfile
- vim Dockerfile
-
- yum install -y tree
- tree
-
- FROM centos:7
- RUN yum -y update
- RUN yum -y install pcre-devel zlib-devel gcc gcc-c++ 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
- RUN make -j 4 && make install
- RUN ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/
- #ENV PATH /usr/local/nginx/sbin/:PATH
- EXPOSE 80
- EXPOSE 443
- RUN echo "daemon off;" >> /usr/local/nginx/conf/nginx.conf
- CMD ["/usr/local/nginx/sbin/nginx"]
- vim /opt/compose_nginx/docker-compose.yml
- version: '3' 1 2 3
- services:
- nginx:
- container_name: web1
- hostname: nginx
- build:
- context: ./nginx
- dockerfile: Dockerfile
- ports:
- - 1216:80
- - 1217:443
- networks:
- lnmp:
- ipv4_address: 172.18.0.10
- volumes:
- - ./wwwroot:/usr/local/nginx/html
- networks:
- lnmp:
- driver: bridge
- ipam:
- config:
- - subnet: 172.18.0.0/16
-
-
- cd /opt/compose_nginx/
- docker-compose -f docker-compose.yml up -d
-
- docker ps -a
- cd /opt/compose_nginx/
- docker-compose ps #必须在docker-compose.yml所在目录执行此命令
-
-f | --file FILE :使用特定的 compose 模板文件,默认为 docker-compose.yml |
-p | --project-name NAME :指定项目名称,默认使用目录名称 |
-d | 在后台运行 |
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。