实现NFS为lamp环境web站点提供共享存储

1.实验需求


1nfs server导出/data/application/web,在目录中提供wordpress;

2nfs client挂载nfs server导出的文件系统,至/var/www/html;

3)客户端1(lamp)部署wordpress,并让其正常访问,要确保正常发文章,上传图片。

4)客户端2(lamp),挂载nfs server导出的文件系统至/var/www/html,验证其wordpress

否可被访问,要确保能正常发文章,上传图片。

5nfs server 导出/mydata/目录;

6nfs client挂载/mydata/至本地的/mydata目录,mysqldmariadb服务的数据目录设置为/mydata, 要求服务能正常启动,且可正常存储数据。

2.服务器规划


服务器版本 角色 主机名 IP地址
centos7.2x86_64

web服务器01apache+php

nfs客户端

web01 172.16.52.51
centos7.2x86_64

web服务器02apache+php

nfs客户端

web02 172.16.52.52
centos7.2x86_64

mysqld数据库服务

nfs客户端

db 172.16.52.53
centos7.2x86_64

nfs服务端

nfs

172.16.52.54

部署NFS服务端及nfs客户端


3.1 配置nfs服务端

(1)安装nfs软件

[root@nfs ~]# yum -y install nfs-utils
[root@nfs ~]# rpm -qa nfs-utils
nfs-utils-1.3.0-0.21.el7.x86_64

 

(2)启动nfs服务

 开机自启动nfs服务:

[root@nfs ~]# systemctl enable rpcbind.service
[root@nfs ~]# systemctl enable nfs-server.service

 

 启动rpcbindnfs服务:

 注意要先启动rpcbind

[root@nfs ~]# systemctl start rpcbind.service
[root@nfs ~]# systemctl start nfs.service

 

 查看nfs状态:

[root@nfs ~]# rpcinfo -p

 

 (3)配置nfs服务

[root@nfs ~]# cat /etc/exports
/data/application/web 172.16.0.0/16(rw,sync,anonuid=888,anongid=888)
/mydata   172.16.0.0/16(rw,sync,anonuid=3306,anongid=3306)

 

  重新导出:

[root@nfs ~]# exportfs -arv
exporting 172.16.0.0/16:/data
exporting 172.16.0.0/16:/data/application/web

 

 为nfs共享文件创建授权用户(uid):

 这里我们不使用默认的nfsnobody用户

[root@nfs ~]# groupadd -g 888 apache
[root@nfs ~]# useradd -u 888 -g apache -s/sbin/nologin -M apache
[root@nfs ~]# id apache
uid=888(apache) gid=888(apache) groups=888(apache)
[root@nfs ~]# chown apache.apache/data/application/web
[root@nfs ~]# ls -ld /data/application/web/
drwxr-xr-x 2 apache apache 6 Jul 20 04:27/data/application/web/
[root@nfs ~]# groupadd -g 3306 mysql
[root@nfs ~]# useradd -u 3306 -g mysql -s/sbin/nologin -M mysql
[root@nfs ~]# id mysql
uid=3306(mysql) gid=3306(mysql) groups=3306(mysql)
[root@nfs ~]# chown mysql.mysql /data
[root@nfs ~]# ls -ld /data
drwxr-xr-x 4 mysql mysql 35 Jul 20 04:27 /data


3.2 配置nfs客户端

 注:3nfs客户端配置都一样

 安装软件包:

[root@db ~]# yum -y install nfs-utils

 

 启动rpcbind

 客户端只用启动rpcbind即可。

[root@db ~]# systemctl start rpcbind


4.部署lamp环境


说明:本次lamp环境采用rpm包安装,数据库分离

web01 web02 配置一样。

为了方便测试:web01域名blog.magedu.comweb02域名blog02.magedu.com

4.1 安装软件

[root@web01 ~]# yum -y install httpd php php-mysql

 

4.2 配置虚拟主机

