WordPress是使用PHP语言开发的博客平台,在支持PHP和MySQL数据库的服务器上,您可以用WordPress搭建自己的网站,也可以用作内容管理系统(CMS)。本教程介绍如何在不同操作系统的ECS实例上,手动搭建WordPress网站的方法。
手动搭建WordPress网站
准备工作
为已创建实例搭建WordPress网站,已创建的ECS实例必须满足以下条件:
-
实例已分配公网IP地址或绑定弹性公网IP(EIP)。具体操作,请参见更换公网IP地址。
-
实例的安全组入方向规则已放行对应端口。具体操作,请参见添加安全组规则。
-
Linux:22、80、443端口。
-
Windows:80、3389端口。
重要
基于服务器数据安全考虑,本文仅说明部署与测试LNMP环境和WordPress网站所必需放行的端口,您可以根据实际需求,放行其他应用所需的端口号。例如,远程连接MySQL数据库时,需要放行MySQL默认占用的3306端口。
-
操作步骤
不同的操作系统搭建WordPress的步骤可能不同,请根据您的ECS实例操作系统选择对应的操作。
Alibaba Cloud Linux 3/2、CentOS 7/8
Windows Server 2012 R2
-
远程连接ECS实例。
具体操作,请参见通过密码或密钥认证登录Linux实例。
-
部署LNMP环境。
具体操作,请参见手动部署LNMP环境(Alibaba Cloud Linux 3/2、CentOS 7/8)。
重要
当您使用不同软件版本时,可能需要根据实际情况调整参数配置。关于WordPress对PHP、MySQL版本的要求,请参见WordPress Compatibility。
-
(条件必选)如果您的操作系统为CentOS 8,则需要切换源地址。
说明
CentOS 8操作系统版本结束了生命周期(EOL),按照社区规则,CentOS 8的源地址http://mirror.centos.org/centos/8/内容已移除,您在阿里云上继续使用默认配置的CentOS 8的源会发生报错。如果您需要使用CentOS 8系统中的一些安装包,则需要手动切换源地址。具体操作,请参见CentOS 8 EOL如何切换源?。
-
配置WordPress数据库。
-
运行以下命令,进入MySQL数据库。
说明
使用
root
用户登录MySQL,并输入密码。密码为您在搭建环境时为数据库设置的密码。mysql -u root -p
-
运行以下命令,为WordPress网站创建一个名称为
wordpress
的数据库。create database wordpress;
-
运行以下命令,创建一个新用户
user
管理WordPress库,新用户密码为PASSword123.
,以提高数据安全性。create user 'user'@'localhost' identified by 'PASSword123.';
说明
-
您可以使用
show variables like "%password%";
命令来查询MySQL服务器中所有与密码相关的系统变量。 -
MySQL在5.7版本后默认安装了密码强度验证插件validate_password。您可以登录MySQL后查看密码强度规则。
-
-
运行以下命令,赋予用户对数据库
wordpress
的全部权限。grant all privileges on wordpress.* to 'user'@'localhost';
-
运行以下命令,使配置生效。
flush privileges;
-
运行以下命令,退出MySQL。
exit;
-
-
下载WordPress,并移动至网站根目录。
-
运行以下命令,进入Nginx网站根目录,下载WordPress压缩包。
说明
本示例默认安装的是WordPress中文版本。如果您需安装WordPress英文版本,需运行命令
wget https://wordpress.org/wordpress-6.4.5.zip
,下载WordPress英文版本压缩包。同时您需要注意,后续操作中压缩包的名称必须替换为wordpress-6.4.5.zip
。cd /usr/share/nginx/html sudo wget https://cn.wordpress.org/wordpress-6.4.5-zh_CN.zip
-
(可选)运行以下命令,安装
unzip
命令。sudo yum install unzip -y
-
运行以下命令,解压WordPress压缩包。
sudo unzip wordpress-6.4.5-zh_CN.zip
-
运行以下命令,将WordPress安装目录下的
wp-config-sample.php
文件复制到wp-config.php
文件中,并将wp-config-sample.php
文件作为备份。cd /usr/share/nginx/html/wordpress sudo cp wp-config-sample.php wp-config.php
-
-
修改WordPress配置文件。
-
运行以下命令,编辑
wp-config.php
文件。sudo vim wp-config.php
-
按
i
键进入编辑模式。根据已配置的WordPress数据库信息,修改MySQL相关配置信息,代码修改如下所示。
// ** MySQL 设置 - 具体信息来自您正在使用的主机 ** // /** WordPress数据库的名称 */ define('DB_NAME', 'wordpress'); /** MySQL数据库用户名 */ define('DB_USER', 'user'); /** MySQL数据库密码 */ define('DB_PASSWORD', 'PASSword123.'); /** MySQL主机 */ define('DB_HOST', 'localhost');
说明
WordPress网站的数据信息将通过数据库的
user
用户保存在名为wordpress
的数据库中。 -
按
Esc
键,输入:wq
后按Enter
键,保存退出配置文件。
-
-
修改Nginx配置文件。
Alibaba Cloud Linux 3/2、CentOS 7
CentOS 8
-
运行以下命令,打开Nginx配置文件。
sudo vim /etc/nginx/nginx.conf
-
按
i
键进入编辑模式。说明
本示例中根目录为
/usr/share/nginx/html/wordpress
。-
在
server
大括号内,将root
后的内容替换为WordPress根目录。 -
在
location ~ .php$
大括号内,将root
后的内容替换为WordPress根目录。
-
-
按
Esc
键,输入:wq
后按Enter
键,保存退出配置文件。 -
运行以下命令,重启Nginx服务。
sudo systemctl restart nginx
-
-
安装并登录WordPress网站。
-
在本地物理机上使用浏览器访问
http://ECS实例公网IP
,进入WordPress安装页面。 -
填写网站基本信息,然后单击安装WordPress。
填写信息参数说明:
-
站点标题:WordPress网站的名称。例如:demowp。
-
用户名:登录WordPress时所需的用户名,请注意安全性。例如:testwp。
-
密码:登录WordPress时所需的密码,建议您设置安全性高的密码。例如:Wp.123456。
-
您的电子邮件:用于接收通知的电子邮件。例如:username@example.com。
-
-
单击登录。
-
输入在安装WordPress时设置的用户名
testwp
和密码Wp.123456
,然后单击登录。成功进入您个人的WordPress网站。
-
快速搭建WordPress网站
说明
本章节内容仅适用于在CentOS 7.x系统的ECS实例上快速搭建WordPress网站。
请参考以下表格以选择不同的WordPress快速部署方式:
搭建方式 | 实例选择 | 说明 |
使用云市场镜像搭建WordPress | 新建实例 | 阿里云云市场提供WordPress镜像,用于快捷搭建WordPress网站,不需要部署Web环境,降低了建站的门槛,适用于刚开始使用阿里云ECS建站的企业或个人用户。更多信息,请参见了解镜像市场。 |
使用计算巢一键部署WordPress | 新建实例 | 计算巢官方提供了WordPress社区版服务,您无需自行配置云主机,即可在计算巢上快速部署WordPress服务,从而方便地基于WordPress简单快捷地搭建自己的网站。更多信息,请参见什么是计算巢服务。 |
使用云市场镜像搭建
使用计算巢一键部署
准备工作
已创建网络类型为专有网络的安全组,并且在安全组的入方向添加规则,放行80端口及8100端口,如果您使用SSH远程连接Linux实例,还需要放行22端口。具体操作,请参见添加安全组规则。
背景信息
本示例中使用的WordPress博客系统镜像基础环境如下:
-
操作系统版本:CentOS 7.4
-
Nginx版本:1.14
-
PHP版本:7.0
-
MySQL版本:5.7.22
该镜像提供的MySQL账号信息如下:
-
用户名:root
-
密码:mysql57@onesul.com
-
步骤一:使用WordPress镜像创建ECS实例
-
登录ECS管理控制台。
-
在左侧导航栏,选择实例与镜像 > 实例。
-
在页面左侧顶部,选择目标资源所在的资源组和地域。
-
在实例列表页,单击创建实例。
-
在自定义购买页面的镜像区域,选择云市场镜像 > 从云市场获取更多选择(含操作系统)。
-
在搜索框中输入
WordPress博客系统
,并单击搜索,选择镜像。您可以单击搜索结果中的镜像标题,进入云市场镜像售卖页,获取镜像的配置信息。本示例中使用的WordPress博客系统镜像如下。
更多镜像环境,您可在云市场基础环境中搜索筛选。
-
单击使用。
-
在自定义购买页面,按照界面提示,配置参数。
请注意以下参数,更多参数说明,请参见自定义购买实例。
-
镜像:镜像区域已自动设置为您选购的镜像。
-
公网 IP:选中分配公网 IPv4 地址,并根据业务需要,设置带宽值。
-
安全组:选择已开通22、80、8100、443端口的安全组。
-
步骤二:安装WordPress
-
在本地浏览器中输入
http://实例公网IP
,选择语言(本示例中,选择简体中文),单击继续,然后单击现在就开始!。 -
填写镜像提供的数据库连接信息,单击提交,然后单击现在安装。
默认参数如下:
-
用户名:root
-
密码:mysql57@onesul.com
说明
如果您需要修改MySQL数据库的用户名和密码,具体操作,请参见常见问题。
-
-
根据您的业务需求填写基本信息,这些信息以后可以再次修改。填写完成后单击。
填写信息参数说明:
-
站点标题:WordPress网站的名称。例如:demowp。
-
用户名:登录WordPress时所需的用户名,请注意安全性。例如:testwp。
-
密码:登录WordPress时所需的密码,建议您设置安全性高的密码。例如:Wp.123456。
-
您的电子邮件:用于接收通知的电子邮件。例如:username@example.com。
-
-
单击登录。
-
使用您设置的用户名和密码登录WordPress网站。
出现如下界面,表示成功搭建WordPress网站。
解析WordPress网站域名
通过实例公网IP地址直接访问您的WordPress网站会降低服务端的安全性。如果您已有域名或者想为WordPress网站注册一个域名,可以参考以下步骤。
-
注册域名。
具体操作,参见域名注册基本流程如何注册阿里云域名。
-
备案域名。
如果您的域名指向的网站托管在阿里云中国内地节点服务器,您需要进行备案。首次备案,请参见ICP备案流程,其他情况请参见ICP备案流程。
-
解析域名。将域名指向实例公网IP。
域名解析是使用域名访问您的网站的必备环节。具体操作,请参见设置域名解析。
-
将实例公网IP替换为新域名。
-
远程连接已搭建WordPress网站的ECS实例。
具体操作,请参见ECS远程连接方式概述。
-
(条件必选)如果您的ECS实例为Windows操作系统,则需要执行本步骤操作。
返回搭建WordPress网站的ECS实例,进入MySQL安装目录下的bin文件夹,先按下
shift
键,同时单击鼠标右键,然后选择在此处打开命令窗口(W)。 -
运行以下命令,登录MySQL数据库。
mysql -u root -p
-
运行以下命令,切换至WordPress对应的数据库。
use wordpress;
-
为WordPress网站设置新域名。
说明
本示例注册域名为
www.example.com
。-
Linux:
运行以下命令,将实例公网IP替换为新域名。
update wp_options set option_value = replace(option_value, 'http://实例公网IP', 'http://www.example.com') where option_name = 'home' OR option_name = 'siteurl';
-
Windows:
运行以下命令,将
http://localhost/
替换为新域名。update wp_options set option_value = replace(option_value, 'http://localhost', 'http://www.example.com') where option_name = 'home' OR option_name = 'siteurl';
-
-
运行以下命令,退出MySQL。
exit;
成功为WordPress网站设置新域名。
-
常见问题
WordPress中设置固定链接后,跳转页面无法访问
网站设置为静态网页有利于搜索引擎收录网站。您在对WordPress站点设置固定链接前,需要先在Nginx服务器中设置为静态规则。操作步骤如下:
-
登录搭建WordPress的ECS实例。
具体操作,请参见通过密码或密钥认证登录Linux实例。
-
运行以下命令,打开Nginx配置文件。
sudo vim /etc/nginx/nginx.conf
-
按
i
键进入编辑模式。 -
在
location /
大括号内,添加如下代码。if (-f $request_filename/index.html){ rewrite (.*) $1/index.html break; } if (-f $request_filename/index.php){ rewrite (.*) $1/index.php; } if (!-f $request_filename){ rewrite (.*) /index.php; }
-
按
Esc
键,输入:wq
后按Enter
键,保存退出配置文件。 -
运行以下命令,重启Nginx服务。
sudo systemctl restart nginx
WordPress中更新版本、上传主题或插件时,提示需要FTP登录凭证或无法创建目录
该问题可能是因为WordPress配置文件、主题或插件的权限不足,您可以参考以下步骤解决。
-
登录搭建WordPress的ECS实例。
具体操作,请参见通过密码或密钥认证登录Linux实例。
-
运行以下命令,打开WordPress配置文件。
sudo vim /usr/share/nginx/html/wordpress/wp-config.php
-
按
i
键进入编辑模式。 -
在最下方,添加如下代码。
define("FS_METHOD","direct"); define("FS_CHMOD_DIR", 0777); define("FS_CHMOD_FILE", 0777);
-
按
Esc
键,输入:wq
后按Enter
键,保存退出配置文件。 -
返回WordPress仪表盘,刷新页面,可解决需要FTP登录凭证的问题。
如果仍存在无法创建目录的问题,需再次返回ECS实例,运行以下命令,将网站根目录的权限用户更新为Nginx对应的用户,本示例环境中为
nginx
用户。sudo chown -R nginx /usr/share/nginx/html/wordpress
如何修改WordPress镜像中的MySQL 5.7数据库的默认用户名和密码?
具体操作如下:
-
远程连接安装WordPress镜像的ECS实例。
具体操作,请参见通过密码或密钥认证登录Linux实例。
-
运行以下命令,登录MySQL数据库。
mysql -u root -p
根据回显信息,输入MySQL数据库root用户的默认密码为
mysql57@onesul.com
。[test@izbp1cgfkqcrs8pi2li**** ~]# mysql -u root -p Enter password: Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 3 Server version: 5.7.23 MySQL Community Server (GPL) Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql>
-
运行以下命令,进入MySQL数据库。
use mysql
说明
运行
select user from mysql.user;
命令,可查看MySQL数据库的用户名。 -
根据需求,修改数据库的用户名和密码。
-
运行以下命令,修改数据库用户名为新用户名。
update user set user="新用户名" where user="用户名";
本示例将
root
用户名修改为admin
,命令如下:update mysql.user set user="admin" where user="root";
-
运行以下命令,修改数据库用户名的密码。
update mysql.user set authentication_string=password("新密码") where user="要更新密码的用户名";
本示例将
root
用户密码改为newpassword
,命令如下:update mysql.user set authentication_string=password("newpassword") where user="root";
-
-
运行以下命令,刷新权限使修改生效。
flush privileges;
-
运行以下命令,退出MySQL数据库。
quit;