CentOS 上配置 NFS 服务器和客户端

部署

要在 CentOS 上配置 NFS 服务器和客户端,你可以按照以下步骤进行操作:

配置 NFS 服务器:

  1. 安装 NFS 服务器软件包:

    sudo yum install nfs-utils
    
  2. 编辑 NFS 服务器配置文件 /etc/exports,添加要共享的目录和权限设置。例如,假设你要共享 /shared 目录给客户端 IP 地址为 192.168.1.100 的主机,可以在 /etc/exports 文件中添加以下行:

    /shared 192.168.1.100(rw,sync,no_root_squash)
    

    这将允许客户端以读写模式访问 /shared 目录,并同步写入到磁盘,同时保留客户端的 root 权限。

  3. 启动 NFS 服务器并设置开机自启动:

    sudo systemctl start nfs-server
    sudo systemctl enable nfs-server
    

配置 NFS 客户端:

  1. 安装 NFS 客户端软件包:

    sudo yum install nfs-utils
    
  2. 创建本地挂载点目录,用于挂载远程共享目录:

    sudo mkdir /mnt/nfs
    
  3. 挂载远程共享目录到本地挂载点:

    sudo mount <NFS服务器IP>:/shared /mnt/nfs
    

    <NFS服务器IP> 替换为实际的 NFS 服务器的 IP 地址。

  4. 验证挂载是否成功:

    df -h
    

    检查输出中是否显示了 /mnt/nfs 目录。

  5. 如果需要在系统启动时自动挂载 NFS 共享,可以编辑 /etc/fstab 文件并添加以下行:

    <NFS服务器IP>:/shared /mnt/nfs nfs defaults 0 0
    

    保存并退出编辑器。

现在,你的 CentOS 服务器已经配置为 NFS 服务器,并且客户端已经成功挂载了共享目录。你可以在客户端上通过 /mnt/nfs 目录访问和操作共享的文件。

错误处理

当在尝试挂载 NFS 共享时出现 “mount.nfs: access denied by server” 错误时,这通常表示服务器拒绝了客户端的访问请求。以下是可能导致此问题的一些原因和解决方法:

  1. 权限配置错误:检查 NFS 服务器上共享目录的权限设置。确保在 /etc/exports 文件中正确配置了共享目录的权限选项。例如,确保使用了 rw(读写权限)或 ro(只读权限)选项,并确保客户端的 IP 地址正确。

  2. 客户端 IP 地址错误:确保在 NFS 服务器的 /etc/exports 文件中正确指定了客户端的 IP 地址。检查客户端的 IP 地址,并确保与服务器配置的 IP 地址匹配。

  3. SELinux 或其他安全机制限制:如果服务器上启用了 SELinux 或其他安全机制,它们可能会限制 NFS 共享的访问。你可以尝试临时禁用 SELinux 来排除此问题:

    sudo setenforce 0
    

    如果问题解决,你可以考虑修改 SELinux 策略或配置以允许 NFS 共享的访问。

  4. 防火墙限制:检查服务器上的防火墙设置,确保允许 NFS 流量通过。确保服务器的防火墙允许传入的 NFS 相关端口(例如,端口 2049)。

  5. NFS 服务未重新加载:在更改了 NFS 服务器的配置文件 /etc/exports 后,需要重新加载 NFS 服务以使更改生效:

    sudo exportfs -r
    

请检查上述问题,并根据需要进行相应的调整。如果问题仍然存在,你可以查看服务器的日志文件(如 /var/log/messages/var/log/syslog)以获取更多详细的错误信息,以帮助确定问题的原因。

猜你喜欢

转载自blog.csdn.net/somken/article/details/132020753