[root@web01 conf.d]# cat blog.conf
<VirtualHost *:80>
         ServerNameblog.magedu.com
         DocumentRoot"/var/www/html"
         CustomLog"/var/log/httpd/blog/access_log" combined
         ErrorLog  "/var/log/httpd/blog/error_log"  
         <Directory"/var/www/html">
                   OptionsNone
                   AllowOverrideNone
                   Requireall granted
         </Directory>
</VirtualHost>

5. 部署mariadb数据库服务


 mariadb采用通用二进制安装

[root@db soft]# ln -sv mariadb-5.5.46-linux-x86_64 mariadb
[root@db soft]#ls
mariadb  mariadb-5.5.46-linux-x86_64

5.1 创建mysql用户

[root@db soft]# groupadd -g 3306 mysql
[root@db soft]# useradd -u 3306 -g mysql mysql
[root@db soft]# id mysql
uid=3306(mysql) gid=3306(mysql) groups=3306(mysql)

5.2 创建数据目录并授权

[root@db soft]# mkdir /mydata
[root@db soft]# chown -R mysql.mysql /mydata
[root@db soft]# ls -ld /mydata
drwxr-xr-x 2 mysql mysql 6 Jul 20 07:27 /mydata

 

5.3 初始化数据库

[root@db mariadb]# chown -R root.mysql /data/soft/mariadb/
[root@db mariadb]# cd /data/soft/mariadb
[root@db mariadb]# scripts/mysql_install_db--user=mysql --datadir=/mydata --basedir=/data/soft/mariadb

 

5.4 配置/etc/my.cnf

# cp support-files/my-large.cnf /etc/my.cnf
vim /etc/my.cnf
[mysqld]
port = 3306
basedir = /data/soft/mariadb
datadir = /data/mydata
innodb_file_per_table = 1 #让innodb表每个表一个表空间文件。

5.5 配置mysqld启动脚本

 复制mysql启动脚本到/etc/init.d/mysqld

[root@db ~]# cp /data/soft/mariadb/support-files/mysql.server/etc/init.d/mysqld
[root@db ~]# chmod 755 /etc/init.d/mysqld
[root@db ~]# sed -i‘s#/usr/local/mysql#/data/soft/mariadb#g‘ /etc/init.d/mysqld
[root@db ~]# chkconfig --add mysqld

 

 修改PATH环境变量:

[root@db mariadb]# cat /etc/profile.d/mysql.sh
export PATH=/data/soft/mariadb/bin:$PATH

 

 配置库文件搜索路径:

[root@db mariadb]# echo"/data/soft/mariadb/lib" > /etc/ld.so.conf.d/mysqld.conf
[root@db mariadb]# ldconfig

5.6 启动mysqld服务

[root@db /]# service mysqld start
Starting MySQL.. SUCCESS!
[root@db /]# lsof -i:3306
COMMAND PID  USER   FD  TYPE DEVICE SIZE/OFF NODE NAME
mysqld  7668mysql   15u  IPv4 23521      0t0  TCP *:mysql (LISTEN)

 

5.7 测试php与数据库的连接

 注:事先创建好相关的库和用户

 在web服务器站点下创建mysql.php 文件

[root@web01 html]# cat mysql.php
<?php
         $conn= mysql_connect(‘172.16.52.53‘,‘wordpress‘,‘123456‘);
         if($conn)
                   echo‘connect 172.16.52.53 is OK‘;
         else
                   echo‘failure‘;
?>

5.8 把nfs服务端的/mydata/目录挂载至本地的/mydata

 

[root@db ~]# showmount -e 172.16.52.54
Export list for 172.16.52.54:
/mydata               172.16.0.0/16
/data/application/web 172.16.0.0/16

 

[root@db ~]# ls -ld /mydata/
drwxr-xr-x 6 mysql mysql 4096 Jul 21 06:05 /mydata/

 

[root@nfs /]# ls -ld /mydata
drwxr-xr-x 6 mysql mysql 4096 Jul 21 06:05 /mydata

 

 把本地mysql数据目录/mydata里面的文件复制到nfs服务端的/mydata目录里

[root@db ~]# scp -r /mydata/*root@172.16.52.54:/mydata

 

 重新对nfs服务端/mydata/下面的文件授权:

chown -R mysql.mysql /mydata

 

 挂载:

mount -t nfs 172.16.52.54:/mydata /mydata

 重启mysqld测试:

[root@db ~]# service mysqld restart
Shutting down MySQL. SUCCESS!
Starting MySQL.. SUCCESS!
ok,没有问题。

6.部署web服务器站点目录


6.1 LAMP 01部署wordpress站点

 站点目录严格授权:

[root@web01 html]# chown -R root.root/var/www/html/
[root@web01 html]# find /var/www/html/ -type f|xargs chmod 644
[root@web01 html]# find /var/www/html/ -type d|xargs chmod 755
[root@web01 html]# chown -R apache.apache/var/www/html/wordpress/wp-content

6.2 把nfs服务端的/data/application/web 挂载至web01本地的/var/www/html

1)把/var/www/html下面的文件复制到/data/application/web目录下面

 [root@web01 ~]# scp -rp /var/www/html/*root@172.16.52.54:/data/application/web/

 

2)授权

 [root@nfs~]# chown -R apache.apache /data/application/web/wordpress/wp-content/

        

3)挂载

[root@web01 ~]# showmount -e 172.16.52.54
Export list for 172.16.52.54:
/mydata               172.16.0.0/16
/data/application/web 172.16.0.0/16
 [root@web01 wordpress]# mount -t nfs 172.16.52.54:/data/application/web/var/www/html

6.3 把nfs服务端的/data/application/web 挂载至web02本地的/var/www/html

1)挂载

[root@web02 ~]# mount -t nfs172.16.52.54:/data/application/web /var/www/html

2)访问blog02.magedu.com/wordpress/index.php

7. 总结


本次实验实现了web站点数据的共享,一定程度上实现session共享和负载均衡的功能。

原创文章,作者:island,如若转载,请注明出处:http://www.178linux.com/74598

(0)
islandisland
上一篇 2017-05-02
下一篇 2017-05-02

相关推荐

  • 从Linux小白到大牛——与狼共舞的日子7

    马哥教育网络班21期+第7周课程练习 1、创建一个10G分区,并格式为ext4文件系统; (1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl; (2) 挂载至/data/mydata目录,要求挂载时禁止程序自动运行,且不更新文件的访问时间戳; [root@localhost ~]#&nbsp…

    Linux干货 2016-11-14
  • 马哥教育网络班22期第2周课程作业

    一、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。     1、cp 文件复制 [选项]源文件 目标文件         -r 递归复制    …

    Linux干货 2016-08-31
  • history命令详解,铭记历史,圆梦中华。

        铭记历史,圆梦中华。在Linux操作系统中,对于管理员操作的命令进行查询也是非常重要,而且熟练掌握调用命令历史能提高管理员管理系统的效率。     history的命令缓存数目是由一个在/etc/profile文件名为HISTSIZE的变量决定,可以通过env命令查看当前设定的数目,也可以通…

    Linux干货 2016-07-26
  • centos7从最小化安装到图形界面

    man /etc/inittab
    systemctl get-default
    sytemctl set-default graphical.target|multi-user.target
    yum install $a -y

    2017-12-09
  • 编程能力与编程年龄

    程序员这个职业究竟可以干多少年,在中国这片神奇的土地上,很多人都说只能干到30岁,然后就需要转型,就像《程序员技术练级攻略》这篇文章很多人回复到这种玩法会玩死人的一样。我在很多面试中,问到应聘者未来的规划都能听到好些应聘都说程序员是个青春饭。因为,大多数程序员都认为,编程这个事只能干到30岁,最多35岁吧。每每我听到这样的言论,都让我感到相当的无语,大家都希…

    Linux干货 2016-08-15
  • 条件判断if、case与文件查找locate、find及相关练习

    一、条件选择 1、if:按条件执行脚本中的内容,可以使用嵌套结构,有单分支、双分支和多分支结构,每个条件中可以有不止一条语句,如果有多条语句,可以用and(-a)或or(-o)连接在一起,但不能使用&&或||: if COMMANDS; then     COMMANDS;   &n…

    Linux干货 2016-08-18