使用LAMP建立Wordpress, 要求如下:

准备工作:

  1. VMware 14
  2. CentOS 7.4 最小化 安装镜像
  3. Wordpress 安装包,  下载

预热:

  1. 使用VMware新建4台虚拟机, 并安装 --> 可以先安装一台CentOS 7 最小系统, 然后使用克隆功能 复制出另外三台, 直接安装还快些;
  2. 设置yum源, 与网卡等基本应用, 使用 yum -y update
  3. 记录各个主机的ip
MariaDB主机 192.168.142.128/24
 nfs 192.168.142.140/24
httpd1 192.168.142.135/24
httpd2 192.168.142.141/24

开始:

  • httpd1/2 共用设置 --> 配置PHP, httpd 和 mariadb 客户端

    1. yum -y install httpd php php-devel php-mysql mariadb
    2. systemctl start httpd
    3. vim /var/www/html/index.php --> <?php phpinfo(); ?>
    4. systemctl reload httpd
    5. 测试php加载是否成功:

  • MariaDB服务器设置:

    1. yum -y install mariadb mariadb-server --> 安装mariadb的 客户端 和 服务端
    2. mysql -uroot -p --> 登陆到本地mysql服务端执行如下操作
      1. 新建库 wpress --> CREATE DATABASE wpress;
      2. 新建Wordpress专用用户及授权 --> 
        1. GRANT SELECT,UPDATE,ALTER,INSERT,CREATE,DELETE ON wpress.* TO 'wpuser'@'192.168.142.%' IDENTIFIED BY 'password';
    3. httpd端进行登陆测试 -->

      1. mysql -uwpress -h192.168.142. -ppassword
        >SHOW GRANTS; --> 登陆进mysql服务器后,使用此命令显示授权信息;

      MariaDB [(none)]> show grants;
      +-------------------------------------------------------------------------------------------------------------------+
      | Grants for wpuser@192.168.142.% |
      +-------------------------------------------------------------------------------------------------------------------+
      | GRANT USAGE ON *.* TO 'wpuser'@'192.168.142.%' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9' |
      | GRANT SELECT, INSERT, UPDATE, CREATE, DELETE, ALTER ON `wpress`.* TO 'wpuser'@'192.168.142.%' |
      +-------------------------------------------------------------------------------------------------------------------+
      2 rows in set (0.00 sec)

      • 进行php-mysql的连接测试:

        1. vim /var/www/html/index.php --> ↓修改如下↓
        1. <?php
        2. echo '<title>
        3. This is a PHP page
        4. </title>';
        5. $link=mysql_connect('192.168.142.128','wpuser','password');
        6. if ($link)
        7. echo "Mysql Connected"; --> 连接成功
        8. else
        9. echo "Mysql Failed";
        10. mysql_close();
        11. phpinfo();
        12. ?>

  • 配置Wordpress到httpd 1服务器中, 准备配置好后直接拷贝到 nfs 上面去

    • 下载源码包 后使用xftp导入 httpd1 服务器中, 解压得到:

    • 访问httpd服务器1 上的 wp站点: http://192.168.142.135/wordpress

      • 根据提示生成 wp-config.php文件内容; 或者, 直接在wordpress/ 目录下,  cp wp-config-sample.php wp-config.php , 修改最上面几行的 define('DB_NAME', 'database_name_here'); 的_here为你自己设置的数据库即可;
      • 刷新页面, 按照提示设置
      • 如果提示需要修改数据库内容 --> 最好能够直接删掉wpress, 再新建一个wpress;
      • 查看站点, 测试站点, 新建用户等;

  • 配置httpd2 服务端

    1. 配置 httpd2服务器, 安装 httpd mariadb php php-mysql 进行测试
  • nfs服务器配置:

    1. yum -y install nfsd-utils --> 安装nfs共享环境
    2. mkdir -pv /share/wp 我用此目录做nfs共享目录
    3. 编辑 /etc/exports 定义该共享文件系统/share/wp 192.168.142.0/(rw,no_root_squash)
    4. systemctl start nfs 启动服务
    5. 使用 showmount -e localhost 查看是否分享成功
      1. [root@nfs ~]# showmount -e localhost
      2. Export list for localhost:
      3. /share/wp 192.168.142.0/
    6. 在 httpd1 和 httpd2 分别安装nfs-utils , 然后挂载 /share/wp 文件系统 mount -t nfs 192.168.142.140:/share/wp /var/www/html/ --> 这里偷个懒, 直接挂载到httpd的默认资源路径, 省得修改...
    7. 随手创建一个 index.php <?php echo "This page is from NFS Server"; phpinfo(); ?> , 再访问:

  • 拷贝httpd1上配置好的wordpress/到nfs服务器上, 访问查看是否正常:                                                                                                                  

  • 但是这么做有一个问题: 管理页面都会跳转到 httpd1 的服务器上, 那么我们删除这个wp站点重新做一遍试试看;

    • 删除wordpress/, 删除数据库新建

    • 在nfs服务器上解压安装wordpress
    • 为了实验效果, 我们这次使用 httpd2 这台服务器来配置wp --> 结果: 登陆后一样会跳转到httpd2 这台主机上来;
  • 上传文件问题:

    • 由于httpd服务器上的 httpd服务 都是使用apache用户身份运行的, 我们需要为apache用户增加对 /var/www/html 目录的写权限。但是!使用 chmod 766 后, wordpress 整个站点都挂了;
    • 嗯,需要 x 权限 才能正确访问;
    • 仔细查看了wp对上传时候的报错, 发现: /wordpress/wp-content 才是需要更改 777 权限的, 更改了之后, 上传正常;

