CentOS 6.7 安装配置nfs 服务

简介:

 

NFS Network File System的缩写,即网络文件系统。它功能是通过网络让不同的机器、不同的操作系统能够彼此分享各自的数据,让应用程序在客户端通过网络访问位于服务器磁盘中的数据。

 

NFS在文件传送或信息传送过程中依赖于RPC协议。RPC:远程过程调用(Remote Procedure Call) 是能使客户端执行其他系统中程序的一种机制。NFS本身是没有提供信息传输的协议和功能的,但NFS却能让我们通过网络进行资料的分享,这是因为NFS使用了一些其它的传输协议。而这些传输协议用到这个RPC功能的。可以说NFS本身就是使用RPC的一个程序。或者说NFS也是一个RPC SERVER。所以只要用到NFS的地方都要启动RPC服务,不论是NFS SERVER或者NFS CLIENT。这样SERVERCLIENT才能通过RPC来实现PROGRAM PORT的对应。可以这么理解RPCNFS的关系:NFS是一个文件系统,而RPC是负责信息的传输。

 

所以,我们需要安装两个软件包:nfs-utilsrpcbind,在centOS 5rpcbind portmap,作用都是一样的,名字不同而已。

 

安装方式:yum安装

nfs服务端:balichvm192.168.171.51

 

客户端:balichos192.168.171.50

 

安装步骤:

 

1)、在balichvm上安装nfs-utilsrpcbind,使用yum 安装,如下:

[root@balichvm ~]# yum install –y nfs-utilsrpcbind                                   

 

2)、在balichvm建立需要分享的目录和编辑配置文件/etc/exports(这个文件默认没有)

[root@balichvm ~]# mkdir –p /data/nfsdata

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

/data/nfsdata/  192.168.171.0/24 (rw,sync,root_squash)

 

这里的配置是共享目录/data/nfsdata/;网段192.168.171.0的主机可以有读写权限、限制root权限、同步到磁盘)

/etc/exports配置文件的格式和选项有:

格式:共享的目录         共享给那些网段的主机         共享的权限

 

选项:(共享的权限)

 

ro:——只读;

rw:——读写;

sync :——同步模式,内存中数据时时写入磁盘;

async :——不同步,把内存中数据定期写入磁盘中;

no_root_squash :——加上这个选项后,root用户就会对共享的目录拥有至高的权限控制,就像是对本机的目录操作一样。不安全,不建议使用;

root_squash:——和上面的选项对应,root用户对共享目录的权限不高,只有普通用户的权限,即限制了root

all_squash:——不管使用NFS的用户是谁,他的身份都会被限定成为一个指定的普通用户身份;

anonuid/anongid :——要和root_squash以及all_squash一同使用,用于指定使用NFS的用户限定后的uidgid,前提是本机的/etc/passwd中存在这个uidgid

 

3)、在balichvm配置防火墙规则,编辑/etc/sysconfig/nfs,固定服务的端口,默认是注释的,需要打开。

# Port rpc.mountd should listen on.

MOUNTD_PORT=892                             #把前面的#号去掉

 

# Port rquotad should listen on.

RQUOTAD_PORT=875                             #把前面的#号去掉

 

# TCP port rpc.lockd should listen on.

LOCKD_TCPPORT=32803                           #把前面的#号去掉

 

# UDP port rpc.lockd should listen on.

LOCKD_UDPPORT=32769                        #把前面的#号去掉

 

这些端口是配置文件默认的,是可以自行修改增加需要的端口号,然后保存配置文件。

 

然后启动rpdbind nfs 服务:

/etc/init.d/rpcbind restart

/etc/init.d/nfs restart

 

服务启动后,使用rpcinfo –p 查看启用的端口。

[root@balichvm ~]# rpcinfo -p

  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

   100005    1   udp   892  mountd

   100005    1   tcp   892  mountd

   100005    2   udp   892  mountd

   100005    2   tcp   892  mountd

   100005    3   udp   892  mountd

   100005    3   tcp   892  mountd

   100003    2   tcp  2049  nfs

   100003    3   tcp  2049  nfs

   100003    4   tcp  2049  nfs

   100227    2  tcp   2049  nfs_acl

   100227    3   tcp  2049  nfs_acl

   100003    2   udp  2049  nfs

   100003    3   udp  2049  nfs

   100003    4   udp  2049  nfs

   100227    2   udp  2049  nfs_acl

   100227    3   udp  2049  nfs_acl

   100021    1   udp 32769  nlockmgr

   100021    3   udp 32769  nlockmgr

   100021    4   udp 32769  nlockmgr

   100021    1   tcp 32803  nlockmgr

   100021    3   tcp 32803  nlockmgr

   100021    4   tcp 32803  nlockmgr

[root@balichvm ~]#

 

将这些启用的端口(tcpudp)写到iptables防火墙里面(vim /etc/sysconfig/iptables),允许通过,如下:

 

-A INPUT -m state --state NEW -m tcp -p tcp--dport 111 -j ACCEPT

-A INPUT -m state --state NEW -m tcp -p tcp--dport 892 -j ACCEPT

-A INPUT -m state --state NEW -m tcp -p tcp--dport 2049 -j ACCEPT

-A INPUT -m state --state NEW -m tcp -p tcp--dport 32769 -j ACCEPT

-A INPUT -m state --state NEW -m tcp -p tcp--dport 32803 -j ACCEPT

