Ubuntu通过NFS实现文件共享

2024-05-26 19:58
文章标签 实现 ubuntu nfs 文件共享

本文主要是介绍Ubuntu通过NFS实现文件共享,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

搭建基础 NFS 服务

服务端(192.168.1.1)

# 安装 NFS Server 服务
sudo apt-get install nfs-kernel-server -y# 创建共享目录并设置权限
cd /data
mkdir -p share
chmod 777 share# 编辑配置文件(/data/share 为共享目录)
sudo vim /etc/exports/data/share *(insecure,rw,sync,no_root_squash)# 或者指定客户端 ip 为 192.168.1.2 才能挂载
#	/data/share 192.168.1.2(insecure,rw,sync,no_root_squash)# 开启 nfs 服务
sudo /etc/init.d/nfs-kernel-server start
# 或者
sudo service nfs-kernel-server start | restart | status###################################
# 			辅助命令
################################### 	
# 列出 服务器(192.168.1.1)上 nfs 服务的共享目录
showmount -e 192.168.1.1
showmount -e localhost# 将配置文件中的目录全部重新export一次!无需重启服务。 
sudo exportfs -rv# 查看 nfs 的运行状态
sudo nfsstat# 查看 nfs 是否启动(nfs 主端口是 2049)
rpcinfo -p

 

客户端(192.168.1.2)

# 安装 nfs-common 工具
sudo apt-get install nfs-common# 挂载远程目录
sudo mount 192.168.1.1:/data/share /data/share# 查看挂载盘信息
df -h    ###################################
# 			辅助命令
################################### 			
# 取消挂载
umount -l /data/share

 

问题排查

# 问题1 
# 执行
sudo mount 192.168.1.1:/data/share /data/share
# 报错
mount.nfs: access denied by server while mounting 192.168.1.1:/data/share
# 解决, 增加 insecure 选项
sudo vim /etc/exports/data/share *(rw,sync,no_root_squash)# 改为/data/share *(insecure,rw,sync,no_root_squash)
# 重启服务
sudo service nfs-kernel-server restart# 问题2
# 客户端开机没有共享文件夹
# 重启rpcbind
sudo /etc/init.d/rpcbind restart 
# 重启nfs
sudo /etc/init.d/nfs-kernel-server restart 
sudo mount 192.168.1.1:/data/share /data/share

 

附录

1. /etc/exports 文件中的 Host 格式

/etc/exports 文件的格式为:Directory Host(Options ...) Host(Options) #comment

其中的 Host 项用来指定可访问对应共享目录的主机,其格式可分为以下几种:

# 1. 单个主机, Host 项可以为一个或多个单独的 TCP/IP 主机名或 IP 地址
admin
admin.starky.net
192.168.56.101# 2. IP 子网
10.0.0.0/255.0.0.0  
172.16.0.0/255.255.0.0
192.168.56.0/24# 3. TCP/IP 域,  通过使用通配符,可以指定某个特定域中的全部或部分主机
*.starky.net
*craft.starky.net
???.starky.net# 4. NIS 组
可以指定某个 NIS 组中所有主机的访问权限,使用 @group 

 

2. /etc/exports 文件中的 Options

选项描述
ro只读权限
rw读写权限(默认)
rw=list通过 list 指定具有写权限的客户端主机,其他主机则为只读权限
root_squash将 UID 0 和 GID 0 映射到 anonuid 和 anongid(即 Ubuntu 系统中的 nobody 和 nogroup)
no_root_squash允许需要 root 权限的文件操作,有安全风险
all_squash将所有的 UID 和 GID 映射到它们的匿名形式,主要针对不信任的主机
anonuid=xxx指定客户端 root 权限的操作需要映射到的 UID(默认是65534)
anongid=xxx指定客户端 root 权限的操作需要映射到的 GID(默认是65534)
insecure允许通过任意端口的远程访问
async服务器可以在写入硬盘之前响应客户端的写入请求
wdelay通过延迟同步多个客户端对文件的更新
sec=flavor指定共享目录的安全验证方法,包括 sys(UNIX 验证),dh (DES),krb5ikrb5pnone(匿名访问)

 

3. NFS 挂载选项

选项描述
rw以读写模式挂载文件系统(rw 也需在服务端定义)
ro以只读模式挂载文件系统
bg如挂载失败(服务器无响应),在后台继续尝试并执行其他挂载请求
hard如果服务器无响应,重复发送请求直到服务器回复
soft如果服务器无响应,重复发送请求,超过一定时间后返回错误,而不会一直阻塞
intr允许用户中断阻塞的文件操作(并返回错误)
nointr不允许用户中断客户端的文件操作请求
retrans=n在 soft 模式下,指定返回错误前重复发送请求的次数
timeo=n设置超时后重复发送请求的时间间隔(单位 1/10 秒)
rsize=n设置读取 buffer 大小为 n bytes
wsize=n设置写入 buffer 大小为 n bytes
sec=flavor设置安全验证方法
proto=proto设置传输协议,NFSv4 必须为 TCP

 