最终测试


总结:

  1. 最开始的将wp站点资源分别放在httpd1和httpd2上是错误的; 正确做法是放在 nfs 上, 这样所有的访问都会从nfs 调用静态资源;

  2. nfs巨卡,性能差劲;

  3. 无可避免的, 无论在哪一台 httpd 上完成wordpress的初始化, 管理权限登陆最终都会跳转到那台进行初始化的服务器上;还没有搞懂为什么;

  4. 对开篇的结构图的补充内容:httpd服务器只提供httpd服务, 不放静态资源;

  5. 几个需要注意的点:
    1. mariadb 对wpuser的授权需要 DELETE 权限;
    2. nfs的搭建安装包是  nfs-utils;
    3. 这种形式的站点不好用。

相关命令整理:

nfs服务器: nfsd(nfs-utils), mountd, idmapd

showmount -e HOST_IP
showmount -a HOST_IP 显示指定NFS上所有的挂载

挂载
mount -t nfs SERVER:/path/to/shared_fs /path/to/mount_point

/etc/exports: 格式:
directory (or file system) client1(option1, option2) client2(option1, option2)

LAMP 建立 Wordpress 站点 Linux Apache MariaDB PHP的更多相关文章

  1. 在Fedora 23 Server和Workstation上安装LAMP(Linux, Apache, MariaDB和PHP)

    在安装LAMP之前,建议先更新系统包$ sudo dnf update 第一步:安装Apache Web服务器1.在Fedora 23安装Apache,你可以运行下面的命令:$ sudo dnf in ...

  2. [PHP] ubuntu16.04配置Lamp环境(搭建linux+apache+mysql+php7环境)

    reference : http://blog.csdn.net/Abyss_sliver/article/details/77621404 好久没有在Linux环境下进行开发了,比较常用的还是win ...

  3. Linux centos7 LAMP架构介绍、 MySQL、MariaDB介绍、MySQL安装

    一.LAMP架构介绍 为Linux+Apache(httpd)+MySQL+PHP简写,把后三者安装在Linux Apache是最常用的的web服务软件,MySQL为小型的数据库存储软件,PHP为脚本 ...

  4. 配置LAMP实现WordPress

    环境说明: 在同一台主机上实现LAMP(Linux + Apache + MariaDB + PHP) CentOS 7.3.Apache 2.4.6.MariaDB 5.5.52.PHP 5.4.1 ...

  5. Install LAMP Server (Apache, MariaDB, PHP) On CentOS/RHEL/Scientific Linux 7

    Install LAMP Server (Apache, MariaDB, PHP) On CentOS/RHEL/Scientific Linux 7 By SK  - August 12, 201 ...

  6. 【腾讯云的1001种玩法】几种在腾讯云建立WordPress的方法(Linux)(二)

    版权声明:本文由张宁原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/126547001488207964 来源:腾云阁 ht ...

  7. L(kali)A(apache)M(mysql)P(php)环境+wordpress站点搭建

    一:LAMP环境配置 首先LAMP(linux+apache+mysql+php)即为本次搭建网站所需的环境,由于本次使用的debian衍生版kali版本自带lamp,因此只要在服务器上启动相应服务既 ...

  8. [转] Ubuntu 12.04下LAMP安装配置 (Linux+Apache+Mysql+PHP)

    我是一个Linux新手,想要安装一台Ubuntu 12.04版的Linux服务器,用这台服务器上的LAMP套件来运行我自己的个人网站.LAMP套件就是 “Linux+Apache+Mysql+PHP这 ...

  9. 【 Linux 】lvs-dr模型实现HA,后端Nginx、PHP、MySQL分离 搭建wordpress站点

    要求:    1. wordpress程序通过nfs共享给各个realserver    2. 后端realserver中的nginx和php分离 网络结构图: 环境说明:    OS:centos6 ...

