> 文档中心 > 使用docker compose快速搭建wordpress博客

使用docker compose快速搭建wordpress博客

文章目录

    • 一、3分钟完成wordpress安装
    • 二、背后隐藏了什么?
    • 三、再深入一点:数据到底存哪了?

一、3分钟完成wordpress安装

废话不多说上来就安装,先看疗效再看药理。这个安装过程就这么三步,需要多长时间呢?如果网络条件好的话,大概三分钟就搞定。(使用docker conpose安装的前提是你的服务器已经安装了docker,怎么安装?可以看我的《CentOS操作系统安装DockerCE》)
第一步: 安装Docker Compose,使用下面的命令行直接安装。实际上该命令的作用就是下载docker compose二进制文件,并将二进制文件存储到/usr/local/bin目录,并重命名为docker-compose。

$ sudo curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

第二步: 书写一个docker compose配置文件docker-compose.yml,我已经书写好了,大家去这里下载docker-compose.yml 。这个文件定义的内容我会在后文为大家讲解。

第三步:docker-compose.yml的同一个目录下执行命令/usr/local/bin/docker-compose up -d 完成服务启动。就是这么简单我已经安装完成了,访问http://:8000你会看到下图,按照图形提示一步一步的设置你的博客就可以了。同样的你使用mysql客户端,可以访问该宿主机的3306端口,查看数据库数据。
使用docker compose快速搭建wordpress博客

二、背后隐藏了什么?

docker compose可以认为是一组容器服务的组合,容器服务的定义方式核心的三段:version指定docker-compose.yml 文件的版本;services配置容器组合中包含哪些具体的服务;volumes用于定义容器中目录与宿主机之间的目录映射。我们来重点说明下services配置段启动的两个服务容器:mysql和wordpress,都做了哪些配置。

  • 第一段db定义了一个mysql数据库,使用的docker容器镜像是mysql:5.7;volumes将容器内的数据持久化保存到宿主机,避免容器服务重启之后数据库数据丢失。restart表示容器如果是停止状态(如果不是人为停止),会尝试重启保持服务运行。environment定义了一些环境变量,比如:mysql的root密码,数据库实例名称,访问该mysql实例的用户名,密码(可以根据自己的需要修改哦)。
   db:     image: mysql:5.7     volumes:- db_data:/var/lib/mysql     restart: always     environment:MYSQL_ROOT_PASSWORD: somewordpressMYSQL_DATABASE: wordpressMYSQL_USER: wordpressMYSQL_PASSWORD: wordpress
  • 第二段wordpress容器服务,depends_on表示该容器服务依赖于上文的mysql,需要先启动mysql容器,再启动wordpress容器; image表示默认使用的容器镜像是wordpress最新版(latest),这个容器镜像里面默认安装了apache web服务、php相关的依赖、mysql客户端等; ports表示端口映射,将容器内apache服务的80端口映射到宿主机的8000端口;environment指定了一些环境变量,用于访问mysql数据库(所以和上文中的定义要一致)。
   wordpress:     depends_on:- db     image: wordpress:latest     ports:- "8000:80"     restart: always     environment:WORDPRESS_DB_HOST: db:3306WORDPRESS_DB_USER: wordpressWORDPRESS_DB_PASSWORD: wordpressWORDPRESS_DB_NAME: wordpress

三、再深入一点:数据到底存哪了?

上文中通过volumes定义/var/lib/mysql映射到磁盘本地路径,我们并没有具体定义磁盘本地路径的位置,那么mysql的数据文件保存到哪里了?
我们通过docker inspect compose_db_1命令来查看一下,其中compose_db_1是上文中mysql镜像运行的服务容器名称。composedocker-compose.yml 文件所在父目录的名称,db是上文中service定义的名称,1就是一个自增序号。

 "Mounts": [     {  "Type": "volume",  "Name": "compose_db_data",  "Source": "/var/lib/docker/volumes/compose_db_data/_data",  "Destination": "/var/lib/mysql",  "Driver": "local",  "Mode": "rw",  "RW": true,  "Propagation": ""     } ]

我们可以看到 "Source": "/var/lib/docker/volumes/compose_db_data/_data",这里表示的就是上文中启动的mysql容器的默认持久化数据保存路径。那么下一个问题,如果我们不希望保存到这个路径怎么办?

     volumes:- db_data:/var/lib/mysql

docker-compose.yml配置文件改成这样即可

     volumes:- <你希望指定的本地宿主机绝对路径>:/var/lib/mysql

本文只是用一个最简单的例子,来向大家说明docker compose的高效、简洁。如果想要深入的学习docker、docker compose可不是这一篇文章能搞定的。那么我们一起向前进!