4. /etc/exports示例
/var/nfs/gernel  192.168.56.0/24(rw,insecure,sync,no_subtree_check)
/var/nfs/public  *(ro,insecure,sync,no_subtree_check)
/home/starky 192.168.56.1(rw,insecure,no_root_squash,sync,no_subtree_check)
  • 第一条纪录表示 192.168.56.0/24 子网中的所有主机都可挂载 var/nfs/gernel 目录并拥有读写(rw)权限

  • 第二条纪录表示所有主机都可挂载 /var/nfs/public 目录且拥有只读ro)权限

  • 第三条纪录表示客户端 IP 地址为 192.168.56.1 的主机可以挂载 /home/starky 目录并拥有读写权限,而且任何 root 权限(UID=0 , GID=0)的文件操作都不默认映射给 nobody:nogroup,而保持属主(组)仍为 root(no_root_squash

  • insecure 选项:允许通过任意端口的远程访问

  • sync 选项:强制 NFS 服务器在响应请求之前将文件的改动写入磁盘(强调客户端和服务端文件内容的一致性,但会降低文件操作的效率)。

  • no_subtree_check 选项:禁用 subtree_check 。subtree_check 用来设置服务器在收到请求时,检查该文件是否在指定目录结构中依旧可用(该选项会在某些情况下发生错误:重命名某文件的同时,该文件在客户端打开)。

 

Ubuntu 设置开机自启动

方式1

# rc.local 脚本是一个 ubuntu 开机后(重启后)会自动执行的脚本
sudo vim /etc/rc.local

 

方式2

# 在 /etc/init.d 下新建脚本 auto-script
touch /etc/init.d/auto-script
# 编辑脚本内容
vim /etc/init.d/auto-script# 设置脚本权限
chmod 755 auto-script
# 将脚本添加到启动脚本
update-rc.d auto-script defaults 90# 移除开机脚本
update-rc.d -f auto-script remove

 

3. systemctl 方式

/etc/init.d/ 下新建脚本 auto-script 并编辑脚本内容后, 执行以下命令设置开启自启动

 systemctl enable auto-script# 或者systemctl enable auto-script.service

适用于Ubuntu 和 Centos

systemctl 命令

# 启动服务
systemctl start nginx.service# 停止服务
systemctl stop nginx.service# 重启服务
systemctl restart nginx.service# 查看服务状态
systemctl status nginx.service# 设置开机自启动
systemctl enable nginx.service# 停止开机自启动
systemctl disable nginx.service# 查看所有服务(包括启动失败的,已经启动的,退出运行的)
systemctl list-units --type=service

 

4. 查看开机启动项

systemd-analyze blame

 

参考

  • Ubuntu通过NFS实现文件共享(精简版)
  • Ubuntu 16.04 搭建 NFS 文件共享服务器

这篇关于Ubuntu通过NFS实现文件共享的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1005445

相关文章

AJAX请求上传下载进度监控实现方式

《AJAX请求上传下载进度监控实现方式》在日常Web开发中,AJAX(AsynchronousJavaScriptandXML)被广泛用于异步请求数据,而无需刷新整个页面,:本文主要介绍AJAX请... 目录1. 前言2. 基于XMLHttpRequest的进度监控2.1 基础版文件上传监控2.2 增强版多

Redis分片集群的实现

《Redis分片集群的实现》Redis分片集群是一种将Redis数据库分散到多个节点上的方式,以提供更高的性能和可伸缩性,本文主要介绍了Redis分片集群的实现,具有一定的参考价值,感兴趣的可以了解一... 目录1. Redis Cluster的核心概念哈希槽(Hash Slots)主从复制与故障转移2.

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

使用Python实现一键隐藏屏幕并锁定输入

《使用Python实现一键隐藏屏幕并锁定输入》本文主要介绍了使用Python编写一个一键隐藏屏幕并锁定输入的黑科技程序,能够在指定热键触发后立即遮挡屏幕,并禁止一切键盘鼠标输入,这样就再也不用担心自己... 目录1. 概述2. 功能亮点3.代码实现4.使用方法5. 展示效果6. 代码优化与拓展7. 总结1.

Mybatis 传参与排序模糊查询功能实现

《Mybatis传参与排序模糊查询功能实现》:本文主要介绍Mybatis传参与排序模糊查询功能实现,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、#{ }和${ }传参的区别二、排序三、like查询四、数据库连接池五、mysql 开发企业规范一、#{ }和${ }传参的

Docker镜像修改hosts及dockerfile修改hosts文件的实现方式

《Docker镜像修改hosts及dockerfile修改hosts文件的实现方式》:本文主要介绍Docker镜像修改hosts及dockerfile修改hosts文件的实现方式,具有很好的参考价... 目录docker镜像修改hosts及dockerfile修改hosts文件准备 dockerfile 文

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.

基于SpringBoot+Mybatis实现Mysql分表

《基于SpringBoot+Mybatis实现Mysql分表》这篇文章主要为大家详细介绍了基于SpringBoot+Mybatis实现Mysql分表的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录基本思路定义注解创建ThreadLocal创建拦截器业务处理基本思路1.根据创建时间字段按年进

SpringBoot3实现Gzip压缩优化的技术指南

《SpringBoot3实现Gzip压缩优化的技术指南》随着Web应用的用户量和数据量增加,网络带宽和页面加载速度逐渐成为瓶颈,为了减少数据传输量,提高用户体验,我们可以使用Gzip压缩HTTP响应,... 目录1、简述2、配置2.1 添加依赖2.2 配置 Gzip 压缩3、服务端应用4、前端应用4.1 N

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态