随机推荐

  1. mac pro 安装 composer 失败

    http://getcomposer.org/doc/00-intro.md#using-composer $ brew install josegonzalez/php/composer 出现错误: ...

  2. Redis安装到Windows系统

    redis官方没有windows版本,在windows下安装需要单独去找.地址:https://github.com/MSOpenTech/redis/releases.本文用的是Redis-x64- ...

  3. css pointer-event

    详见:张鑫旭 CSS3 pointer-events:none应用举例及扩展 pointer-events:none ,可以使事件穿透, 如: 2 覆盖在 1 上面. 给 2 设置 pointer-e ...

  4. Java校验8位字符串是否为正确的日期格式

    import java.text.ParseException; import java.text.SimpleDateFormat; /** * 校验8位字符串是否为正确的日期格式 * @autho ...

  5. Web API Filter

    在Web Api中,有三种Filter Filter类型 实现的接口 描述 Authorization IAuthorizationFilter 最先运行的Filter,被用作请求权限校验 Actio ...

  6. js数组的一些骚操作 (用一行代码实现)

    1.扁平化n维数组 1.终极篇 [1,[2,3]].flat(2) //[1,2,3] [1,[2,3,[4,5]].flat(3) //[1,2,3,4,5] [1[2,3,[4,5[...]].f ...

  7. 三、Git 分支

    使用分支意味着你可以把你的工作从开发主线上分离开来,以免影响开发主线.有人把 Git 的分支模型称为它的`‘必杀技特性’',也正因为这一特性,使得 Git 从众多版本控制系统中脱颖而出. 1.分支简介 ...

  8. KMP算法题集

    模板 caioj 1177 KMP模板 #include<bits/stdc++.h> #define REP(i, a, b) for(register int i = (a); i & ...

  9. jquery简直是太酷炫强大了

    链接地址:http://www.yyyweb.com/350.html Web 开发中很实用的10个效果[源码下载] 小鱼 发布于 3年前 (2014-07-15) 分类:前端开发 阅读(303741 ...

  10. ssm框架下上传图片及其他信息

    先引入这两个包: <dependency> <groupId>commons-fileupload</groupId> <artifactId>comm ...