WordPress标准软件基于Bitnami wordpress 构建。当前版本为6.4.3
你可以通过Qinghub部署工具直接安装部署,也可以手动按如下文档操作
WordPress 是世界上最受欢迎的博客和内容管理平台。功能强大但简单,从学生到跨国公司,每个人都可以使用它来构建美观、实用的网站。
docker run --name wordpress bitnami/wordpress:latest
WordPress 需要访问 MySQL 或 MariaDB 数据库来存储信息。
docker network create wordpress-network
$ docker volume create --name mariadb_data
docker run -d --name mariadb \
--env ALLOW_EMPTY_PASSWORD=yes \
--env MARIADB_USER=bn_wordpress \
--env MARIADB_PASSWORD=bitnami \
--env MARIADB_DATABASE=bitnami_wordpress \
--network wordpress-network \
--volume mariadb_data:/bitnami/mariadb \
bitnami/mariadb:latest
$ docker volume create --name wordpress_data
docker run -d --name wordpress \
-p 8080:8080 -p 8443:8443 \
--env ALLOW_EMPTY_PASSWORD=yes \
--env WORDPRESS_DATABASE_USER=bn_wordpress \
--env WORDPRESS_DATABASE_PASSWORD=bitnami \
--env WORDPRESS_DATABASE_NAME=bitnami_wordpress \
--network wordpress-network \
--volume wordpress_data:/bitnami/wordpress \
bitnami/wordpress:latest
访问 : http://your-ip/
docker-compose up -d
如果删除容器,所有数据都将丢失,并且下次运行映像时,数据库将重新初始化。为了避免这种数据丢失,您应该安装一个即使在容器被删除后仍然存在的卷。
为了持久化,您应该在路径上安装一个目录/bitnami/wordpress。如果挂载的目录为空,则首次运行时会对其进行初始化。此外,您应该安装一个卷来持久保存 MariaDB 数据。
mariadb_data上面的示例定义了名为和 的Docker 卷wordpress_data。只要不删除卷,WordPress 应用程序状态就会持续存在。
为了避免无意中删除卷,您可以将主机目录挂载为数据卷。或者,您可以使用卷插件来托管卷数据。
mariadb:
...
volumes:
- - 'mariadb_data:/bitnami/mariadb'
+ - /path/to/mariadb-persistence:/bitnami/mariadb
...
wordpress:
...
volumes:
- - 'wordpress_data:/bitnami/wordpress'
+ - /path/to/wordpress-persistence:/bitnami/wordpress
...
-volumes:
- mariadb_data:
- driver: local
- wordpress_data:
- driver: local
注意: 由于这是一个非根容器,因此安装的文件和目录必须具有 UID 的适当权限1001。
docker network create wordpress-network
docker run -d --name mariadb \
--env ALLOW_EMPTY_PASSWORD=yes \
--env MARIADB_USER=bn_wordpress \
--env MARIADB_PASSWORD=bitnami \
--env MARIADB_DATABASE=bitnami_wordpress \
--network wordpress-network \
--volume /path/to/mariadb-persistence:/bitnami/mariadb \
bitnami/mariadb:latest
NOTE: 由于这是一个非根容器,因此安装的文件和目录必须具有 UID 的适当权限1001。
docker run -d --name wordpress \
-p 8080:8080 -p 8443:8443 \
--env ALLOW_EMPTY_PASSWORD=yes \
--env WORDPRESS_DATABASE_USER=bn_wordpress \
--env WORDPRESS_DATABASE_PASSWORD=bitnami \
--env WORDPRESS_DATABASE_NAME=bitnami_wordpress \
--network wordpress-network \
--volume /path/to/wordpress-persistence:/bitnami/wordpress \
bitnami/wordpress:latest
NOTE: 由于这是一个非根容器,因此安装的文件和目录必须具有 UID 的适当权限1001。
Name | Description | Default Value |
---|---|---|
| 相对于 WordPress 安装目录保留的文件。要提供多个值,请用空格分隔它们。 |
|
| 是否默认为 WordPress 启用 HTTPS。 |
|
| WordPress blog 名称. |
|
| 生成应用程序 URL 的方案。已弃用WORDPRESS_ENABLE_HTTPS。 |
|
| 将 ApacheAllowOverride变量设置为None. 所有默认指令都将从/opt/bitnami/wordpress/wordpress-htaccess.conf. |
|
| 保留 htaccess 的自定义更改。是否坚持就看值WORDPRESS_HTACCESS_OVERRIDE_NONE。/opt/bitnami/wordpress/wordpress-htaccess.confno/opt/bitnami/wordpress/.htaccess |
|
| 初始化时强制重置持久数据的所有权/权限,否则假设所有权/权限正确。以非 root 身份运行时被忽略。 |
|
| 在 WordPress 中使用的表前缀。 |
|
| 要安装和激活的 WordPress 插件列表,以逗号分隔。还可以设置为all激活所有当前安装的插件,或none跳过。 |
|
| 是否对应用程序执行初始引导。 |
|
| 允许安装 WordPress 核心的自动更新级别。有效值:major、minor、none。 |
|
| 启用 WordPress 对反向代理标头的支持 |
|
| 启用 WordPress XML-RPC 端点 |
|
| WordPress user name. |
|
| WordPress user password. |
|
| WordPress user e-mail address. |
|
| WordPress user first name. |
|
| WordPress user last name. |
|
| 启用 WordPress 多站点配置。 |
|
| 要启用的 WordPress 多站点网络类型。有效值:subfolder、subdirectory、subdomain。 |
|
| WordPress 多站点的外部 HTTP 端口。 |
|
| WordPress 多站点的外部 HTTPS 端口。 |
|
| 启用 WordPress 多站点时是否启用 IP 地址重定向到 nip.io 通配符 DNS。仅当在具有子域网络类型的 IP 地址上运行时才支持此功能。 |
|
| WordPress 多站点上传允许的最大上传文件大小(以千字节为单位)。 |
|
| Database server host. |
|
| Database server port. |
|
| Database name. |
|
| Database user name. |
|
| Database password |
|
| 是否为数据库连接启用SSL。 |
|
| 当数据库连接启用SSL时是否验证数据库SSL证书。 |
|
| 覆盖持久性中的数据库设置。 |
|
| smtp host。 |
|
| smtp port。 |
|
| smtp user。 |
|
| smtp password。 |
|
Name | Description | Value |
---|---|---|
| WordPress 安装目录。 |
|
| 配置文件。 |
|
| WP-CLI 安装目录 |
|
| 二进制文件 |
|
| 配置文件目录 |
|
| 配置文件 |
|
| 用于挂载配置文件的 WordPress 目录。 |
|
| 默认 database server host. |
|
| 默认 database server host. |
|
| 默认 PHP memory limit. |
|
| 默认 PHP post_max_size. |
|
| 默认 PHP upload_max_size. |
|
| WP-CLI system user. |
|
| WP-CLI system group. |
|
当您启动 WordPress 映像时,您可以通过在 docker-compose 文件或命令行上传递一个或多个环境变量来调整实例的配置docker run。请注意,某些变量仅在容器首次启动时才被考虑。如果要添加新的环境变量:
对于 docker-compose
wordpress:
environment:
- WORDPRESS_PASSWORD=my_password
$ docker run -d --name wordpress -p 80:8080 -p 443:8443 \
--env WORDPRESS_PASSWORD=my_password \
--network wordpress-tier \
--volume /path/to/wordpress-persistence:/bitnami \
bitnami/wordpress:latest
$ docker run -d --name wordpress -p 80:8080 -p 443:8443 \
--env WORDPRESS_DATABASE_USER=bn_wordpress \
--env WORDPRESS_DATABASE_NAME=bitnami_wordpress \
--env WORDPRESS_SMTP_HOST=smtp.gmail.com \
--env WORDPRESS_SMTP_PORT=587 \
--env WORDPRESS_SMTP_USER=your_email@gmail.com \
--env WORDPRESS_SMTP_PASSWORD=your_password \
--network wordpress-tier \
--volume /path/to/wordpress-persistence:/bitnami \
bitnami/wordpress:latest
WordPress 容器支持将 WordPress 应用程序连接到外部数据库。这是为 WordPress 使用外部数据库的示例。
wordpress:
...
environment:
- - WORDPRESS_DATABASE_HOST=mariadb
+ - WORDPRESS_DATABASE_HOST=mariadb_host
- WORDPRESS_DATABASE_PORT_NUMBER=3306
- WORDPRESS_DATABASE_NAME=wordpress_db
- WORDPRESS_DATABASE_USER=wordpress_user
- - ALLOW_EMPTY_PASSWORD=yes
+ - WORDPRESS_DATABASE_PASSWORD=wordpress_password
...
$ docker run -d --name wordpress\
-p 8080:8080 -p 8443:8443 \
--network wordpress-network \
--env WORDPRESS_DATABASE_HOST=mariadb_host \
--env WORDPRESS_DATABASE_PORT_NUMBER=3306 \
--env WORDPRESS_DATABASE_NAME=wordpress_db \
--env WORDPRESS_DATABASE_USER=wordpress_user \
--env WORDPRESS_DATABASE_PASSWORD=wordpress_password \
--volume wordpress_data:/bitnami/wordpress \
bitnami/wordpress:latest
如果数据库已包含以前 WordPress 安装的数据,您需要将变量设置WORDPRESS_SKIP_BOOTSTRAP为yes. 否则,容器将执行安装向导并可以修改数据库中的现有数据。请注意,当设置WORDPRESS_SKIP_BOOTSTRAP为时yes,环境变量(例如WORDPRESS_USERNAME、WORDPRESS_PASSWORD或 )的值WORDPRESS_EMAIL将被忽略。确保在此导入的数据库中,表前缀与 中设置的表前缀匹配WORDPRESS_TABLE_PREFIX。
WordPress 容器包含命令行界面wp-cli,可以帮助您管理 WP 站点并与之交互。要运行此工具,请注意您需要使用正确的系统用户daemon。
这是使用wp-cli显示帮助菜单的示例:
docker-compose exec wordpress wp help
WordPress Docker 映像将容器日志发送到stdout. 要查看日志:
docker logs wordpress
使用docker-compose命令:
docker-compose logs wordpress
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。