Wordpress 容器化、HTTPS化全攻略
<p>大家可能都在用Wordpress写博客,之前都都是买个VPS部署一个一键L/WAMP程序完成整个部署,部署可能也容易但是操作比较费劲。前两天虫虫的博客VPS出问题导致数据丢失,需要重新部署,在这次部署中为了追求***使用了docker容器方式并对网站升级使用全站HTTPS的方式进行部署,站点支持TLS 1.3协议以***程度提高性能,本文虫虫就给大家介绍整个部署的全过程供大家参考优化。</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" src="https://zhuji.jb51.net/uploads/img/202305/fa6d0425ca1b5a8ca1d23f213416208c.jpg"></p>
<p>
<strong>概述</strong></p>
<p>
站点采用Docker方式部署,使用两个容器一个是mysql 5.7数据库容器,一个是apache(2.4.25)、php(7.3.6),Wordpress(5.2.2)容器,容器部件都是***版本。为了安全连个容器都映射到宿主机127.0.0.1端口不直接对外提供服务。宿主机上部署nginx***版本1.17反向代理到容器,nginx对外提供https服务:使用TLS 1.3协议,证书是从Let's Encrypt申请免费SSL,可以一键申请证书并且免费3个月更新。整个架构结构如下:</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" src="https://zhuji.jb51.net/uploads/img/202305/eff8d3b9dbe85f60e3542618e2f90ed5.jpg"></p>
<p>
<strong>VPS和容器环境准备</strong></p>
<p>
基础VPS环境是centos 7.2,默认是vi我们先将它换成vim</p>
<p>
yuminstallvim</p>
<p>
<strong>挂载VPS数据盘</strong></p>
<p>
初始化VPS数据盘,注意该盘为外挂的盘VPS变化重新初始化时候数据不会丢失,一般为sdb,比如虫虫的盘,60G</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" border="0" src="https://zhuji.jb51.net/uploads/img/202305/2a6563cce95a42b505001fd75bc487c8.jpg" width="627"></p>
<p>
创建分区并格式化</p>
<p>
fdisk/dev/sdb</p>
<p>
mkfs.ext4/dev/sdb1</p>
<p>
挂载,挂载目录我们设为/data</p>
<p>
mkdir/data</p>
<p>
mount/dev/sdb1/data</p>
<p>
修改/etc/fstab实现重启自动挂载:</p>
<p>
通过dumpe2fs或者blkid查看磁盘UUID</p>
<p>
d179868b-6fb9-414c-8901-b990f7c586bd</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" border="0" src="https://zhuji.jb51.net/uploads/img/202305/10e065583910181fa012922fa8ed358c.jpg" width="600"></p>
<p>
echo'UUID="d179868b-6fb9-414c-8901-b990f7c586bd"/dataext4defaults00'>>/etc/fstab</p>
<p>
mount –a测试fstab配置,如果没提示表示正确,如果有错误会显示,比如我们给UUID前面加个1,测试信息如下:</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" border="0" src="https://zhuji.jb51.net/uploads/img/202305/5ae1dbaa10968f70b291f0f22e2476b3.jpg" width="645"></p>
<p>
<strong>更换防火墙关闭selinux</strong></p>
<p>
系统其默认的防火墙firewalld,先将其修改为比较熟悉称手的iptables:</p>
<p>
yuminstalliptablesiptables-services</p>
<p>
systemctldisablefirewalld</p>
<p>
systemctlstopfirewalld</p>
<p>
systemctlenableiptables</p>
<p>
systemctlstartiptables</p>
<p>
selinux配置太复杂,我们先暂时关闭(在正式生产环境不建议该操作):</p>
<p>
setenforce0</p>
<p>
为了一直关闭,需要修改其配置文件,这样重启后就不会再加载。方法</p>
<p>
perl-i-lpe's/SELINUX=enforcing/SELINUX=disabled/g'/etc/selinux/config</p>
<p>
<strong>更改ssh安全配置</strong></p>
<p>
为了VPS已经修改掉系统默认的ssh 22端口,并且禁止root登陆,方法修改/etc/ssh/sshd_config,查找Port去掉其前面的注释#号,并把22修改为其他端口,比如12322:</p>
<p>
Port12322</p>
<p>
增加一行" PermitRootLogin no"禁止root登陆:</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" border="0" src="https://zhuji.jb51.net/uploads/img/202305/242799272e594f5929652892dc9ca2e8.jpg" width="250"></p>
<p>
事先添加证书登陆,然后禁止密码登录方式"PasswordAuthentication no":</p>
<p align="center">
</p>
<p>
防火墙开启新sshd端口,并删掉22端口</p>
<p>
iptables-IINPUT-ptcp-mstate--stateNEW-mtcp-dport12322-jACCEPT</p>
<p>
重启sshd服务</p>
<p>
systemctlrestartsshd.service</p>
<p>
用新端口证书方式访问服务器,如果没有问题:</p>
<p>
删掉22端口</p>
<p>
iptables-DINPUT-ptcp-mstate--stateNEW-mtcp-dport22-jACCEPT</p>
<p>
保存防火墙规则</p>
<p>
systemctlsavesshd.service</p>
<p>
添加epel和源管理工具</p>
<p>
yuminstallepel-releaseyuminstall-yyum-utils</p>
<p>
docker和容器部署</p>
<p>
添加docker源</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" border="0" src="https://zhuji.jb51.net/uploads/img/202305/9fa82033704d4da52850e196d0897dc8.jpg" width="600"></p>
<p>
<strong>安装docker服务</strong></p>
<p>
yuminstalldocker-cedocker-compose</p>
<p>
systemctlenabledocker</p>
<p>
systemctlstartdocker</p>
<p>
启用docker过程中报了一个错误"SELinux is not supported with the overlay2 graph drive...false",原因是linux的内核中的SELinux不支持 overlay2 graph drive,解决方法,修改docker配置文件/etc/sysconfig/docker修改--selinux-enabled为--selinux-enabled=false</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" border="0" src="https://zhuji.jb51.net/uploads/img/202305/8154620a3b917804970aa25b0fa8b06d.jpg" width="600"></p>
<p>
还有一个典型错误如下:</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" border="0" src="https://zhuji.jb51.net/uploads/img/202305/727645ac656167f128f8e6d698dc0482.jpg" width="600"></p>
<p>
fatal msg="Error starting daemon: error initializing graphdriver: "/var/lib/docker" contains several valid graphdrivers: devicemapper, overlay; Please cleanup or explicitly choose storage driver (-s )"是由于docker初始化数据有问题导致,只需清理/var/lib/docker/目录下文件</p>
<p>
"rm -rf /var/lib/docker/",然后重启就OK了</p>
<p>
<strong>拉取docker应用镜像</strong></p>
<p>
dockerpullwordpress</p>
<p>
dockerpullmysql:5.7.25</p>
<p>
迁移docker数据目录</p>
<p>
systemctlstopdocker.service</p>
<p>
mv/var/lib/docker/data/docker</p>
<p>
vim /usr/lib/systemd/system/docker.service 查找ExecStart给其参数增加:</p>
<p>
"--graph /data/docker":</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" border="0" src="https://zhuji.jb51.net/uploads/img/202305/53966f09c2c5c415947cc87965409b94.jpg" width="600"></p>
<p>
重新加载配置文件</p>
<p>
systemctldaemon-reload</p>
<p>
重启docker服务</p>
<p>
systemctlrestartdocker.service</p>
<p>
创建应用数据目录</p>
<p>
首先是数据库mysql目录:</p>
<p>
mkdir-p/data/web/data</p>
<p>
chown-R999:999/data/web/data</p>
<p>
网站目录:</p>
<p>
mkdir/data/web/webapps</p>
<p>
chown-R33:33/data/web/webapps</p>
<p>
启动应用容器</p>
<p>
mysql容器:</p>
<p>
dockerrun--namemysql-hmysql</p>
<p>
--restart=always</p>
<p>
-eMYSQL_ROOT_PASSWORD=wp12345</p>
<p>
-p127.0.0.1:13306:3306</p>
<p>
-v/data/web/data:/var/lib/mysql</p>
<p>
-dmysql:5.7.25</p>
<p>
注意上面加重的参数表示mysql的root初始化密码,需要根据实际修改。</p>
<p>
<strong>wordpress应用容器</strong></p>
<p>
dockerrun-hwordpress--namewordpress</p>
<p>
--restart=always</p>
<p>
--linkmysql:mysql</p>
<p>
-p2880:80</p>
<p>
-v/data/web/webapps:/var/www/html</p>
<p>
-dwordpress</p>
<p>
注意上面黑体表示连接到mysql容器,注意两个服务启动顺序,现有mysql,wordpress放弃才能连接到这个数据库,在宿主机上映射的端口为2880。</p>
<p>
<strong>数据迁移</strong></p>
<p>
以上两个个容器启动后,wordpress部署就完全完成,现在通过浏览器访问</p>
<p>
http://ip:2880就可以访问到wordpress安装界面了。</p>
<p>
就可以通过web安装wordpress和配置了。</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" border="0" src="https://zhuji.jb51.net/uploads/img/202305/d1c784aca1865ffebf13ed3bdc0fe709.jpg" width="640"></p>
<p>
有可能报错数据库连接错误:</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" border="0" src="https://zhuji.jb51.net/uploads/img/202305/178292d2aa73f7fbd126429f9fd76c34.jpg" width="640"></p>
<p>
提示信息表示数据库服务没有创建wordpress数据库,这时候需要连接到mysql容器:</p>
<p>
dockerexec-itmysql/bin/bash</p>
<p>
在容器中执行mysql -uroot -p 输入上面我们设置mysql密码,wp12345</p>
<p>
在mysql命令行创建一个数据库wordpress</p>
<p>
create database wordpress;</p>
<p>
然后再访问就可以了</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" border="0" src="https://zhuji.jb51.net/uploads/img/202305/6f96f4f3661200912a0eadd8eda7c582.jpg" width="640"></p>
<p>
注意该处保存好系统给你设置的密码,或者修改为自己的密码。</p>
<p>
进过以上步骤,一个全新版本的wordpress服务就可以:</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" border="0" src="https://zhuji.jb51.net/uploads/img/202305/80b793a8c7c11ab764a37d9cf523a1be.jpg" width="640"></p>
<p>
安装好后需要迁移历史数据,最主要是两部分数据:数据库数据和上传的文件数据。</p>
<p>
<strong>上传文件数据迁移:</strong></p>
<p>
这部分迁移很简单把以前保存的目录中的wp-content下的uploads目录复制过来所有上传数据就ok了。</p>
<p>
<strong>数据库迁移:</strong></p>
<p>
数据库迁移,如果wordpress版本相同,可以直接把以前保存的数据文件导入到新数据库就可以。如果版本不同需要注意版本差异,否则会导致错误,可以只导入wp-post和wp-comments这两个表的数据。</p>
<p>
通过wordpress导入导出功能:</p>
<p>
如果你以前通过wordpress的导出插件导出过历史数据,就可以利用它导入所有数据信心,结合uploads目录导入文件就可以***恢复历史数据。具体方法:</p>
<p>
点击"工具"-"导入":</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" border="0" src="https://zhuji.jb51.net/uploads/img/202305/5754ef48944928cfdbf670acc60a332f.jpg" width="640"></p>
<p>
在该页面点击WordPress下的现在安装,先安装该插件。安装后点击"插件":</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" border="0" src="https://zhuji.jb51.net/uploads/img/202305/33dee5814130d1ec752750e0545f62a6.jpg" width="600"></p>
<p>
点击"启用"。</p>
<p>
然后再返回"工具"-"导入":</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" border="0" src="https://zhuji.jb51.net/uploads/img/202305/7da27b96f81c9f69d08409a290890d43.jpg" width="600"></p>
<p>
点击"运行导入器"。</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" border="0" src="https://zhuji.jb51.net/uploads/img/202305/34724b28c11f05cecd459cc371cf19ec.jpg" width="600"></p>
<p>
弹出页面选择以前保存的xml文件,然后点击"上传并导入"按钮,</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" border="0" src="https://zhuji.jb51.net/uploads/img/202305/c9425ef8e93aa33da9e0b6a6751f1db4.jpg" width="548"></p>
<p>
选择好需要迁移的用户,点解"Submit"按钮。</p>
<p>
根据保存文件大小,该步骤需要比较长的时间。***会显示如下页面,表示导入过程已经完成:</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" border="0" src="https://zhuji.jb51.net/uploads/img/202305/eebe25adf9349f110e729bc6f20ad103.jpg" width="623"></p>
<p>
文章页面:</p>
<p align="center">
<img style="max-width:100%!important;height:auto!important;"title="Wordpress 容器化、HTTPS化全攻略" alt="Wordpress 容器化、HTTPS化全攻略" align="" border="0" src="https://zhuji.jb51.net/uploads/img/202305/2ccad85462369a643c2b5e6c9baf270e.jpg" width="640"></p>
<p>
<strong>迁移问题</strong></p>
<p>
迁移目前遇到问题有些插件不好使用,最主要是代码高亮插件"Crayon Syntax Highlighter"在***版本中不能用了,启用该插件后,前台不能显示文章列表和内容,目前还未知道解决方案,暂时安装了另一个代码高亮插件"Enlighter"来代替。</p>
<p>
<strong>总结:</strong></p>
<p>
本文我们使用部署中docker容器方式重新部署和迁移了Wordpress站点,涉及了VPS基础设置、docker容器环境和安装、应用容器的安装和Wordpress历史数据的迁移。限于篇幅我们总体文章分两篇来介绍,本文第二篇将介绍nginx编译安装支持TLS 1.3,站点https设置和wordpress https化存在的问额和解决。</p>
頁:
[1]