一.简介

NFS是单点的,如果一个节点出现问题,那使用它挂载服务的都将出现问题。所以需要高可用,挂掉一台不影响。
采用keepalived+rsync+inotify-tools

环境: ubuntu16.4
nfs1 192.168.1.1 /mnt/server
nfs2 192.168.1.2 /mnt/server

虚拟地址 192.168.1.3

二.操作

基本配置

1.机器之间添加信任关系免密码登录,安装nfs

2.有三项输出,则表示默认支持inotify,可以安装inotify-tools工具.
ll /proc/sys/fs/inotify

-rw-r—r— 1 root root 0 Oct 18 12:18 max_queued_events
-rw-r—r— 1 root root 0 Oct 18 12:18 max_user_instances
-rw-r—r— 1 root root 0 Oct 18 12:18 max_user_watches

同步配置(2台服务器均操作)

1.编写脚本
vim sync_nfs.sh

  1. #!/bin/bash
  2. #监控本地目录,有变动则输出一下
  3. inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f%e' -e close_write,delete,create,attrib /mnt/server/ | while read file
  4. do
  5. #将本地同步到远程目录,这里要根据实际情况修改
  6. rsync -avz --delete /mnt/server/ root@192.168.1.1:/mnt/server/
  7. echo " ${file} was rsynced" >>/tmp/rsync.log 2>&1
  8. done

2.添加权限并运行
chmod +x sync_nfs.sh
nohup inotify_bak.sh &

3.查看日志
tail -f /tmp/rsync.log

4.提示
如果是主备模式,则一个脚本直接同步即可,如果是双方做备份,则要写2个脚本进行互相同步

主备切换(均操作)

1.安装keepalived
apt-get install keepalived -y

2.编写文件,默认可能没有配置文件,直接新建即可
vim /etc/keepalived/keepalived.conf

  1. ! Configuration File for keepalived
  2. global_defs { #全局配置
  3. router_id lb01 #路由id号,不能重复
  4. }
  5. vrrp_script nfs #vrrp脚本命名
  6. {
  7. script "/etc/keepalived/check_nfs.sh" #要执行的脚本
  8. interval 2 #脚本指定间隔
  9. weight -40 #优先级(如果脚本执行结果为0,并且weight配置的值大于0,则优先级相应的增加,如果脚本执行结果非0,并且weight配置的值小于0,则优先级相应的减少)
  10. }
  11. vrrp_instance VI_1 { #定义一个实例
  12. state MASTER #态参数 master/backup 只是说明,具体根据优先级
  13. interface eth0 #虚IP地址放置的网卡位置
  14. virtual_router_id 51 #同一个集群id一致
  15. priority 100 #优先级决定是主还是备 越大越优先
  16. advert_int 1 #主备通讯时间间隔
  17. authentication {
  18. auth_type PASS
  19. auth_pass 1111 #认证号,集群中要一致
  20. }
  21. virtual_ipaddress {
  22. 192.168.1.3 #使用的虚拟ip,要和网段内ip不冲突
  23. }
  24. }

备份nfs配置文件,这是不一样的

  1. ! Configuration File for keepalived
  2. global_defs { #全局配置
  3. router_id lb02 #路由id号,不能重复
  4. }
  5. vrrp_script nfs #vrrp脚本命名
  6. {
  7. script "/etc/keepalived/check_nfs.sh" #要执行的脚本
  8. interval 2 #脚本指定间隔
  9. weight -40 #优先级(如果脚本执行结果为0,并且weight配置的值大于0,则优先级相应的增加,如果脚本执行结果非0,并且weight配置的值小于0,则优先级相应的减少)
  10. }
  11. vrrp_instance VI_1 { #定义一个实例
  12. state BACKUP #态参数 master/backup 只是说明,具体根据优先级
  13. interface eth0 #虚IP地址放置的网卡位置
  14. virtual_router_id 51 #同一个集群id一致
  15. priority 80 #优先级决定是主还是备 越大越优先
  16. advert_int 1 #主备通讯时间间隔
  17. authentication {
  18. auth_type PASS
  19. auth_pass 1111 #认证号,集群中要一致
  20. }
  21. virtual_ipaddress {
  22. 192.168.1.3 #使用的虚拟ip,要和网段内ip不冲突
  23. }
  24. }

3.编写检查脚本
vim /etc/keepalived/check_nfs.sh

  1. #!/bin/bash
  2. #nfs服务检测脚本,服务不存在则返回1
  3. A=`ps -aux | grep '\[nfsd\]' | wc -l`
  4. if [ $A -eq 0 ];then
  5. exit 1 #测试的时候可以加一个echo 1
  6. fi

添加权限
chmod +x /etc/keepalived/check_nfs.sh

4.测试
systemctl start keepalived

查看是否有配置的虚拟ip,ping一下试试,只会在主上面出现
ip addr

