• wordpress 配置坑详解


    首先 经过我测试,php74模块没有支持apache的.所以升级到php74 之后,php无法使用. 最基本的函数phpinfo 调用不出来,没有相关的模块.
    安装mariadb 10.4 之后发现,mariadb 这个版本好像不支持密码(反正我是没搞定,一天) .改配置什么的我都试了,仍然免密登陆. 所以最后经过我测试了一天 确定的方案就是 php72+mysql8.0 (依旧遇到了相当多的问题, 包括mysql和mariadb版本冲突,配置冲突,以及和php的模块冲突,为了不浪费时间去改配置,系统我重装了五次左右.血与泪的实践)
    下面开始正确的步骤,首先安装mysql 仓库,从官方下载仓库文件,传到服务器 或者拿到链接,采用wget的方式

    wget https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm 下载后通过本地安装
    yum localinstall 包

    刷新仓库 yum clean all

    重建缓存 yum makecache

    安装mysql yum install mysql (一定要先安装mysql再安装php 否则到时候模块找不到支持,先安装了MySQL之后,模块方便自动识别版本.否则到时候版本错误,有得回退半天,然后清理配置,出现莫名其妙的错误)

    安装好之后,进入mysql 这时候需要密码.但是你没有设置密码,哪来的密码呢? 这是MySQL 高版本的特性,它会生成一个随机密码
    在你 mysql-uroot -p 之后 要求输出密码, 确定之后提示没有密码,然后, 查看MySQL 日志 cat var/log/mysqld.log |grep password 就可以看到这个生成的随机密码(找不到多的登陆几次)刷新下

    然后 mysql-uroot -p 拿到的随机密码.登陆进去,必须立刻重置密码

    alter user 'root'@'localhost'IDENTIFIED BY 'YourNewPass'; -->mysql8.0的密码规则比较严,要求账号包含大小写,数字符号 长度为8, 两次确认密码之后 后面几个选项全部默认Yes

    重置完密码,新建一个wordpress 数据库

    create database wordpress ; q 退出.

    安装php --> 因为官方没有高版本的源. 只有5.4好像,wordpress 最低要5.6 还是更高来着,反正阿里云仓库没有,其他的都没有.

    安装php72w,是需要配置额外的yum源地址的,否则会报错不能找到相关软件包。

    php高版本的yum源地址,有两部分,其中一部分是epel-release,另外一部分来自webtatic。如果跳过epel-release的话,安装webtatic的时候,会有错误爆出。

    所以,这里需要的命令是:

    rpm -Uvh https://dl.Fedoraproject.org/pub/epel/7/x86_64/Packages/e/epel-release-7-11.noarch.rpm

    rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm

    当然,您也可以选择下面的这个命令,也是一样的效果。

    yum install epel-release -y

    rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm

    记得更新源之后重建缓存
    yum clean all
    yum makecache

    如果之前有装过php 为了防止CentOS上面发生php冲突,所以,这个命令还是先执行一下更好些。
    清除历史版本
    yum -y remove php*
    安装扩展包

    事实上,这里面的对应扩展库很多,这里大家一定要注意cli和fpm这两个包,而其它的相关包就看需要了。

    yum -y install php72w php72w-cli php72w-fpm php72w-common php72w-devel

    最好装这个
    yum -y install php72w php72w-cli php72w-fpm php72w-common php72w-devel php72w-embedded php72w-gd php72w-mbstring php72w-mysqlnd php72w-opcache php72w-pdo php72w-xml

    安装完成以后,启动服务
    systemctl enable php-fpm.service 设置开机启动

    systemctl start php-fpm.service 启动php-fpm

    然后开始安装apache

    yum install httpd
    systemctl enable httpd
    systemctl start httpd
    这时候访问 能访问到标准apache 测试页面
    然后进入到网站目录 /var/www/html
    新建一个php 文件 用来测试
    vim index.php 添加测试代码

    保存退出之后,访问地址,如果出现php版本信息页面说明php链接成功.
    可以开始下一步.
    下载wordpress ,wge 下载之后解压.
    新建一个 网站根目录 webroot/wordpress
    将解压的wordpress 全部移动到这个文件夹

    再来配置虚拟主机
    vim /etc/httpd/conf.d/vhosts.conf
    添加代码
    <VirtualHost *:80>
    ServerName 网站地址
    ServerAlias 别名网站地址
    DocumentRoot "/webroot/blog" //刚刚新建的文件夹

    <Directory "/webroot/blog">
    Require all granted

    保存退出,然后重启httpd

    访问服务器地址, 最好在配置虚拟主机之后,再通过之前我说的方法, 写一个php测试页,看虚拟主机能不能访问php成功,成功了就可以放心开始下一步了.

    进入到相关页面.配置页面.提示数据库链接,名称,账户,密码 ,分别输入我们刚刚设置的数据库信息,这时候问题就来了,发现无论如何无法写入,提示数据库有问题. (确定账户密码什么的没问题.)

    其实这是为因为我采用的是高版本的mysql8.0 ,之前修改密码之后默认安全策略是不让外部访问的. 以及 服务器要求的身份验证方法对客户端未知。提示服务端(要连接的数据库)所要求的验证方式为caching_sha2_password。
    打开phpinfo(),查看当前安装的php版本中的配置信息,找到mysqlnd.

    当前PHP版本中所带的mysqlnd无法支持这种验证(caching_sha2_password),而PHP默认的是mysql_native_password 。
    MySQL中以root登录,并查看数据库所默认的身份验证
    select host,user,plugin from mysql.user where user ='root';

    解决方法 :
    MySQL中创建一个支持mysql_native_password验证的用户,并用该用户登录管理wp_database数据库。

    创建一个认证方式是mysql_native_password的用户

    create user '你的账户'@'localhost' identified with mysql_native_password by '你的密码';

    创建要存放wordpress数据的数据库,指定字符集

    create database wp_database default charset utf8 collate utf8_general_ci;

    将wp_database的所有权限给用户 你的账户

    grant all on 创建的wordpress数据库名称.* to '刚刚创建的账户'@'localhost';

    然后再刷新网址 就可以登陆成功了.

    如果还是不行,

    修改配置
    1,登进MySQL之后,

    2,输入以下语句,进入mysql库:

    use mysql

    3,更新域属性,'%'表示允许外部访问:

    update user set host='%' where user ='root';

    4,执行以上语句之后再执行:

    FLUSH PRIVILEGES;

    5,再执行授权语句:

    GRANT ALL PRIVILEGES ON . TO 'root'@'%'WITH GRANT OPTION;

    然后外部就可以通过账户密码访问了。

    )

  • 相关阅读:
    字符串哈希之Rabin-Karp,poj1200
    字符串哈希之ELFHash,poj2503
    dfs之n的全排列
    几大排序算法(选择,插入)
    dfs之地图染色
    单纯的dfs
    dfs之记忆化搜索(字符串匹配,位置相对变)
    STL之map的一种用法
    JAVA之大数处理,有简单方法不用是sb
    ACM之素数环(DFS)
  • 原文地址:https://www.cnblogs.com/thelovelybugfly/p/12289494.html
Copyright © 2020-2023  润新知