您的位置:首页 > 运维架构 > Linux

Linux下nfs实现跨机器的文件共享

2018-03-18 20:57 477 查看
目前的项目开发过程中都是采用分布式,在上传文件的时候,文件不一定会在同一台机器中,因此就需要跨机器共享文件,在这里就简单的采用nfs实现跨机器的文件共享。

1、安装nfs和rpcbind(在centOS6之前是portmap)

检查自己的电脑是否已经默认安装了nfs和rpcbind:

[root@unsion2 ~]# rpm -aq | grep nfs
nfs-utils-1.2.3-54.el6.x86_64
nfs4-acl-tools-0.3.3-6.el6.x86_64
nfs-utils-lib-1.1.5-9.el6.x86_64

[root@unsion2 ~]# rpm -aq | grep rpcbind
rpcbind-0.2.0-11.el6.x86_64


这表示系统已经默认安装。如果没有安装也没事,可以采用下面的命令安装(需要联网,会用虚拟机的就不多说怎么联网了):

[root@unsion2 ~]# yum install nfs-utils rpcbind


2、配置nfs的配置文件和hosts文件

2.1 创建需要共享的目录:

[root@unsion2 ~]# cd /tmp
[root@unsion2 tmp]# mkdir test


2.2 配置nfs的配置文件:

[root@unsion2 ~]# vim /etc/exports


在这个文件中添加需要输出的目录,如:

/tmp/test 192.168.56.202(rw)


其中:

/tmp/test:表示的是服务器共享输入的目录

192.168.56.202:表示可以挂在服务器目录的客户端ip

(rw):表示该客户端对共享的文件具有读写权限

2.3 配置hosts文件:

[root@unsion2 ~]# vim /etc/hosts


在文件中添加下面这句话

192.168.56.201 unsion2


其中:

192.168.56.201:表示服务器本机的ip地址

unsion2:表示服务器的机器名

3、启动nfs和rpcbind服务、检测服务状态、已经设置服务开机启动

启动服务:

[root@unsion2 ~]#service rpcbind start
[root@unsion2 ~]#service nfs start


测试状态:

[root@unsion2 ~]#service rpcbind status
rpcbind (pid  1063) 正在运行...

[root@unsion2 ~]#service nfs status
rpc.svcgssd 已停
rpc.mountd (pid 2193)正在运行...
nfsd (pid 22092208 2207 2206 2205 2204 2203 2202) 正在运行...
rpc.rquotad (pid2188) 正在运行...


自动启动:

[root@unsion2 ~]#chkconfig --list rpcbind
[root@unsion2 ~]#chkconfig --list nfs


4、检测服务器的nfs状态

[root@unsion2etc]# showmount -e  //查看自己共享的服务
Export list forunsion2:
/tmp/test192.168.56.202
注意:在执行这个命令的时候如果出现错误,说明DNS不能解析当前的服务器,那就是hosts文件没有配置。


5、客户端挂载NFS中共享的目录

首先是启动nfs和rpcbind服务。

查询服务端共享的文件目录:

[root@unsion1tmp]# showmount -e 192.168.56.201
Export list for192.168.56.201:
/tmp/test192.168.56.202


创建挂载目录:

[root@unsion2 ~]# cd/tmp
[root@unsion2 tmp]#mkdir hehe


挂载服务端的共享目录:

[root@unsion1tmp]# mount 192.168.56.201:/tmp/test/ /tmp/hehe/
mount.nfs: accessdenied by server while mounting 192.168.56.201:/tmp/ test /
看到此信息表示成功挂载。


查看挂载的状态:

[root@unsion1tmp]# mount | grep nfs
sunrpc on/var/lib/nfs/rpc_pipefs type rpc_pipefs (rw)
nfsd on/proc/fs/nfsd type nfsd (rw)
192.168.56.201:/tmp/test/on /tmp/hehe type nfs (rw,vers=4,addr=192.168.56.201,clientaddr=192.168.56.202)


6、测试共享

服务器创建文件:

[root@unsion2 /]#cd /tmp/test
[root@unsion2test]# touch 123456


客户端查看文件:

[root@unsion1 /]#cd /tmp/hehe
[root@unsion1hehe]# ll
总用量 0
-rw-r--r--. 1 rootroot 0 2月  25 15:37 123456


到此就结束了,nfs实现文件的共享已经完成。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: