How to build a NFS Service
NFS网络文件系统的服务的配置
1 Preparation
Three Linux virtual machines
one: to be NFS Service
the other two: NFS Clinet
2 Install And Setting
2.1 checking System version
Client:
cat /etc/redhat-release
uname -a
ifconfig

Service:
cat /etc/redhat-release
uname -a
ifconfig

you are better make sure three Linux System is same.
2.2 Checking RPC and NFS whether has installed at Service
Service:
rpm -aq nfs-utils portmap rpcbind

If the PRC and NFS haven’t installed, you can user “ yum install nfs-utils rpcbind -y”
2.3 Start NFS and RPC Service at Service
switch to NFS Service
Firstly start RPC Service at service.
rpcinfo -p localhost: check RPC localhost port
“rpcinfo: can't contact portmapper: RPC: Remote system error - Connection refused”: show RPC Service does not start.

Secondly: start NFS Service

2.4 Setting NSF at Service
/etc/exports is setting of NFS, we need to set it by “VIM”.
The GateWay can be replaced by IP, it will make the /date used by only Client. So we always use gateway.
The authority includes:
ro: only read
wo:only write
sync:
use “,” as separator.

Then, you need to reload the nfs Service.

Then, you need to check the mount information for an NFS Server.

At this moment, The Service is OK.
2.5 Setting RPC in Client
switch to NFS Client.
Firstly: start RPC Service.

Check NFS information of NFS Server from Client, If show flowing it success.

If it don’t success ,you use ping SERVICE_IP or telnet SERVICE_IP 111(RPC port) to check where error occurs.
you are better make sure two client Linux System is same.
2.6 mount Service Data and update directory owner.

The you should update owner or group of /data at Service, or client will has authority errors.
If you set “w” authority, you need set “nfsnobody” to owner or group of /data and give writable authority.

“nfsnobody” is the default user of NFS.
you can see it’s UID in /var/lib/nfs/etab

If show red information, it is OK.
The another client operations is same as first one.
3 run and test
switch to Client.

Then switch to Service

If the /date of Service is same as the /mnt of Client, indicates it success.
4 optimization
4.1 set start with System open
we add all NFS, RPC starting commands in /etc/rc.local file to manage easily.
at Service:

at Client: you better make sure two client is same.

4.2 update /etc/exports
we want all clients can ADD, VIEW, UPDATE, and DELETE file. So we should use the same user to execute the client process. So we can use
all_squash: indicates all user will be set anonuid, if anonuid is not given, using default nfsnobody to be the client process executor.
anonuid: give executor UID
anongid: give executor GID

It will prompt the system safety.
4.3 use soft not hard
hard: request NFS service all time
soft: request NFS service intermittent
but, the two options belong to mount.
We use soft we reduce the coupling(耦合性) between NFS Service and NFS Client.
So we should use flowing command to mount NFS Service and add it at /etc/rc.local
/bin/mount -t nfs -o soft 192.168.98.132:/data /mnt/.

4.4 rsize, wsize
rsize: the max size of cache of reading file.
wsize: the max size of buffer of write file
test data:
#test read and write speed about rsize,wsize
the rsize=1024,wsize=1024
time sh read.sh
real 0m43.792s
user 0m11.669s
sys 0m21.960s
time sh write.sh
20000+0 records in
20000+0 records out
184320000 bytes (184 MB) copied, 64.963 s, 2.8 MB/s
real 1m5.058s
user 0m0.006s
sys 0m6.103s
[root@nfs_clinet_2 nfs_test]# grep mnt /proc/mounts
192.168.98.132:/data/ /mnt nfs4 rw,relatime,vers=4,rsize=1024,wsize=1024,namlen=255,soft,proto=tcp,port=0,timeo=600,retrans=2,sec=sys,clientaddr=192.168.98.134,minorversion=0,local_lock=none,addr=192.168.98.132 0 0
the rsize=262144,wsize=262144,
time sh read.sh
real 0m37.112s
user 0m4.690s
sys 0m25.867s
time sh write.sh
20000+0 records in
20000+0 records out
184320000 bytes (184 MB) copied, 6.63189 s, 27.8 MB/s
real 0m6.645s
user 0m0.002s
sys 0m1.366s
grep mnt /proc/mounts
192.168.98.132:/data/ /mnt nfs4 rw,relatime,vers=4,rsize=262144,wsize=262144,namlen=255,soft,proto=tcp,port=0,timeo=600,retrans=2,sec=sys,clientaddr=192.168.98.134,minorversion=0,local_lock=none,addr=192.168.98.132 0 0
obvious the rsize and wsize bigger, the speed is more quickly.
In Centos 6.5 default rsize and wrize is so good ,we don’t need to update it.
4.5 noatime, nodiratime
noatime: when you access a file, will not update its atime
nodiratime: when you access a file, will not update its atiem
If you hope you NFS Service read/write more quickly, you can add these two options.
4.6 nosuid, noexec, nodev
nosuid: forbidden seting suid
noexec:forbidden executing scripts, including shell and scropts
nodev: Do not interpret character or block special devices on the file system.
The three is safe options, we can use these to prevent our system be invaded
The picture is show noexec option effect.

