CentOS 7部署NFS存儲服務器
1.1NFS
網絡文件系統,是FreeBSD支持的文件系統中的一種,它允許網絡中的計算機之間通過TCP/IP網絡共享資源。在NFS的應用中,本地NFS的客戶端應用可以透明地讀寫位於遠端NFS服務器上的文件,就像訪問本地文件一樣。NFS服務只能應用在Linux系統上,FTP、samba服務均支持linux和windows。
1.2工作原理
部署好NFS服務,在NFS服務端創建一個data共享目錄;NFS客戶端創建一個本地video目錄,作為掛載點,通過mount命令實現網絡掛載,將NFS服務器上的data目錄掛載到本地video目錄掛載點上;NFS客戶端上在video目錄中,增加、刪除、修改數據的操作,都等價於在NFS服務端data目錄中的操作。
2.環境準備
[root@nfs01 ~]# cat /etc/redhat-release
CentOS Linux release 7.2.1511 (Core)
[root@nfs01 ~]# uname -r
3.10.0-327.el7.x86_64
[root@nfs01 ~]# getenforce
Disabled
[root@nfs01 ~]# systemctl status firewalld.service
● firewalld.service - firewalld - dynamic firewall daemon
Loaded: loaded (/usr/lib/systemd/system/firewalld.service; disabled; vendor preset: enabled)
Active: inactive (dead)
[root@nfs01 ~]# ifconfig
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 10.0.0.31 netmask 255.255.255.0 broadcast 10.0.0.255
inet6 fe80::20c:29ff:fe7a:66a4 prefixlen 64 scopeid 0x20<link>
ether 00:0c:29:7a:66:a4 txqueuelen 1000 (Ethernet)
RX packets 1204 bytes 327779 (320.0 KiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 111 bytes 14968 (14.6 KiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
eth1: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 172.16.1.31 netmask 255.255.255.0 broadcast 172.16.1.255
inet6 fe80::20c:29ff:fe7a:66ae prefixlen 64 scopeid 0x20<link>
ether 00:0c:29:7a:66:ae txqueuelen 1000 (Ethernet)
RX packets 0 bytes 0 (0.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 10 bytes 744 (744.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536
inet 127.0.0.1 netmask 255.0.0.0
inet6 ::1 prefixlen 128 scopeid 0x10<host>
loop txqueuelen 0 (Local Loopback)
RX packets 0 bytes 0 (0.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 0 bytes 0 (0.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
3.部署NFS服務端
3.1檢查是否安裝NFS
[root@nfs01 ~]# rpm -qa nfs
3.2安裝NFS
[root@nfs01 ~]# yum install -y nfs-utils rpcbind
3.3創建共享目錄的管理用戶
[root@nfs01 ~]# useradd -s /sbin/nologin -M www
[root@nfs01 ~]# id www
uid=1000(www) gid=1000(www) groups=1000(www)
3.4編寫NFS配置文件
[root@nfs01 ~]# cat /etc/exports
/data 172.16.1.0/24(rw,sync,all_squash,anonuid=1000,anongid=1000)
/data 共享目錄
172.16.1.0/24 允許掛載的網段
rw 讀寫權限
sync 數據同步寫入NFS服務端的硬盤
all_squash 所有用戶都做映射
anonuid=1000,anongid=1000 NFS客戶端的www用戶與NFS服務端的www用戶完全相同(企業中,不可能只用1臺web服務器,所以需要多臺web服務器同時掛載到同一個目錄,防止其中的某臺不能讀取或寫入數據)
3.5創建共享目錄
[root@nfs01 ~]# mkdir /data
[root@nfs01 ~]# chown -R www.www /data/
3.6啟動相關服務
[root@nfs01 ~]# systemctl start rpcbind.service 必須先啟動rpcbind服務
[root@nfs01 ~]# systemctl start nfs.service
3.7本地檢測
[root@nfs01 ~]# rpcinfo -p 172.16.1.31
program vers proto port service
100000 4 tcp 111 portmapper
100000 3 tcp 111 portmapper
100000 2 tcp 111 portmapper
100000 4 udp 111 portmapper
100000 3 udp 111 portmapper
100000 2 udp 111 portmapper
100024 1 udp 46849 status
100024 1 tcp 50012 status
100005 1 udp 20048 mountd
100005 1 tcp 20048 mountd
100005 2 udp 20048 mountd
100005 2 tcp 20048 mountd
100005 3 udp 20048 mountd
100005 3 tcp 20048 mountd
100003 3 tcp 2049 nfs
100003 4 tcp 2049 nfs
100227 3 tcp 2049 nfs_acl
100003 3 udp 2049 nfs
100003 4 udp 2049 nfs
100227 3 udp 2049 nfs_acl
100021 1 udp 48689 nlockmgr
100021 3 udp 48689 nlockmgr
100021 4 udp 48689 nlockmgr
100021 1 tcp 42653 nlockmgr
100021 3 tcp 42653 nlockmgr
100021 4 tcp 42653 nlockmgr
[root@nfs01 ~]# showmount -e 172.16.1.31
Export list for 172.16.1.31:
/data 172.16.1.0/24
4.客戶端部署NFS
4.1安裝NFS相關服務(不需啟動,只需要使用相關命令)
yum install -y nfs-utils rpcbind
4.2掛在目錄
mount -t nfs 172.16.1.31:/data /mnt (/mnt只是測試,工作中需要掛載站點的相關目錄)
CentOS 7部署NFS存儲服務器