nfs高可用的更多相关文章

  1. 2 NFS高可用解决方案之NFS的搭建

    preface 我们紧接着上一篇博文的基础(drbd+heartbeat的正常工作,http://www.cnblogs.com/liaojiafa/p/6129499.html)来搭建NFS的服务. ...

  2. (转)Heartbeat+DRBD+NFS高可用案例

    原文:http://9861015.blog.51cto.com/9851015/1939521--------------------------------Heartbeat+DRBD+NFS高可 ...

  3. 1 NFS高可用解决方案之DRBD+heartbeat搭建

    preface NFS作为业界常用的共享存储方案,被众多公司采用.我司也不列外,使用NFS作为共享存储,为前端WEB server提供服务,主要存储网页代码以及其他文件. 高可用方案 说道NFS,不得 ...

  4. NFS-heartbeat-drbd模拟NFS高可用

    NFS介绍: NFS(Network File System)即网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间通过TCP/IP网络共享资源.在NFS的应用中,本地NFS ...

  5. 使用DRBD+KEEPALIVED来实现NFS高可用

    目录 一 DRBD介绍 二 DRBD的模式 三 DRBD的同步协议 四 实验环境 五 安装配置 关于脑裂(split-brain)处理 一 DRBD介绍 DRBD(Distributed Replic ...

  6. DRBD+Heratbeat+NFS高可用文件共享存储

    一.概述 .通过ha-log日志可以看出主释放资源,备接管资源. 来自为知笔记(Wiz)

  7. 六十一.常用组件 、 Kafka集群 、 Hadoop高可用

    1.Zookeeper安装搭建Zookeeper集群并查看各服务器的角色停止Leader并查看各服务器的角色 1.1 安装Zookeeper1)编辑/etc/hosts ,所有集群主机可以相互 pin ...

  8. Nfs+Drdb+Heartbeat 数据存储高可用服务架构方案

    一.方案的应用场景 适用于2千万-3千万PV架构的网站,Nfs数据存储高可用服务方案 备注:互联网排名前30左右公司常用的架构 二.生产环境方案部署原理图 三.生产环境服务器硬件配置: 生产环境中采用 ...

  9. Centos下部署DRBD+NFS+Keepalived高可用环境记录

    使用NFS服务器(比如图片业务),一台为主,一台为备.通常主到备的数据同步是通过rsync来做(可以结合inotify做实时同步).由于NFS服务是存在单点的,出于对业务在线率和数据安全的保障,可以采 ...

随机推荐

  1. H3C Short GI

  2. FreeBSD更换国内源(pkg源使用台湾源,中科大源备用)

    安装后第一件事就是更换国内源,不然后面安装桌面等,不用国内源下载太慢. 修改 pkg 源 创建用户级 pkg 源目录:mkdir -p /usr/local/etc/pkg/repos ee /usr ...

  3. Hoax or what UVA - 11136(multiset的应用)

    刚开始把题意理解错了,结果样例没过,后来发现每天只处理最大和最小的,其余的不管,也就是说昨天的元素会影响今天的最大值和最小值,如果模拟的话明显会超时,故用multiset,另外发现rbegin()的功 ...

  4. 大数据之路week07--day07 (修改mysql默认编码)

    在Sqoop导入或者导出,我们在查看mysql的时候会出现中文乱码大部分乱码会是?这样的问号,那么该怎么处理呢? 1.打开my.cnf文件  vim /etc/my.cnf 2.找到对应需要修改的地方 ...

  5. 【http】Coolie 属性

    expires属性 指 定了coolie的生存期,默认情况下coolie是暂时存在的,他们存储的值只在浏览器会话期间存在,当用户推出浏览器后这些值也会丢失,如果想让 cookie存在一段时间,就要为e ...

  6. makefile的三个变量

    “$@”代表目标文件. “$^”代表所有的依赖文件. “$<”代表第一个依赖文件. main:main.o mytool1.o mytool2.o gcc -o $@ $^ .c.o: gcc ...

  7. apache commons-configuration包读取配置文件

    1.pom依赖添加 <!-- 配置文件读取 --> <dependency> <groupId>commons-configuration</groupId& ...

  8. [Javascript] Use requestIdleCallback to schedule JavaScript tasks at an optimal time

    JavaScript is single-threaded, which can present some problems when creating an interactive user exp ...

  9. BZOJ1113 海报PLA1(单调栈入门题)

    一,自己思考下 1,先自己思考下 N个矩形,排成一排,现在希望用尽量少的海报去cover住它们. 2,不懂. 着实不懂. 3,分析下,最优性问题对吧,然后就每什么想法了.. 虽然肯定和单调栈和单调队列 ...

  10. 1129. Shortest Path with Alternating Colors

    原题链接在这里:https://leetcode.com/problems/shortest-path-with-alternating-colors/ 题目: Consider a directed ...