-A INPUT -m state --state NEW -m udp -p udp--dport 111 -j ACCEPT

-A INPUT -m state --state NEW -m udp -p udp--dport 892 -j ACCEPT

-A INPUT -m state --state NEW -m udp -p udp--dport 2049 -j ACCEPT

-A INPUT -m state --state NEW -m udp -p udp--dport 32769 -j ACCEPT

-A INPUT -m state --state NEW -m udp -p udp--dport 32803 -j ACCEPT

 

然后重启iptables服务:/etc/init.d/iptables restart

 

4)、在客户端balichos上,安装nfs-utils,并且挂载balichvm共享的nfsdata目录,查看某台主机共享的nfs使用命令showmount–e ip(主机名)

[root@balichOS ~]# yum install –y nfs-utils

[root@balichOS ~]# showmount -e192.168.171.51                          ##查看共享的nfs

Export list for 192.168.171.51:

/data/nfsdata 192.168.171.0/24

[root@balichOS ~]#

 

[root@balichOS ~]# mount -t nfs192.168.171.51:/data/nfsdata/ /mnt/

[root@balichOS ~]# df -h

Filesystem     Size      Used     Avail      Use%       Mountedon

/dev/sda3      18G      5.9G     11G        36%        /

tmpfs        495M     0      495M        0%         /dev/shm

/dev/sda1      190M    36M      145M        20%         /boot

192.168.171.51:/data/nfsdata/  18G  3.8G   13G    24%        /mnt

 

现在就已经挂载了一个文件系统,但是由于在balichvm/data/nfsdata的权限是755,其他用户不具备写的权限,而在nfs配置文件/etc/exports上又限定了root用户权限,默认是使用其他的用户的登录,所有无法写入数据,只有读取的权限。

如果需要有写入的权限,可以修改权限。

 



本文转自 巴利奇 51CTO博客,原文链接:http://blog.51cto.com/balich/1709934

相关文章
|
12天前
|
关系型数据库 MySQL Linux
CentOS 7系统下详细安装MySQL 5.7的步骤:包括密码配置、字符集配置、远程连接配置
以上就是在CentOS 7系统下安装MySQL 5.7的详细步骤。希望这个指南能帮助你顺利完成安装。
180 26
|
22天前
|
安全 Linux 网络安全
在Linux(CentOS和AWS)上安装更新的git2的方法并配置github-ssh
经过以上这些步骤,你现在就能在GitHub上顺利往返,如同海洋中的航海者自由驰骋。欢迎你加入码农的世界,享受这编程的乐趣吧!
52 10
|
3月前
|
Java
CentOS7.8配置Adoptium-Java17运行环境
本指南介绍如何设置清华镜像源并安装 Temurin-17-JRE 运行环境。首先,编辑 `/etc/yum.repos.d/adoptium.repo` 文件,配置清华镜像源。接着,使用 `yum install -y temurin-17-jre` 命令安装 Temurin-17-JRE,并通过 `java --version` 验证安装成功。相关配置和操作界面截图附后。
113 8
|
3月前
|
网络协议 Java 应用服务中间件
centos7环境下tomcat8的安装与配置
本文介绍了在Linux环境下安装和配置Tomcat 8的详细步骤。首先,通过无网络条件下的文件交互软件(如Xftp 6或MobaXterm)下载并解压Tomcat安装包至指定路径,启动Tomcat服务并测试访问。接着,修改Tomcat端口号以避免冲突,并部署Java Web应用项目至Tomcat服务器。最后,调整Linux防火墙规则,确保外部可以正常访问部署的应用。关键步骤包括关闭或配置防火墙、添加必要的端口规则,确保Tomcat服务稳定运行。
|
4月前
|
Ubuntu Unix Linux
Linux网络文件系统NFS:配置与管理指南
NFS 是 Linux 系统中常用的网络文件系统协议,通过配置和管理 NFS,可以实现跨网络的文件共享。本文详细介绍了 NFS 的安装、配置、管理和常见问题的解决方法,希望对您的工作有所帮助。通过正确配置和优化 NFS,可以显著提高文件共享的效率和安全性。
557 7
|
5月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
520 2
|
6月前
|
监控 安全 Linux
CentOS7下安装配置ntp服务的方法教程
通过以上步骤,您不仅能在CentOS 7系统中成功部署NTP服务,还能确保其配置合理、运行稳定,为系统时间的精确性提供保障。欲了解更多高级配置或遇到特定问题,提供了丰富的服务器管理和优化资源,可作为进一步学习和求助的平台。
622 1
|
6月前
|
Unix Linux 网络安全
NFS挂载服务
【10月更文挑战第14天】
224 2
|
6月前
|
Java jenkins 持续交付
Centos7下docker的jenkins下载并配置jdk与maven
通过上述步骤,您将成功在CentOS 7上的Docker容器中部署了Jenkins,并配置好了JDK与Maven,为持续集成和自动化构建打下了坚实基础。
346 1
|
6月前
|
存储 监控 Linux
在 CentOS 7 中如何对新硬盘进行分区、格式化、挂载及配置最佳实践
本文详细介绍了在 CentOS 7 中如何对新硬盘进行分区、格式化、挂载及配置最佳实践,包括使用 `fdisk` 创建分区、`mkfs` 格式化分区、创建挂载点、编辑 `/etc/fstab` 实现永久挂载等步骤,旨在有效管理服务器磁盘空间,提高系统稳定性和可维护性。
1184 1
下一篇
oss创建bucket