今天来总结一下几种WordPress博客的部署方式。不说废话,直接开始!
部署到服务器/VPS {#部署到服务器-VPS}
这里有几种常见的部署方式。
使用Oneinstack部署 {#使用Oneinstack部署}
首先确保服务器没有安装任何PHP和数据库环境。
然后使用一键安装命令安装 Oneinstack 。
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | hljs shell sudo wget -c http://mirrors.linuxeye.com/oneinstack-full.tar.gz && tar xzf oneinstack-full.tar.gz && ./oneinstack/install.sh --nginx_option 1 --php_option 9 --phpcache_option 1 --phpmyadmin --db_option 2 --dbinstallmethod 1 --dbrootpwd jtrof057 --node --pureftpd --redis --memcached --iptables --reboot ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SHELL </div> </pre></td> </tr> ` |
安装可能需要 1~3 个小时,请耐心等待。
安装完成后目录里会多出一个 oneinstack文件夹
进入文件夹并开始创建虚拟主机。
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | hljs shell cd oneinstack && sudo ./vhost.sh ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SHELL </div> </pre></td> </tr> ` |
按照以下参考以此配置HTTPS,域名,网站根目录,防盗链,伪静态。
这里为了测试方便并不开启HTTPS和防盗链,但是在正式环境中应该开启。
然后进入你设置的网站根目录下载WordPress文件。
在网站根目录下执行:
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | hljs shell sudo wget https://cn.wordpress.org/latest-zh_CN.zip && sudo apt install unzip && sudo unzip latest-zh_CN.zip && sudo mv -r ./wordpress/* ./ ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SHELL </div> </pre></td> </tr> ` |
接着添加数据库。
首先查看数据库密码
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 | hljs shell cd ~/oneinstack sudo grep dbrootpwd options.conf ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SHELL </div> </pre></td> </tr> ` |
dbrootpwd 项后的值即为你的MySQL数据库root用户的密码
然后使用 公网IP:80 进入 oneinstack管理页面 ,然后进入 PhpMyAdmin ,使用用户名 root ,刚刚查看的密码登录。
在终端控制台输入:
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | hljs sql create user wordpress@ '%' identified by 'yourpassword' ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SQL </div> </pre></td> </tr> ` |
创建一个名为 wordpress ,密码为 yourpassword 的账户,账户账号和密码可以自行输入。
随后创建一个名为 wordpress 的数据库,并授权,数据库名称可自定。
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | hljs sql create database wordpress ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SQL </div> </pre></td> </tr> ` |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | hljs 继续sql grant all privileges on wordpress.* to wordpress@'%' with grant option ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> 继续SQL </div> </pre></td> </tr> ` |
然后进入网站根目录进行授权:
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 | hljs shell cd /data/wwwroot sudo chown -R www test.example.com sudo chmod -R 777 test.example.com ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SHELL </div> </pre></td> </tr> ` |
最后重启 NGINX :
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | hljs shell sudo systemctl reload nginx ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SHELL </div> </pre></td> </tr> ` |
打开网站就可以安装你的WordPress博客了,按照数据库账号,密码完成安装。
使用Docker部署 {#使用Docker部署}
环境安装 {#环境安装}
Docker安装 {#Docker安装}
为了方便,推荐使用官方脚本安装。此脚本适用于常用 Linux 发行版。
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | hljs shell curl -fsSL https://get.docker.com | sudo sh ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SHELL </div> </pre></td> </tr> ` |
默认情况下,Docker 只能通过 root 用户运行,普通用户通常要加 sudo 。如果觉得麻烦,可以启用 Docker 的 rootless 模式。使用普通用户执行下面这条命令即可安装:
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | hljs shell dockerd-rootless-setuptool.sh install ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SHELL </div> </pre></td> </tr> ` |
安装 Docker Compose {#安装-Docker-Compose}
下载二进制文件
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | hljs shell sudo curl -L "https://github.com/docker/compose/releases/latest/download/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SHELL </div> </pre></td> </tr> ` |
赋予执行权限
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | hljs shell sudo chmod +x /usr/local/bin/docker-compose ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SHELL </div> </pre></td> </tr> ` |
设置容器 {#设置容器}
创建项目 {#创建项目}
1.新建项目目录,这里以 ~/my_wordpress 为例。
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | hljs shell mkdir ~/my_wordpress ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SHELL </div> </pre></td> </tr> ` |
2.进入项目目录
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | hljs shell cd ~/my_wordpress ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SHELL </div> </pre></td> </tr> ` |
3.编辑配置文件
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | hljs shell nano docker-compose.yml ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SHELL </div> </pre></td> </tr> ` |
文件内容:
|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 | hljs yml version: "3.9" services: db: image: mysql:5.7 volumes: - db_data:/var/lib/mysql restart: always environment: MYSQL_ROOT_PASSWORD: somewordpress 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: {} ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> YML </div> </pre></td> </tr> ` |
注意:
这里用到了 mysql:5.7 和 wordpress:latest 两个 Docker 镜像,WordPress 镜像依赖于 MySQL 镜像。
restart: always 参数表明容器服务宕机后会自动重启。
MYSQL_ROOT_PASSWORD 为数据库的 root 密码, MYSQL_PASSWORD 为数据库的普通用户密码,请自行修改,对应的 WORDPRESS_DB_PASSWORD 也要同时修改。 MYSQL_USER 为数据库普通用户的用户名,如果有需要也可以修改,对应的 WORDPRESS_DB_USER 也要同时修改。
80:80 的意思是把宿主机的 80 端口映射到容器内部的 80 端口。如需通过其他端口访问,只需修改前面的 80。比如,我要通过 8080 端口访问 WordPress,填写 8080:80 即可。
执行 Ctrl + O 保存文件,回车,再执行 Ctrl + X 退出。
启动容器 {#启动容器}
在 ~/my_wordpress 目录中执行以下命令启动 WordPress:
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | hljs shell sudo docker-compose up -d ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SHELL </div> </pre></td> </tr> ` |
构建完成后就可以通过 http://ip:port 来访问 WordPress(请将ip替换为 VPS 的 IP, port 替换为你使用的端口,如果是 80 端口则可以省略)。如果提示 Error establishing a database connection ,说明配置尚未完成,等待 1~2 分钟,刷新网页即可进入安装界面。
配置SSL {#配置SSL}
进入容器
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | hljs shell sudo docker-compose exec wordpress bash ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SHELL </div> </pre></td> </tr> ` |
注意:本章中后续命令都要在容器中执行!
安装 cron 及 nano
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | hljs shell apt update && apt install -y cron nano ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SHELL </div> </pre></td> </tr> ` |
安装 acme.sh 用于签发 SSL 证书(请把 my@example.com 改为你的邮件地址)
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | hljs shell curl https://get.acme.sh | sh -s email=my@example.com ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SHELL </div> </pre></td> </tr> ` |
将域名解析至 VPS 的 IP,然后执行以下命令签发证书(请把 example.com 改为你的域名)
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | hljs shell bash ~/.acme.sh/acme.sh --issue -d example.com --apache --tlsport 56789 ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SHELL </div> </pre></td> </tr> ` |
启用模块
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 | hljs shell a2enmod rewrite a2enmod ssl ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> SHELL </div> </pre></td> </tr> ` |
创建证书目录
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | hljs bash mkdir -p /etc/apache2/ssl ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> BASH </div> </pre></td> </tr> ` |
复制证书(请把 example.com 改为你的域名1
创建站点(将以下全部内容粘贴进终端 )
启用站点
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 | hljs maxima a2ensite wordpress service apache2 restart ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> MAXIMA </div> </pre></td> </tr> ` |
编辑 /var/www/html/.htaccess ,在顶部加入以下内容:
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 | hljs apache # BEGIN SSL Redirect <IfModule mod_rewrite.c> RewriteEngine on RewriteCond %{HTTPS} != on [NC] RewriteRule ^(.*)$ https:// %{HTTP_HOST} /$ 1 [R=301,L] </IfModule> # END SSL Redirect ` <div class="code-widget-light code-widget copy-btn" data-clipboard-snippet=""> <i class="iconfont icon-copy"> </i> APACHE </div> </pre></td> </tr> ` |
最后一步,访问域名,进入 WordPress 后台,打开 「设置」-「常规选项」,并把 WordPress地址 和 站点地址 中的 http 改为 https ,并保存。
至此,SSL 配置已完成。
该部署方法转载自
Tony's Blog:通过 Docker Compose 部署 WordPress
遵循CC BY-NC-SA 4.0开源协议进行转载,已获原作者授权
51工具盒子