欢迎访问本人博客浏览此文章
1、安装docker、docker-compose
1.1、安装 docker
sudo apt-get update apt-get install ca-certificates curl gnupg lsb-release curl -fsSL http://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add - #安装证书 sudo add-apt-repository "deb [arch=amd64] http://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable" #写入软件源信息 sudo apt-get install docker-ce docker-ce-cli containerd.io #安装 systemctl start docker #启动docker
1.2、安装 docker-compose
sudo apt-get install docker-compose-plugin
验证是否成功
docker compose version
mkdir wordpress #在你指定的地方创建WordPress项目目录 cd wordpress mkdir db_data mkdir wordpress_data touch docker-compose.yml vim docker-compose.yml
在docker-compose.yml文件中写入一下内容
version: "3.3" services: db: image: mysql:latest 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 volumes: - ./wordpress_data:/var/www/html ports: - "80:80" - "443:443" restart: always environment: WORDPRESS_DB_HOST: db WORDPRESS_DB_USER: wordpress WORDPRESS_DB_PASSWORD: wordpress WORDPRESS_DB_NAME: wordpress volumes: db_data: {} wordpress_data: {}
3、一键启动wordpress项目
启动
docker-compose up -d
停止
docker-compose down
重启
docker-compose restart
4、查看正在运行的容器及镜像
查看正在运行的容器
docker ps
查看镜像
docker images
5、登录管理员界面
网页登录管理员页面设置管理员账号密码并安装WordPress
https://yourserverip/wp-admin
至此WordPress安装完成
6、安装SSL/TLS证书
6.1、为什么要安装证书
安全套接字层 (SSL) 是一种加密安全协议。它最初由 Netscape 于 1995 年开发,旨在确保 Internet 通信中的隐私、身份验证和数据完整性。SSL 是如今使用的现代 TLS 加密的前身。实施 SSL/TLS 的网站的 URL 中带有“HTTPS”,而不是“HTTP”。
简而言之,你没安装这个证书只能用“http”访问你的网站,不能用“https”访问,而且网站前面会出现“不安全”字眼,所以我建议安装。
6.2、下载证书
在你的服务器厂商管理页面上申请并下载证书,以腾讯服务器为例,访问SSL证书管理页面,下载Apache证书
6.3、安装证书
6.2.1、加载Apache SSL模块
查看wordpress的docker容器ID,进入该容器
sudo docker exec -it 937faae55666 /bin/bash
在wordpress容器中输入a2enmod ssl
a2enmod ssl
第一次会加载,并且提示重启Apache,我们直接从重启容器即可,也可以直接重启Apache
/etc/init.d/apache2 reload
6.2.2、绑定SSL证书
Apache 加载 SSL 模块后,会在 /etc/apache2/sites-available
下生成 default-ssl.conf
文件
vim /etc/apache2/sites-available/default-ssl.conf
该文件中有以下内容
SSLCertificateFile /etc/ssl/certs/ssl-cert-snakeoil.pem
SSLCertificateKeyFile /etc/ssl/private/ssl-cert-snakeoil.key
上述两行配置就是证书的存放位置,我们只需要把第三方可信CA签发的证书相应的文件上传至对应位置即可。
ssl-cert-snakeoil.pem:为证书,文件内容是这样
—–BEGIN CERTIFICATE—–
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
—–END CERTIFICATE—–
ssl-cert-snakeoil.key:为密钥,文件内容是这样
—–BEGIN PRIVATE KEY—–
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
—–END PRIVATE KEY—–
先把ssl-cert-snakeoil.pem 和 ssl-cert-snakeoil.key 上传到服务器。然后直接用docker cp将文件复制进wordpress容器中
docker cp 服务器文件路径/ssl-cert-snakeoil.pem 容器名:/etc/ssl/certs docker cp 服务器文件路径/ssl-cert-snakeoil.key 容器名:/etc/ssl/private
6.2.3、链接配置文件
从 apache 的配置文件 apache2.conf 可以看到,apache 只会读取 /etc/apache2/sites-enabled 目录的配置文件,所以需要把 /etc/apache2/sites-available 下的 default-ssl.conf 文件链接到 /etc/apache2/sites-enabled 目录下。
ln -s /etc/apache2/sites-available/default-ssl.conf \ /etc/apache2/sites-enabled/default-ssl.conf
6.2.4、配置http请求强制跳转到https
编辑 /etc/apache2/sites-available/000-default.conf
,在 <VirtualHost *:80> </VirtualHost>
标签中增加下面的配置
<Directory "/var/www/html"> RewriteEngine on RewriteBase / # FORCE HTTPS RewriteCond %{HTTPS} !=on RewriteRule ^/?(.*) https://%{SERVER_NAME}/$1 [R,L] </Directory>
6.2.5、修改完成后重启容器
exit退出容器,然后进入docker-compose.yml配置文件所在的目录,管理员身份执行以下命令
docker-compose restart
6.2.6、配置wordpress访问地址
一定要保证 https 和 http 两种方式都能正常访问网站,才能改这个配置,否则可能导致网站无法访问。(如果这种情况已经发生,解决方案见【7.1】)
进入wordpress后台中,【设置】-【常规】中配置WordPress 地址(URL)、站点地址(URL)两个地址的 http协议 修改为 https协议 并保存。
7、疑难杂症
7.1、WordPress地址(URL)错误
登陆mysql
sudo docker exec -it d6401cc9265d /bin/bash #我用的docker容器运行的mysql,所以要先进入容器 mysql -u wordpress -p #输入密码登录
选中wordpress的数据库
USE wordpress;
查看wp_options表单
select * from wp_options limit 2;
更改option_values
#将下列your_wordpress_url修改为你的网站 UPDATE wp_options SET option_value="your_wordpress_url" WHERE option_name="siteurl"; UPDATE wp_options SET option_value="your_wordpress_url" WHERE option_name="home";
7.2、WordPress上传媒体限制
7.2.1、上传文件大小限制
方法1:修改WordPress根目录下的.htaccess文件,加入以下代码:
不推荐这种方法,每次修改配置重启服务就失效了,又得重新加入
php_value upload_max_filesize 200M php_value post_max_size 200M php_value max_execution_time 300 php_value max_input_time 300
方法2:通过插件进行设置
安装 Big File Uploads 插件,安装后设置下面有个大文件上传的选项
修改自己想要的大小即可
7.2.2、上传文件类型限制
安装 WP Extra File Types 插件,安装后在设置里有扩展文件类型的选项。
另外,WordPress 升级 4.4 之后,推出了 srcset 这个图片多屏自适应功能,默认会生成至少四个版本的缩略图,而这个插件禁用了WordPress裁剪功能(你无法修改这一设定),WordPress将不再自动生成缩略图文件,这从某种角度上来讲帮你节省了大量内存空间
选择这个选项,将第二个勾上
CTRL+F搜索你想增加的文件类型,将其勾上
如果这里面没有你想要的文件类型,那么鼠标滑到最底部,增加文件类型
最后保存更改
7.2.3、媒体库缺少文件管理
媒体库没有分类管理的功能,文件较多时,媒体库堆积了很多各种各样的文件,非常难管理,可以安装插件 Filester – File Manager Pro 解决这个问题(很多相关插件都要收费,这个插件功能全且免费)
然后在这个插件提供的管理页面进行文件管理,不使用原生的媒体库管理
7.3、wordpress在线评论留言不能接收邮件提醒信息
wordpress接收评论邮件提醒是需要主机空间支持php的mail()函数的,但是国内很多主机都是不支持这个mail()函数的,那么就不能接收邮件,下面是解决方案:
后台设置,如果主机空间支持mail()函数,只需要设置这里就可以了
如果主机空间不支持mail()函数,那么就需要安装Configure SMTP插件
安装成功后左侧多一个选项,可以进去设置
登录QQ邮箱在【设置】-【账号】下面开启POP3/SMTP服务,操作很简单,我已经开启了就不演示怎么打开了,同样的你也可以在这里查看POP3/SMTP授权码
然后我们在这个界面点击“发送电子邮件”进行测试,如果你能收到邮件,那就设置成功了,试试在文章下面评论看看能不能收到邮件吧 (*^▽^*)
原文链接:https://blog.csdn.net/qq_36804616/article/details/130204268?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522168623078216800184162743%2522%252C%2522scm%2522%253A%252220140713.130102334.pc%255Fblog.%2522%257D&request_id=168623078216800184162743&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~blog~first_rank_ecpm_v1~times_rank-2-130204268-null-null.268%5Ev1%5Ekoosearch&utm_term=docker%E3%80%81wordpress%E3%80%81wordpress%E5%BB%BA%E7%AB%99%E3%80%81wordpress%E4%B8%BB%E9%A2%98%E3%80%81%E5%AE%B9%E5%99%A8%E9%95%9C%E5%83%8F%E3%80%81