Docker-compose运行wordpress示例

本文介绍如何使用Docker和docker-compose快速部署WordPress和MySQL,并通过示例展示如何查看MySQL中的用户表信息。

准备工作

安装docker-compose
然后把mysql:5.7和wordpress:latest的镜像拉下来

docker pull mysql:5.7
docker pull wordpress

选择任一位置新建项目文件夹

mkdir -p /opt/compose/wordpress

进入上述目录,新建docker-compose.yml文件

touch docker-compose.yml

编辑上述文件,填入以下内容

version: "2"
services:
   db:
     image: mysql:5.7
     volumes:
       - db_data:/var/lib/mysql
     restart: always
     environment:
       MYSQL_ROOT_PASSWORD: wordpress
       MYSQL_DATABASE: wordpress
       MYSQL_USER: wordpress
       MYSQL_PASSWORD: wordpress

   wordpress:
     depends_on:
       - db
     image: wordpress:latest
     ports:
       - "8001:80"
     restart: always
     environment:
       WORDPRESS_DB_HOST: db:3306
       WORDPRESS_DB_USER: wordpress
       WORDPRESS_DB_PASSWORD: wordpress
volumes:
    db_data:

运行项目

/opt/compose/wordpress目录内执行docker-compose执令

docker-compose up

可以看到项目正在启动运行。
在这里插入图片描述
启动之后,在浏览器上输入映射后的端口,即IP:8001
可以看到wordpress项目已经正常启动。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

查看mysql中的用户表

查看当前docker中正在运行的容器

docker container ls

在这里插入图片描述
使用docker exec执令进入mysql交互端
其中5d15989cb3f2 是容器的ID

docker exec -it 5d15989cb3f2 bash

接下来像正常操作mysql一样,默认密码是wordpress
在这里插入图片描述
操作数据库

show databases;
use wordpress;
show tables;
select * from wp_users;

在这里插入图片描述
在这里插入图片描述
可以看到我们自己新增加的用户信息。
在这里插入图片描述

