运维遇到NFS挂载,所以总结一下这里主要是实战,理论很少。为了方便,部分地方使用了ansible,只用了shell模块,不影响阅读

  亲近的人是不应该分开太久的。没见面的时候朝思暮想,可一旦见到,是否双方都会无可奈何地感觉到这条鸿沟呢?虽然可怕,但这也许更接近事实。——中岛敦《古玩记》

  NFS(Network File System, 网络文件系统),用来为客户机提供共享使用的文件夹;

  将NFS服务器分享的目录,挂载到本地机器当中,本地NFS的客户端应用可以读写位于远端NFS服务器上的文件,在客户端端看起来,就像访问本地文件一样。

  NFS本身的服务并没有提供数据传递的协议,而是通过使用 RPC(远程过程调用 Remote Procedure Call)来实现。当NFS启动后,会随机的使用一些端口,NFS就会向RPC去注册这些端口。RPC就会记录下这些端口,RPC会开启111端口。通过client端和sever端端口的连接来进行数据的传输。在启动nfs之前,首先要确保rpc服务启动。但是本质上还使用的TCP协议

  使用NFS网络文件系统提供的共享目录存储数据时,我们需要在系统中部署一个NFSServer

  下载服务需要的包,设置开机自启

  ┌──[root@vms81.liruilongs.github.io]-[~] #软件包:nfs-utils

  └─$yum -y install nfs-utils.x86_64

  ┌──[root@vms81.liruilongs.github.io]-[~] #系统服务:nfs-server

  └─$systemctl enable nfs-server.service --now

  创建网络共享文件夹,写入测试信息

  ┌──[root@vms81.liruilongs.github.io]-[~]

  └─$mkdir -p /liruilong

  ┌──[root@vms81.liruilongs.github.io]-[/liruilong]

  └─$cd /liruilong/;echo `date` > liruilong.txt

  ┌──[root@vms81.liruilongs.github.io]-[/liruilong]

  └─$cd /liruilong/;cat liruilong.txt

  2021年 11月 27日 星期六 21:57:10 CST

  exports配置文件解析 (服务端)

  语法: 文件夹路径 客户机地址(权限) 客户机地址(权限)…

  PS1: /public 192.168.4.0/24

  ┌──[root@vms81.liruilongs.github.io]-[/liruilong]

  └─$cat /etc/exports

  ┌──[root@vms81.liruilongs.github.io]-[/liruilong] #任意主机可以访问 (ro)只读的方式

  └─$echo "/liruilong *(rw,sync,no_root_squash)" > /etc/exports

  刷新配置exportfs -arv

  ┌──[root@vms81.liruilongs.github.io]-[/liruilong]

  └─$exportfs -arv

  exporting *:/liruilong

  ┌──[root@vms81.liruilongs.github.io]-[/liruilong]

  └─$showmount -e #查看当前机器服务列表

  Export list for vms81.liruilongs.github.io:

  /liruilong *

  ┌──[root@vms81.liruilongs.github.io]-[/liruilong]

  └─$

  这里为了方便,使用了ansible

  然后我们需要在所有的使用节点安装nfs-utils,然后挂载

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible node -m shell -a "yum -y install nfs-utils"

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible node -m shell -a "systemctl enable nfs-server.service --now"

  nfs共享文件测试:查看指定机器的共享文件列表:showmount -e

  vms81.liruilongs.github.io

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible] #查看指定机器的共享文件列表

  └─$ansible node -m shell -a "showmount -e vms81.liruilongs.github.io"

  192.168.26.83 | CHANGED | rc=0 >>

  Export list for vms81.liruilongs.github.io:

  /liruilong *

  192.168.26.82 | CHANGED | rc=0 >>

  Export list for vms81.liruilongs.github.io:

  /liruilong *

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$

  挂载测试,这里我们通过手动的方式挂载

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible node -m shell -a "mount vms81.liruilongs.github.io:/liruilong /mnt"

  192.168.26.82 | CHANGED | rc=0 >>

  192.168.26.83 | CHANGED | rc=0 >>

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible node -m shell -a "cd /mnt/;ls"

  192.168.26.83 | CHANGED | rc=0 >>

  liruilong.txt

  192.168.26.82 | CHANGED | rc=0 >>

  liruilong.txt

  查看挂载信息

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible node -m shell -a "df -h | grep liruilong"

  192.168.26.82 | CHANGED | rc=0 >>

  vms81.liruilongs.github.io:/liruilong 150G 8.3G 142G 6% /mnt

  192.168.26.83 | CHANGED | rc=0 >>

  vms81.liruilongs.github.io:/liruilong 150G 8.3G 142G 6% /mnt

  取消挂载

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible node -m shell -a "umount /mnt"

  当然,挂载方式还可以使用开机自动挂载,触发挂载的方式

  挂载机器环境准备

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible 192.168.26.100 -m shell -a "yum -y install nfs-utils"

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible 192.168.26.100 -m shell -a "systemctl enable nfs-utils --now"

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible 192.168.26.100 -m shell -a "showmount -e 192.168.26.81"

  192.168.26.100 | CHANGED | rc=0 >>

  Export list for 192.168.26.81:

  /vdisk *

  /tmp *

  /liruilong *

  配置 etc/fstab

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible 192.168.26.100 -m shell -a "echo '192.168.26.81:/liruilong /mnt/nfsmount nfs defaults,_

  netdev 0 0' >> /etc/fstab"

  192.168.26.100 | CHANGED | rc=0 >>

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible 192.168.26.100 -m shell -a "cat /etc/fstab | grep liruilong"

  192.168.26.100 | CHANGED | rc=0 >>

  192.168.26.81:/liruilong /mnt/nfsmount nfs defaults,_netdev 0 0

  刷新配置:测试

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible 192.168.26.100 -m shell -a " mkdir /mnt/nfsmount"

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible 192.168.26.100 -m shell -a " mount -a"

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible 192.168.26.100 -m shell -a " ls -l /mnt/nfsmount"

  192.168.26.100 | CHANGED | rc=0 >>

  总用量 4

  -rw-r--r-- 1 root root 43 11月 27 21:57 liruilong.txt

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ll /liruilong/

  总用量 4

  -rw-r--r-- 1 root root 43 11月 27 21:57 liruilong.txt

  由 autofs 服务提供的 “按需访问” 机制,只要访问挂载点,就会触发响应,自动挂载指定设备;闲置超过时限(默认5分钟)后,会自动卸载

  安装需要的软件包

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible 192.168.26.100 -m shell -a "yum -y install autofs"

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible 192.168.26.100 -m shell -a "systemctl enable autofs --now"

  192.168.26.100 | CHANGED | rc=0 >>

  Created symlink from /etc/systemd/system/multi-user.target.wants/autofs.service to /usr/lib/systemd/system/autofs.service.

  查看配置文件位置

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible 192.168.26.100 -m shell -a "rpm -qc autofs"

  [WARNING]: Consider using the yum, dnf or zypper module rather than running 'rpm'. If you need to use

  command because yum, dnf or zypper is insufficient you can add 'warn: false' to this command task or

  set 'command_warnings=False' in ansible.cfg to get rid of this message.

  192.168.26.100 | CHANGED | rc=0 >>

  /etc/auto.master

  /etc/auto.misc

  /etc/auto.net

  /etc/auto.smb

  /etc/autofs.conf

  /etc/autofs_ldap_auth.conf

  /etc/sysconfig/autofs

  /usr/lib/systemd/system/autofs.service

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$

  配置文件编辑

  配置自动挂载需要修改两个配置文件,一个/etc/auto.master

  /etc/auto.master这个配置文件为主配置文件,配置当前机器挂载的目录的配置文件

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible 192.168.26.100 -m shell -a "echo '/liruilong /etc/auto.misc' >> /etc/auto.master"

  192.168.26.100 | CHANGED | rc=0 >>

  这个配置文件为挂载目录挂载的远程目录配置文件的挂载

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible 192.168.26.100 -m shell -a "echo 'sy -fstype=nfs 192.168.26.81:/liruilong ' >>/etc/auto.misc"

  192.168.26.100 | CHANGED | rc=0 >>

  重启服务

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible 192.168.26.100 -m shell -a "systemctl restart autofs"

  192.168.26.100 | CHANGED | rc=0 >>

  触发挂载,查看

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ls /liruilong/

  liruilong.txt mGAX.23 work

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible 192.168.26.100 -m shell -a "ls /liruilong/sy"

  192.168.26.100 | CHANGED | rc=0 >>

  liruilong.txt

  mGAX.23

  work

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$ansible 192.168.26.100 -m shell -a "df -ah | grep liruilong"

  192.168.26.100 | CHANGED | rc=0 >>

  192.168.26.81:/liruilong 150G 8.5G 142G 6% /mnt/nfsmount

  /etc/auto.misc 0 0 0 - /liruilong

  192.168.26.81:/liruilong 150G 8.5G 142G 6% /liruilong/sy

  ┌──[root@vms81.liruilongs.github.io]-[~/ansible]

  └─$


更多相关文章

  1. Android使用SAX解析XML(4)
  2. 【Android】Menu不同菜单的使用介绍
  3. 如何在Android平台上创建自定义的Cordova插件并使用SAP UI5消费
  4. android中启动服务
  5. android Fragment
  6. Android(安卓)使用FTP上传文件
  7. Android使用DigitalClock进行定时抢购
  8. Android(安卓)Studio插件大全
  9. Material Design综合实例

随机推荐

  1. Android的SDK与ADT不匹配问题
  2. android studio 报Error:failed to find
  3. 环境变量ANDROID_SDK_HOME的作用
  4. android控件之ImageButton android:scale
  5. android布局居中
  6. android:各种访问权限Permission
  7. android消息处理机制学习(一)-Handler,Mess
  8. android 二 BMI 小例子
  9. Android 3.0 r1 API中文文档(107) —— A
  10. android aapt (android asset packaging t