一、检测系统是否存在 Docker 以及 CentOS 镜像
1、检测系统是否存在 Docker 以及 CentOS 镜像
docker images # 查看当前镜像
docker --version # 查看 docker 的版本
2、如果没有 Docker 或者 CentOS 镜像需要先进行下载
yum -y install docker-io # linux centos下安装 docker
apt-get install docker.io # linux ubuntu下安装 docker
service docker start # 启动 docker
docker pull centos # 从镜像仓库中拉取 centos 镜像
二、创建基于 CentOS 镜像的:Dockerfile.web
1、进入 modules
目录,创建 Dockerfile.web
cd modules
vim Dockerfile.web
2、编辑 Dockerfile.web,定义 web 的运行环境(不同的语言对应的环境依赖包也就不同)
FROM centos
MAINTAINER <Armin>
RUN yum -y install gcc automake autoconf libtool make
RUN yum -y install gcc gcc-c++
RUN curl --silent --location https://rpm.nodesource.com/setup_8.x | bash -
RUN yum install -y nodejs
ADD web /opt/apps/web
WORKDIR /opt/apps/web
EXPOSE 4000
RUN npm install pm2 -g
CMD ["pm2-docker", "docker.yml"]
3、进入 modules
目录,创建 web 镜像
cd modules
docker build -t web:centos -f Dockerfile.web .
三、创建基于 CentOS 镜像的:Dockerfile.nginx
1、进入 modules
目录,创建 Dockerfile.nginx
cd modules
vim Dockerfile.nginx
2、编辑 Dockerfile.nginx,定义 nginx 的运行环境(nginx 的配置文件为 nginx.conf)
FROM centos
MAINTAINER <Armin>
RUN yum install -y gcc-c++
RUN yum install -y pcre pcre-devel
RUN yum install -y zlib zlib-devel
RUN yum install -y openssl openssl-devel
ADD nginx-1.12.0 /opt/nginx-1.12.0
WORKDIR /opt/nginx-1.12.0
RUN ./configure
RUN make
RUN make install
EXPOSE 80
ADD run.sh /usr/local/sbin/run.sh
RUN chmod 755 /usr/local/sbin/run.sh
CMD ["/usr/local/sbin/run.sh"]
RUN rm /usr/local/nginx/conf/nginx.conf
COPY devops/nginx.conf /usr/local/nginx/conf/nginx.conf
RUN echo "daemon off;">>/usr/local/nginx/conf/nginx.conf
3、进入 modules
目录,创建 nginx 镜像
cd modules
docker build -t nginx:centos -f Dockerfile.nginx .
四、创建基于 CentOS 镜像的:Dockerfile.redis
1、进入 modules
目录,创建 Dockerfile.redis
cd modules
vim Dockerfile.redis
2、编辑 Dockerfile.redis,定义 redis 的运行环境
FROM centos
MAINTAINER <Armin>
ADD epel-release-6-8.noarch.rpm /opt/epel-release-6-8.noarch.rpm
WORKDIR /opt
RUN rpm -ivh epel-release-6-8.noarch.rpm
RUN yum install -y redis
USER root
CMD ["/usr/bin/redis-server", "/etc/redis.conf"]
EXPOSE 6379
3、进入 modules
目录,创建 redis 镜像
cd modules
docker build -t redis:centos -f Dockerfile.redis .
五、使用 docker-compose 编排容器
1、进入 devops
目录,创建 compose.yml
cd devops
vim compose.yml
2、编辑 compose.yml
version: '3.0'
services:
redis:
image: redis:centos
web:
image: web:centos
volumes:
- ../web:/opt/apps/web
- ./data/log/web:/root/.pm2/logs
nginx:
image: nginx:centos
ports:
- '3003:80'
volumes:
- ../web/static:/opt/apps/web/static
- ./data/log/nginx:/var/log/nginx
- ./nginx.conf:/usr/local/nginx/conf/nginx.conf
depends_on:
- web
3、进入 devops
目录,执行 compose.yml 启动容器
cd devops
docker-compose -p fof -f compose.yml up -d
4、查看容器是否启动
docker ps
5、常用 docker-compose 命令
docker-compose up -d nginx # 构建建启动 nignx 容器
docker-compose exec nginx bash # 登录到 nginx 容器中
docker-compose down # 删除所有 nginx 容器,镜像
docker-compose ps # 显示所有容器
docker-compose restart nginx # 重新启动 nginx 容器
docker-compose build nginx # 构建镜像
docker-compose build --no-cache nginx # 不带缓存的构建
docker-compose logs nginx # 查看 nginx 的日志
docker-compose logs -f nginx # 查看 nginx 的实时日志
docker-compose events --json nginx # 以 json 的形式输出 nginx 的 docker 日志
docker-compose pause nginx # 暂停 nignx 容器
docker-compose unpause nginx # 恢复 ningx 容器
docker-compose rm nginx # 删除容器(删除前必须关闭容器)
docker-compose stop nginx # 停止 nignx 容器
docker-compose start nginx # 启动 nignx 容器
注:上面开发环境的构建和部署流程只是为了方便大家理解思路,有些配置文件和项目文件并没有放上去,望大家知晓!
六、知识点归纳
1、关于 dockerfile 的详解
FROM # 指定基础镜像 1、FROM <image> 2、 FROM <image>:<tag> 3、FROM <image>:<digest>; <tag>和<digest> 是可选项,默认为 latest
RUN # 运行指定的命令(构建容器时就运行) 1. RUN <command>(shell 命令) 2. RUN ["executable", "param1", "param2"](可执行文件,后面为两个参数)
CMD # 容器启动时运行的命令(构建容器时并不运行) 1. CMD ["executable","param1","param2"] 2. CMD ["param1","param2"] 3. CMD command param1 param2
MAINTAINER # 署名作者
EXPOSE # 暴露容器运行时的监听端口给外部
ENV # 设置环境变量
ADD # 复制文件到容器中(可以是本地文件也可以是一个 url)
COPY # 复制文件到容器中(只能是本地文件)
ENTRYPOINT # 启动时的默认命令,与 CMD相似,区别是 ENTRYPOINT 不会被运行的 command 覆盖,而 CMD 则会被覆盖
VOLUME # 可实现挂载功能,可以将本地文件夹或者其他容器中的文件夹挂载到这个容器中
WORKDIR # 设置工作目录,进入容器中指定的目录,如果目录不存在则会创建
USER # 设置启动容器的用户
2、关于 compose.yml 的详解
compose.yml 主要分为三个部分:services、networks、volumes
services:定义各个容器
networks:定义需要使用到的 network
volumes:定义services使用到的 volume
services:
build:使用当前目录下的 Dockerfile 进行构建
context:可以是 Dockerfile 的文件路径,也可以是到链接到 git 仓库的 url
image:指定运行容器使用的镜像
command:覆盖容器启动后默认执行的命令(Dockerfile 定义的 CMD)
entrypoint:可以覆盖 Dockerfile 中定义的 entrypoint 命令
env_file:定义了在 docker-compose.yml 中使用的变量, 封装变化
environment:定义的变量会覆盖 .env 文件中定义的重名环境变量
ports:端口映射
将容器的端口80映射到宿主机的端口8080:
ports:
- "8080:80"
- "127.0.0.1:8080:80"
volumes:挂载一个目录或者一个已存在的数据卷容器
- ../web:/opt/apps/web
- ./data/log/web:/root/.pm2/logs
depends_on:容器的依赖、启动的先后顺序
dns:自定义 DNS 服务器
tmpfs:挂载临时文件目录到容器内部
expose:暴露端口,但不映射到宿主机,只被连接的服务访问
- "3000"
- "8000"
external_links:链接到 docker-compose.yml 外部的容器
labels:使用 Docker 标签将元数据添加到容器
links:链接到其它服务中的容器,可以指定服务名称也可以指定链接别名
logging:配置日志服务
extends:扩展另一个服务
file: compose_new.yml
service: webapp
七、后记
关于学习 docker 的文档总结:
1、撰写 docker-compose.yml 文件参考
2、docker 官方文档
3、docker 中文文档
4、Docker修炼第一招: 先从Dockerfile开始