<think> 我们参考了上述引用内容,特别是引用[2]和引用[3]中关于使用Docker Compose部署WordPress的步骤。下面将提供一个清晰的、逐步的部署指南。请注意,我们将结合最佳实践和常见配置进行说明。 ### 使用Docker Compose部署WordPress的详细步骤 #### 1. 准备工作 - 确保已安装DockerDocker Compose。如果没有安装,请参考官方文档进行安装。 - 安装Docker: https://docs.docker.com/engine/install/ - 安装Docker Compose: https://docs.docker.com/compose/install/ - 创建一个项目目录,用于存放`docker-compose.yml`文件和其他相关文件。 #### 2. 创建`docker-compose.yml`文件 在项目目录中创建`docker-compose.yml`文件,并写入以下内容。这里我们使用一个典型的配置,包括WordPress服务和MySQL数据库服务。 ```yaml version: '3.8' services: db: image: mysql:5.7 volumes: - db_data:/var/lib/mysql environment: MYSQL_ROOT_PASSWORD: your_mysql_root_password MYSQL_DATABASE: wordpress MYSQL_USER: wordpress MYSQL_PASSWORD: your_mysql_password restart: always networks: - wordpress_net wordpress: depends_on: - db image: wordpress:latest ports: - "8080:80" restart: always environment: WORDPRESS_DB_HOST: db:3306 WORDPRESS_DB_USER: wordpress WORDPRESS_DB_PASSWORD: your_mysql_password WORDPRESS_DB_NAME: wordpress volumes: - wordpress_data:/var/www/html networks: - wordpress_net volumes: db_data: wordpress_data: networks: wordpress_net: ``` **注意:** - 请将`your_mysql_root_password`和`your_mysql_password`替换为强密码。 - 这里我们使用了两个命名卷(`db_data`和`wordpress_data`)来持久化数据库和WordPress文件。 - 服务间通过自定义网络`wordpress_net`通信。 #### 3. 启动服务 在项目目录下运行以下命令启动服务: ```bash docker-compose up -d ``` - `-d`参数表示在后台运行- 首次运行会下载所需的镜像(mysqlwordpress),这可能需要一些时间。 #### 4. 验证服务 - 访问WordPress:在浏览器中输入`http://localhost:8080`(如果部署在本地服务器)或`http://<你的服务器IP>:8080`。 - 如果看到WordPress安装界面,则表示部署成功。 #### 5. 配置反向代理(可选) 如果你希望通过域名(如`www.example.com`)访问,并且使用80/443端口,可以配置Nginx反向代理。以下是一个简单的Nginx配置示例: 在Nginx的配置文件中(如`/etc/nginx/sites-available/example.com`)添加: ```nginx server { listen 80; server_name example.com; location / { proxy_pass http://localhost:8080; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; } } ``` 然后重启Nginx: ```bash sudo systemctl reload nginx ``` #### 6. 停止和清理 - 停止服务(在项目目录下): ```bash docker-compose down ``` - 如果希望同时删除数据卷(持久化数据),则: ```bash docker-compose down -v ``` ### 注意事项 1. **安全性**:确保使用强密码,并且不要将`docker-compose.yml`文件中的密码直接暴露在公共仓库中。对于生产环境,考虑使用Docker secrets或环境变量文件来管理敏感信息。 2. **更新**:可以通过重新运行`docker-compose up -d`来更新服务(当有新的镜像可用时)。 3. **备份**:定期备份数据卷(位于Docker存储卷中)。 通过以上步骤,你应该能够成功使用Docker Compose部署WordPress。如果遇到问题,可以检查容器日志: ```bash docker-compose logs ``` §§相关问题§§ 1. 如何为Docker Compose中的服务设置环境变量文件? 2. 如何备份和恢复Docker卷中的WordPress数据? 3. 如何配置HTTPS(SSL/TLS)来保护WordPress站点? </think> ### 使用 Docker Compose 部署 WordPress 的详细步骤 #### 1. 安装 DockerDocker Compose ```bash # 安装 Docker(Ubuntu 示例) sudo apt update sudo apt install docker.io # 安装 Docker Compose sudo apt install python3-pip sudo pip3 install docker-compose # 验证安装 docker --version # 应返回 Docker 版本 docker-compose --version # 应返回 Compose 版本 ``` #### 2. 创建项目目录和配置文件 ```bash mkdir wordpress && cd wordpress touch docker-compose.yml ``` #### 3. 配置 `docker-compose.yml` 文件 ```yaml version: '3.8' services: db: image: mysql:5.7 volumes: - db_data:/var/lib/mysql environment: MYSQL_ROOT_PASSWORD: your_mysql_root_password MYSQL_DATABASE: wordpress MYSQL_USER: wordpress MYSQL_PASSWORD: your_mysql_password restart: always wordpress: depends_on: - db image: wordpress:latest ports: - "8080:80" environment: WORDPRESS_DB_HOST: db WORDPRESS_DB_USER: wordpress WORDPRESS_DB_PASSWORD: your_mysql_password WORDPRESS_DB_NAME: wordpress volumes: - wordpress_data:/var/www/html restart: always volumes: db_data: wordpress_data: ``` > **参数说明**: > - `db`: MySQL 数据库服务 > - `volumes`: 持久化存储数据库和网站数据 > - `ports`: `8080:80` 表示主机 8080 端口映射到容器 80 端口 > - `environment`: 配置数据库连接参数(需替换 `your_xxx_password`) > - 完整配置参考:[官方文档](https://docs.docker.com/compose/compose-file/) #### 4. 启动服务 ```bash # 后台启动容器 docker-compose up -d # 查看运行状态 docker-compose ps ``` > 预期输出: > ``` > Name Command State Ports > -------------------------------------------------------------------------- > wordpress_db_1 docker-entrypoint.sh mysqld Up 3306/tcp > wordpress_wordpress_1 apache2-foreground Up 0.0.0.0:8080->80/tcp > ``` #### 5. 完成 WordPress 安装 1. 浏览器访问 `http://your-server-ip:8080` 2. 按向导设置: - 选择语言 → 填写站点信息 → 创建管理员账户 3. 完成安装后登录后台:`http://your-server-ip:8080/wp-admin` #### 6. 常见管理命令 ```bash # 停止服务(保留数据) docker-compose down # 停止并删除所有数据 docker-compose down -v # 查看实时日志 docker-compose logs -f # 更新容器镜像 docker-compose pull docker-compose up -d ``` #### 配置优化建议 1. **安全加固**: - 修改默认端口(如 `8080`→`8888`) - 使用强密码(建议 16 位含大小写+数字+符号) 2. **持久化备份**: ```bash # 备份数据卷 docker run --rm -v wordpress_wordpress_data:/source -v $(pwd):/backup alpine tar czf /backup/wordpress_backup.tar.gz /source ``` 3. **HTTPS 配置**: - 在 `docker-compose.yml` 中添加反向代理容器(如 Nginx) - 使用 Let's Encrypt 自动签发证书 > 注意:首次启动时若出现数据库连接失败,等待 1-2 分钟重试(MySQL 初始化需要时间)[^2][^3]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值