`
maosheng
  • 浏览: 550508 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

NFS 挂载文件系统

nfs 
阅读更多
NFS 挂载文件系统

1.概述

NFS(Network File System) 即 网络文件系统,允许一个节点通过网络访问远程计算机的文件系统,远程文件系统可以被直接挂载到本地,文件操作和本地没有区别。

2.服务端

  首先是服务端配置,服务端提供文件系统供客户端来挂载使用,配置过程如下:

  首先检查是否缺少基础环境:

     > rpm -qa | grep nfs-utils   ##NFS服务的主程序
     > rpm -qa | grep rpcbind     ##rpc程序





  如果这两个包存在那么可以直接使用,一般服务器安装的时候都会存在,如果没有的话执行下面命令安装:

     > yum -y install nfs-utils
     > yum -y install rpcbind

  安装完成之后配置nfs访问目录,配置文件位置/etc/exports,默认是空的,这里添加一行:

     /etc/exports配置文件的格式是:
     NFS共享的目录  NFS客户端地址(参数1,参数2)

     NFS客户端地址可以是一个IP,一个网段,一个域名,域名通配符:*.youxia.com,客户端地址和权限之间没有空格。


     /nfs_test 192.168.1.8(rw,no_root_squash,no_all_squash,async)

  这个配置表示开放本地存储目录/nfs_test 只允许192.168.1.8这个主机有访问权限,rw表示允许读写;no_root_squash表示root用户具有完全的管理权限;no_all_squash表示保留共享文件的UID和GID,此项是默认不写也可以;async表示数据可以先暂时在内存中,不是直接写入磁盘,是先写到缓存区,再写到磁盘里,可以提高性能,另外也可以配置sync表示数据直接同步到磁盘;就配置这些就可以,保存退出

  如果想让另外一台主机也可以挂载这个目录,那么直接在后面追加即可,比如:

     /nfs_test 192.168.1.8(rw,no_root_squash,no_all_squash,async) 192.168.1.9(rw,no_root_squash,no_all_squash,async)

  多个目录可以每行配置一个,如果想让这个网段的主机都可以访问,假如此时子网掩码是255.255.255.0,网关是192.168.1.0,那么ip那里可以写成192.168.1.0/24表示允许地址段的所有主机访问。

  其他参数:

  rw : read-write  读写权限
  ro :  read-only  只读权限
  no_root_squash: 如果客户端以root身份登录,则对共享的服务器目录页有root的使用权限(不安全)。
  root_squash:如果客户端以root身份登录,则对共享的服务器目录以匿名用户的权限操作,一般为nobody或者nfsnobody.


  现在配置完这些配置,启动相关服务:

     > systemctl start rpcbind.service
     > systemctl start nfs.service

  启动之后可以通过status来查看状态,如果下次修改了配置,可以重启服务来使配置生效,也可以直接执行如下命令刷新配置:

     > exportfs -a
  刷新配置即可生效

3.客户端

  现在服务端配置完毕,可以在对应的主机上来配置客户端了,需要的环境和服务端一样,要保证安装nfs-utils和rpcbind

  保证环境没问题和上面一样启动rpcbind服务和nfs服务

  首先创建挂载点: mkdir /mnt/test1

  然后挂载nfs: mount -t nfs 192.168.1.3:/nfs_test /mnt/nfs

    解析:

    mount -t nfs           -->挂载命令,表示挂载NFS共享的文件夹
    192.168.1.3:/nfs_test  -->服务器端共享的文件夹路径,格式为 IP:/共享文件夹路径
    /mnt/nfs               -->映射到本地的文件夹,即客户端开发板上的文件夹。


  挂载成功之后通过 df -h 可以查看挂载的情况,nfs可用空间就是服务端/nfs_test目录所能使用的最大空间

  现在就可以往nfs写入数据了,服务端往/nfs_test读写数据和客户端往/mnt/nfs读写数据是一样的,这样就实现了文件同步和共享

  查看目前客户端的挂载情况
    > mount | grep nfs

  卸载nfs和普通文件系统一样,使用: umount /mnt/nfs

 
  开机自动挂载
  > vim /etc/rc.local
  ##添加一行
  sudo mount -t nfs 192.168.1.3:/nfs_test /mnt/nfs


OK,至此挂载完毕,其实就是通过NFS共享了一个文件夹。


4.检查命令

  nfs服务端:

  > showmount     ### 查看挂载状态

  nfs客户端:

  > mount       ###查看挂载点状态

  > df -h       ###查看系统状态 








  • 大小: 8.4 KB
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics