为项目配置docker
之前就了解过docker
,但是一直没有自己配置过docker
。这次自己为项目配置了一下docker,在这里做一下总结记录。
Dockerfile和docker-compose
首先,在以往的项目中,都是使用DockerFile + docker-compose
的形式来配置docker的,所以,首先就需要了解这两者的关系。
我们要知道的是,如果我们只使用dockerfile
就可以完成对docker的镜像配置。那么,为什么我们还要使用docker-compose
呢?
最开始是这样的,我们只是用docker中的一些命令,就可以实现配置一个镜像。但是这是有问题的:不能保存
。所以就是用dockerfile
将创建镜像的过程记录下来,然后我们只需要使用:
docker build
就可以创建一个镜像。
现在问题又来了:我想创建一个完整的项目,光是有一个镜像是不够的,比如我们的项目中就需要使用nginx
、mysql
、redis
才能够启动项目。
虽然我们也可以考虑使用一个dockerfile
,然后写成一个镜像,但是这就不可复用了。所以更加合理的做法应该是我们分别为nginx
、mysql
、redis
创建一个镜像,然后将这些镜像结合起来使用。
docker-compose
就是帮我们实现这个问题的。
所以,总结来说,dockerfile
是用来创建单个镜像的,而docker-compose
是用来创建一个项目的。
Dockerfile
首先先说一下dockerfile
的创建。在这个项目中,我们只写了一条语句:
FROM registry.cn-beijing.aliyuncs.com/mengyunzhi/nginx:1.13.12
FROM
是第一条命令,并且是必须的一条命令,它指定了基础镜像。
在这里,我们使用的基础镜像是托管在阿里docker仓库中的镜像。
我们也可以从docker官方仓库中获取镜像:
FROM nginx:1.13.12
但是有可能在拉取镜像的时候比较慢。
docker-compose
docker-compose
我们通过配置docker-compose.yml
来实现。
声明版本
version: '3'
这是声明我们要使用哪种版本的语法
的,不同版本的略有差异。
声明服务
按照我们上面所说,需要nginx
、mysql
、redis
三个镜像,也就是需要三个服务:
services: alice.mysql: alice.nginx: alice.redis:
然后我们以mysql
为例,说明需要哪些命令来构建service。
首先我们要使用上面创建的dockerfile
,对获取的镜像进行构建(build
)。
services: alice.mysql: build: context: ./mysql
context
选项指定了基础镜像。
然后就是image
:
services: alice.mysql: build: context: ./mysql image: mysql:5.7
image
指定了服务使用的镜像名,这个在我们没有上面的构建命令(build)时,会先找本地是否有对应的镜像,如果没有,compose
会尝试拉取镜像。
端口(ports
):
services: alice.mysql: build: context: ./mysql image: mysql:5.7 ports: - "3309:3306"
将docker容器的3306
端口映射到本地的3309
端口。
环境(environment
):
services: alice.mysql: build: context: ./mysql image: mysql:5.7 ports: - "3309:3306" environment: - MYSQL_USER=root - MYSQL_PASSWORD= - MYSQL_ALLOW_EMPTY_PASSWORD=true - MYSQL_DATABASE=alice
其实我更喜欢将这一部分叫做环境变量
,因为这部分是用来定义变量的。
最后,因为我们是要将多个服务结合起来,使项目运行的,所以就需要各个容器间进行通信。所以就需要使用网络(networks
)进行配置,将各个服务放在同一个局域网下:
services: alice.mysql: build: context: ./mysql image: mysql:5.7 ports: - "3309:3306" environment: - MYSQL_USER=root - MYSQL_PASSWORD= - MYSQL_ALLOW_EMPTY_PASSWORD=true - MYSQL_DATABASE=alice networks: aliceNetwork: ipv4_address: 172.28.8.4
这里使用了ipv4_address
为其分配了一个静态IP地址。
声明网络
上面我们使用了网络,那是为服务定义网络,其实在这之前,我们还需要定义一个自己的网络:
networks: aliceNetwork: ipam: config: - subnet: 172.28.8.0/24
这里声明了一个子网段,所以可以看到上面mysql
的网络是172.28.8.4
这种形式,其实只是从这个网段中随便选了一个。
完整配置文件:
# 版本号 version: '3' # 服务 services: alice.mysql: build: context: ./mysql image: mysql:5.7 ports: - "3309:3306" environment: - MYSQL_USER=root - MYSQL_PASSWORD= - MYSQL_ALLOW_EMPTY_PASSWORD=true - MYSQL_DATABASE=alice networks: aliceNetwork: ipv4_address: 172.28.8.4 alice.nginx: build: context: ./nginx image: nginx:1.13.12 volumes: - ./:/etc/nginx/conf.d - ./app:/usr/local/app ports: - 9000:80 - 9001:81 networks: aliceNetwork: ipv4_address: 172.28.8.3 alice.redis: build: context: ./redis image: redis:alpine ports: - "6380:6379" networks: aliceNetwork: ipv4_address: 172.28.8.5 networks: aliceNetwork: ipam: config: - subnet: 172.28.8.0/24
官方参考:
https://docs.docker.com/compo...
https://hub.docker.com/_/nginx