How to build a NFS Service的更多相关文章
- Build a Restful Service
最近项目中遇到的REST的问题很多,很多情况下受weblogic以及Jdeveloper版本的影响,无法直接从Jdeveloper中生成一个RESTful Service出来,所以基于流行的Sprin ...
- [转]How to Use Web API OData to Build an OData V4 Service without Entity Framework
本文转自:http://www.odata.org/blog/how-to-use-web-api-odata-to-build-an-odata-v4-service-without-entity- ...
- NFS文件系统存储服务部署
1 NFS介绍 1.1 什么是NFS? NFS是Network File System的缩写,中文名称是网络文件系统.它的主要功能是通过网络让不用的主机系统之间可以共享文件或者目录.NFS客户端通过挂 ...
- nfs服务的讲解
第4章 nfs存储服务的搭建 4.1 nfs服务的介绍 4.1.1 nfs的作用 nfs服务器是一种远程网络传输的共享文件系统 节省web服务器的本地存储空间 用户存储在web服务器上面的资源,会通过 ...
- 【集群实战】NFS网络文件共享服务
1. NFS介绍 1.1 什么是NFS? NFS是Network File System的缩写,中文意思是网络文件系统. 它的主要功能是通过网络(一般是局域网)让不同的主机系统之间可以共享文件或目录. ...
- Linux NFS 服务部署
系统环境:Oracle Linux 5.7 服务端:192.168.1.111 客户端:192.168.1.171 一.服务端配置 二.客户端配置 一.服务端配置 1.依次启动portmap和nfs服 ...
- Windows Service--Write a Better Windows Service
原文地址: http://visualstudiomagazine.com/Articles/2005/10/01/Write-a-Better-Windows-Service.aspx?Page=1 ...
- 2 NFS高可用解决方案之NFS的搭建
preface 我们紧接着上一篇博文的基础(drbd+heartbeat的正常工作,http://www.cnblogs.com/liaojiafa/p/6129499.html)来搭建NFS的服务. ...
- Linux 配置NFS,文件共享
配置: 1.设定共享主机服务器 ---(注意防火墙) 编辑ipA端的/etc/exports 文件 [root@dbrac2 ~]# cat /etc/exports /media 192 ...
随机推荐
- Linux2.6内核协议栈系列--TCP协议2.接收
1.排队机制 接收输入TCP报文时,有三个队列: ● 待处理队列 ● 预排队队列 ● 接收队列 接收队列包含了处理过的TCP数据段,也就是说,去除了全部的协议头,正准备将数据复制到用户应用程序.接收队 ...
- luke使用
Luke介绍 Luke是一个方便的索引查看和诊断工具,可以访问Lucene构建的索引文件,显示和修改某些索引内容.能提供: 通过document编号或term浏览索引 查看document内容,可复制 ...
- [Erlang 0124] Erlang Unicode 两三事 - 补遗
最近看了Erlang User Conference 2013上patrik分享的BRING UNICODE TO ERLANG!视频,这个分享很好的梳理了Erlang Unicode相关的问题,基本 ...
- MySQL高可用方案
高可用架构对于互联网服务基本是标配,无论是应用服务还是数据库服务都需要做到高可用.虽然互联网服务号称7*24小时不间断服务,但多多少少有一些时候服务不可用,比如某些时候网页打不开,百度不能搜索或者无法 ...
- log4j:ERROR Failed to rename [/log/xxx.log] to [/log/xxx.log.2016-11-23.log]
Log4j报错: log4j:ERROR Failed to rename [/log/xxx.log] to [/log/xxx.log.2016-11-23.log] google了一下发现是个b ...
- Oracle学习笔记十二 子程序(存储过程、自定函数)和程序包
子程序 子程序:命名的 PL/SQL 块,编译并存储在数据库中. 子程序的各个部分: 1.声明部分 2.可执行部分 3.异常处理部分(可选) 子程序的分类: 1.过程 - 执行某些操作 2.函数 ...
- 浅谈Virtual Machine Manager(SCVMM 2012) cluster 过载状态检测算法
在我们使用scvmm2012的时候,经常会看到群集状态变成了这样 点开看属性后,我们发现是这样 . 发现了吗?Over-committed,如果翻译过来就是资源过载,或者说资源过量使用了,那么这个状态 ...
- jpa
学习尚硅谷jpa笔记: 所依赖的jar包: 首先在META-INF下创建配置文件,persistence.xml <?xml version="1.0" encoding=& ...
- 启用SQLite的Data Provider 运行WECOMPANYSITE时遇到ERROR CREATING CONTEXT 'SPRING.ROOT': ERROR THROWN BY A DEPENDENCY OF OBJECT 'SYSTEM.DATA.SQLITE'
从网上下载的源码WeCompanySite,运行时报错 Error creating context 'spring.root': Error thrown by a dependency of ob ...
- python sokct 包详解
1. getaddrinfo简介getaddrinfo可解析得到IPv6地址,而gethostbyname仅能得到IPv4地址.getaddrinfo在Python的socket包中,以下为pytho ...