0


【docker系列】使用docker compose快速搭建wordpress博客

文章目录

一、3分钟完成wordpress安装

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

/usr/local/bin

目录,并重命名为docker-compose。

$ sudocurl -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://<linux宿主机服务器>:8000

你会看到下图,按照图形提示一步一步的设置你的博客就可以了。同样的你使用mysql客户端,可以访问该宿主机的3306端口,查看数据库数据。

二、背后隐藏了什么?

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.7volumes:- db_data:/var/lib/mysql
     restart: always
     environment:MYSQL_ROOT_PASSWORD: somewordpress
       MYSQL_DATABASE: wordpress
       MYSQL_USER: wordpress
       MYSQL_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: wordpress
       WORDPRESS_DB_PASSWORD: wordpress
       WORDPRESS_DB_NAME: wordpress

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

上文中通过volumes定义

/var/lib/mysql

映射到磁盘本地路径,我们并没有具体定义磁盘本地路径的位置,那么mysql的数据文件保存到哪里了?
我们通过

docker inspect compose_db_1

命令来查看一下,其中compose_db_1是上文中mysql镜像运行的服务容器名称。

compose

docker-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可不是这一篇文章能搞定的。那么我们一起向前进!

标签: 云原生 docker 容器

本文转载自: https://blog.csdn.net/hanxiaotongtong/article/details/124162598
版权归原作者 字母哥哥 所有, 如有侵权,请联系我们删除。

“【docker系列】使用docker compose快速搭建wordpress博客”的评论:

还没有评论