本文旨在实现NFS为lamp环境web站点提供共享存储。

1.实验需求


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

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

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

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

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

(5)nfs server 导出/mydata/目录;

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

2.服务器规划


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

web服务器01(apache+php)

nfs客户端

web01 172.16.52.51
centos7.2x86_64

web服务器02(apache+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

3.实验拓扑


4.部署NFS服务端及nfs客户端


4.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

启动rpcbind和nfs服务:

注意要先启动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


4.2 配置nfs客户端

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

安装软件包:

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

启动rpcbind:

客户端只用启动rpcbind即可。

[root@db ~]# systemctl start rpcbind


5.部署lamp环境


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

web01 和web02 配置一样。

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

5.1 安装软件

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

5.2 配置虚拟主机

[root@web01 conf.d]# cat blog.conf
<VirtualHost *:80>ServerNameblog.magedu.comDocumentRoot"/var/www/html"CustomLog"/var/log/httpd/blog/access_log" combinedErrorLog  "/var/log/httpd/blog/error_log"  <Directory"/var/www/html">OptionsNoneAllowOverrideNoneRequireall granted</Directory>
</VirtualHost>

5.3 php访问测试

6. 部署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

6.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)

6.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

6.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

6.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表每个表一个表空间文件。

6.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

6.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)

6.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';elseecho'failure';
?>

6.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,没有问题。

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


7.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

在博客里发一篇文章,插入一张图片。

7.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

(4)读写测试,插入图片

7.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

访问没有问题

测试插入图片:

8. 总结


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

转载于:https://blog.51cto.com/zhangbei/1828602

NFS为lamp提供共享存储实践相关推荐

  1. glusterfs+heketi为k8s提供共享存储

    背景 近来在研究k8s,学习到pv.pvc .storageclass的时候,自己捣腾的时候使用nfs手工提供pv的方式,看到官方文档大量文档都是使用storageclass来定义一个后端存储服务, ...

  2. NFS技术实现图片共享存储

    几乎所有的软件都有图片或附件的资源,将应用服务区和图片服务器放一起不合理的行为,因为一般图片服务器IO消耗严重,可能导致应用崩溃.因此需要剥离出专门的图片服务器,正对其进行专门的优化.对于小型的图片服 ...

  3. heartbeat(v2)实现LAMP提供wordpress博客站点高可用模型实践

    友情提醒:本文实验环境 vmware 10 + Centos 6.6 X86_64,文中涉及到的命令和方式请谨慎使用 内容概括: 1)实验思路 2)实验环境和拓扑 3)实验步骤 4)实验后的思考 一 ...

  4. CentOS7.5搭建Heartbeat+DRBD+NFS高可用共享存储

    在一般的网络架构的设计中,如果前端web做了负载均衡,后端存储都会用到共享存储,在并发不大.数据量不大的情况下,nfs是一个不错共享存储方案,但是nfs存在单点故障的问题,要想保证nfs的高可用,就要 ...

  5. 基于共享存储的Harbor高可用-Docker部署方案

    部署规划 架构图 Redis也可以和Harbor集中部署.这样避免了在不使用Reids集群模式下单节点的故障. 使用此模式,目前测试对于Harbor的登录,镜像信息查看,在计算节点,镜像的推送和下载没 ...

  6. 并行多核体系结构基础 Yan Solihin 第6章 共享存储多处理器简介 摘录

    本章讨论需要什么样的硬件支持才能保证多处理器系统上基于共享存储的并行程序的正确执行.将介绍三种主要类型的硬件支持:1)缓存一致性协议,确保多个处理器看到的缓存数据是一致的:2)存储一致性模型,确保存储 ...

  7. 3.NFS 共享存储

    1.NFS基本概述 共享存储,文件服务器 NFS是Network File System的缩写及网络文件系统.NFS主要功能是通过局域网络让不同的主机系统之间可以共享文件或目录.NFS系统和Windo ...

  8. Linux YUM扩展NFS共享存储服务(配置图解)

    NFS共享存储服务 一.YUM 1.YUM (Yellow dog Updater Modified) 2.软件仓库的提供方法 3.RPM软件包的来源 4.构建CentOS 7 软件仓库 5.在软件仓 ...

  9. nfs服务器远程访问,NFS远程共享存储

    原标题:NFS远程共享存储 构建储NFS远程共享存 因为NFS有很多功能,不同的功能需要使用不同的端口.因此NFS无法固定端口.而RPC会记录NFS端口的信息,这样就能够通过RPC实现服务端和客户端的 ...

最新文章

  1. Shell 下记录程序运行时间
  2. 功能性农业未来方向-农业大健康·徐春晖:农业品牌市场规范
  3. PHP 笔记——操作MySQL数据库
  4. IXDC 2018 | 打动人心的互联网保险设计
  5. android settext 参数,Android TextView.setTextColor()的参数设置方式
  6. 一级减速器装配图cad文件_减速器的基本结构,减速箱各组成零件的结构及功用,值得保存...
  7. 保存时间 默认_一些不起眼但又非常的实用的PPT制作技巧,大大节省PPT制作时间...
  8. 多核分布式队列的实现:“偷”与“自私”的运用(1)
  9. Docker快速搭建Tuleap项目管理平台
  10. 摄影基础知识:等效焦距是什么?
  11. Node.js之------模块篇
  12. 小白学前端之:JavaScript null 和 undefined 的区别
  13. 用U盘PE启动安装系统教程
  14. css文本样式(一):css字体样式
  15. 铃木雅臣晶体管电路设计学习笔记1
  16. 油管YouTube直播点赞订阅提示PR字幕Mogrt动态图形模板
  17. 能够有效提高App线下活动的方法
  18. Android性能优化系列之电量优化
  19. html中scr作用,车用尿素在SCR系统中的作用讲解?
  20. ffmpeg 之 dash

热门文章

  1. 我的Linux随笔目录
  2. Hadoop JobHistory
  3. 删除指定目录下的所有文件包括目录
  4. 树莓派安装python模块_树莓派引脚编号、pypi说明和安装
  5. 系统试图将驱动器合并到合并驱动器上的目录_系统小技巧:“徒手”创建可启动的VHD系统...
  6. Windowsw核心编程 第13章 Windows内存结构
  7. hdu1251 hash或者字典树
  8. 操作系统原理第三章:进程
  9. 【Linux 内核 内存管理】虚拟地址空间布局架构 ① ( 虚拟地址空间布局架构 | 用户虚拟地址空间划分 )
  10. 【Android 逆向】整体加固脱壳 ( DexClassLoader 加载 dex 流程分析 | 类加载器构造函数分析 | DexPathList 引入 )