nfs高可用
一.简介
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
#!/bin/bash
#监控本地目录,有变动则输出一下
inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f%e' -e close_write,delete,create,attrib /mnt/server/ | while read file
do
#将本地同步到远程目录,这里要根据实际情况修改
rsync -avz --delete /mnt/server/ root@192.168.1.1:/mnt/server/
echo " ${file} was rsynced" >>/tmp/rsync.log 2>&1
done
2.添加权限并运行chmod +x sync_nfs.sh
nohup inotify_bak.sh &
3.查看日志tail -f /tmp/rsync.log
4.提示
如果是主备模式,则一个脚本直接同步即可,如果是双方做备份,则要写2个脚本进行互相同步
主备切换(均操作)
1.安装keepalivedapt-get install keepalived -y
2.编写文件,默认可能没有配置文件,直接新建即可vim /etc/keepalived/keepalived.conf
! Configuration File for keepalived
global_defs { #全局配置
router_id lb01 #路由id号,不能重复
}
vrrp_script nfs #vrrp脚本命名
{
script "/etc/keepalived/check_nfs.sh" #要执行的脚本
interval 2 #脚本指定间隔
weight -40 #优先级(如果脚本执行结果为0,并且weight配置的值大于0,则优先级相应的增加,如果脚本执行结果非0,并且weight配置的值小于0,则优先级相应的减少)
}
vrrp_instance VI_1 { #定义一个实例
state MASTER #态参数 master/backup 只是说明,具体根据优先级
interface eth0 #虚IP地址放置的网卡位置
virtual_router_id 51 #同一个集群id一致
priority 100 #优先级决定是主还是备 越大越优先
advert_int 1 #主备通讯时间间隔
authentication {
auth_type PASS
auth_pass 1111 #认证号,集群中要一致
}
virtual_ipaddress {
192.168.1.3 #使用的虚拟ip,要和网段内ip不冲突
}
}
备份nfs配置文件,这是不一样的
! Configuration File for keepalived
global_defs { #全局配置
router_id lb02 #路由id号,不能重复
}
vrrp_script nfs #vrrp脚本命名
{
script "/etc/keepalived/check_nfs.sh" #要执行的脚本
interval 2 #脚本指定间隔
weight -40 #优先级(如果脚本执行结果为0,并且weight配置的值大于0,则优先级相应的增加,如果脚本执行结果非0,并且weight配置的值小于0,则优先级相应的减少)
}
vrrp_instance VI_1 { #定义一个实例
state BACKUP #态参数 master/backup 只是说明,具体根据优先级
interface eth0 #虚IP地址放置的网卡位置
virtual_router_id 51 #同一个集群id一致
priority 80 #优先级决定是主还是备 越大越优先
advert_int 1 #主备通讯时间间隔
authentication {
auth_type PASS
auth_pass 1111 #认证号,集群中要一致
}
virtual_ipaddress {
192.168.1.3 #使用的虚拟ip,要和网段内ip不冲突
}
}
3.编写检查脚本vim /etc/keepalived/check_nfs.sh
#!/bin/bash
#nfs服务检测脚本,服务不存在则返回1
A=`ps -aux | grep '\[nfsd\]' | wc -l`
if [ $A -eq 0 ];then
exit 1 #测试的时候可以加一个echo 1
fi
添加权限chmod +x /etc/keepalived/check_nfs.sh
4.测试
systemctl start keepalived
查看是否有配置的虚拟ip,ping一下试试,只会在主上面出现ip addr
nfs高可用的更多相关文章
- 2 NFS高可用解决方案之NFS的搭建
preface 我们紧接着上一篇博文的基础(drbd+heartbeat的正常工作,http://www.cnblogs.com/liaojiafa/p/6129499.html)来搭建NFS的服务. ...
- (转)Heartbeat+DRBD+NFS高可用案例
原文:http://9861015.blog.51cto.com/9851015/1939521--------------------------------Heartbeat+DRBD+NFS高可 ...
- 1 NFS高可用解决方案之DRBD+heartbeat搭建
preface NFS作为业界常用的共享存储方案,被众多公司采用.我司也不列外,使用NFS作为共享存储,为前端WEB server提供服务,主要存储网页代码以及其他文件. 高可用方案 说道NFS,不得 ...
- NFS-heartbeat-drbd模拟NFS高可用
NFS介绍: NFS(Network File System)即网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间通过TCP/IP网络共享资源.在NFS的应用中,本地NFS ...
- 使用DRBD+KEEPALIVED来实现NFS高可用
目录 一 DRBD介绍 二 DRBD的模式 三 DRBD的同步协议 四 实验环境 五 安装配置 关于脑裂(split-brain)处理 一 DRBD介绍 DRBD(Distributed Replic ...
- DRBD+Heratbeat+NFS高可用文件共享存储
一.概述 .通过ha-log日志可以看出主释放资源,备接管资源. 来自为知笔记(Wiz)
- 六十一.常用组件 、 Kafka集群 、 Hadoop高可用
1.Zookeeper安装搭建Zookeeper集群并查看各服务器的角色停止Leader并查看各服务器的角色 1.1 安装Zookeeper1)编辑/etc/hosts ,所有集群主机可以相互 pin ...
- Nfs+Drdb+Heartbeat 数据存储高可用服务架构方案
一.方案的应用场景 适用于2千万-3千万PV架构的网站,Nfs数据存储高可用服务方案 备注:互联网排名前30左右公司常用的架构 二.生产环境方案部署原理图 三.生产环境服务器硬件配置: 生产环境中采用 ...
- Centos下部署DRBD+NFS+Keepalived高可用环境记录
使用NFS服务器(比如图片业务),一台为主,一台为备.通常主到备的数据同步是通过rsync来做(可以结合inotify做实时同步).由于NFS服务是存在单点的,出于对业务在线率和数据安全的保障,可以采 ...
随机推荐
- H3C Short GI
- FreeBSD更换国内源(pkg源使用台湾源,中科大源备用)
安装后第一件事就是更换国内源,不然后面安装桌面等,不用国内源下载太慢. 修改 pkg 源 创建用户级 pkg 源目录:mkdir -p /usr/local/etc/pkg/repos ee /usr ...
- Hoax or what UVA - 11136(multiset的应用)
刚开始把题意理解错了,结果样例没过,后来发现每天只处理最大和最小的,其余的不管,也就是说昨天的元素会影响今天的最大值和最小值,如果模拟的话明显会超时,故用multiset,另外发现rbegin()的功 ...
- 大数据之路week07--day07 (修改mysql默认编码)
在Sqoop导入或者导出,我们在查看mysql的时候会出现中文乱码大部分乱码会是?这样的问号,那么该怎么处理呢? 1.打开my.cnf文件 vim /etc/my.cnf 2.找到对应需要修改的地方 ...
- 【http】Coolie 属性
expires属性 指 定了coolie的生存期,默认情况下coolie是暂时存在的,他们存储的值只在浏览器会话期间存在,当用户推出浏览器后这些值也会丢失,如果想让 cookie存在一段时间,就要为e ...
- makefile的三个变量
“$@”代表目标文件. “$^”代表所有的依赖文件. “$<”代表第一个依赖文件. main:main.o mytool1.o mytool2.o gcc -o $@ $^ .c.o: gcc ...
- apache commons-configuration包读取配置文件
1.pom依赖添加 <!-- 配置文件读取 --> <dependency> <groupId>commons-configuration</groupId& ...
- [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 ...
- BZOJ1113 海报PLA1(单调栈入门题)
一,自己思考下 1,先自己思考下 N个矩形,排成一排,现在希望用尽量少的海报去cover住它们. 2,不懂. 着实不懂. 3,分析下,最优性问题对吧,然后就每什么想法了.. 虽然肯定和单调栈和单调队列 ...
- 1129. Shortest Path with Alternating Colors
原题链接在这里:https://leetcode.com/problems/shortest-path-with-alternating-colors/ 题目: Consider a directed ...