两台linux之间实现共享文件夹挂载实例

一台linux服务器挂载另外一台linux服务器文件系统的方法。
目标:在客户端上访问服务端上指定的文件夹

服务端ip:192.168.1.1
客户端ip:192.168.1.2

服务端:

第一步:安装NFS和rpc。

[root@localhost ~]# yum install -y rpc-bind nfs-utils #安装nfs服务
[root@localhost ~]# yum install -y rpcbind #安装rpc服务

[root@localhost ~]# systemctl start rpcbind #先启动rpc服务
[root@localhost ~]# systemctl enable rpcbind #设置开机启动
[root@localhost ~]# systemctl start nfs-server #启动nfs服务
[root@localhost ~]# systemctl enable nfs-server
[root@localhost ~]# systemctl start nfs-secure-server #启动nfs安全传输服务(可能会报错,不过无所谓)
[root@localhost ~]# systemctl enable nfs-secure-server
[root@localhost /]# firewall-cmd --permanent --add-service=nfs #配置防火墙放行nfs服务(可能会报错,不过无所谓)
success
[root@localhost /]# firewall-cmd --reload
success

第二步:配置。
编辑/etc/exports,加入:
/public 192.168.1.2(rw) #IP是客户端的地址, 目录是要共享出的目录

[root@localhost /]# systemctl reload nfs
#重新加载NFS服务,使配置文件生效

客户端:

安装nfs-utils
yum install nfs-utils
可以挂载了
mount 192.168.1.1:/public /public2

进入客户端的/public2目录就可以看到服务端上的/public目录的内容了
这样就可以在客户端上像访问本地目录一样访问服务端的目录了

异常处理:

mount.nfs: access denied by server while mounting 10.9.*.15:/sharedata

原因可能是:
由于这个NFS的目录文件基本是临时文件,所以后来决定用tmpfs来内存化存储,以减少不必要的IO开销。
但发现用tmpfs初始化后,原来的NFS就不能同步了,后来试了各种方法,就是无法用NFS挂载tmpfs的目录。
也可能是:
服务端的盘是挂载的其他服务器的文件系统
解决:
找到服务端这个文件系统名字,可能是这样的:10.*..192:/ufs-v2rprm51,那么好办,直接使用下面语句挂载,
mount 10.*.
.192:/ufs-v2rprm51 /sharedata

### 如何在Ubuntu中配置和使用共享文件夹 #### 使用VirtualBox增强功能自动挂载共享文件夹 对于使用VirtualBox作为虚拟化平台的情况,为了使Windows主机上的文件夹能够在Ubuntu 20.04客户端上被访问,可以利用VirtualBox自带的共享文件夹特性。这需要先确保已安装了Guest Additions组件[^3]。 一旦完成了上述准备工作,则可以通过图形界面来定义要分享给Ubuntu使用的文件夹: - 打开VirtualBox管理器; - 选择对应的Ubuntu实例并点击“设置”选项; - 寻找名为“共享文件夹”的标签页; - 添加想要共享的新条目,并指定其所在路径以及名称;如果希望该文件夹能在每次启动时都自动连接至Linux端的话,记得勾选相应的复选框[^5]。 当一切设定完毕后,在Ubuntu内部应当可以在`/media/sf_<shared_folder_name>`找到新加入的内容。 #### 利用Samba服务构建跨操作系统间的高效资源共享机制 另一种方法是通过部署Samba服务器于Ubuntu之上,从而允许不同操作系统的计算机之间互相交换数据而不必依赖特定厂商提供的工具集。这种方式特别适合那些发现经由内置方式传输效率低下的场景——比如提到过的GCC编译过程变得异常缓慢的问题[^2]。 具体实施步骤如下所示: 1. **准备阶段** 更新软件包列表并获取最新版本的应用程序: ```bash sudo apt update && sudo apt upgrade -y ``` 2. **安装必要组件** 接下来就是按照提示依次执行下面两条命令完成Samba及其配套客户端的支持库安装工作: ```bash sudo apt install samba smbclient -y ``` 3. **创建用于共享目的之专用存储空间** 假设打算把个人文档放置在一个叫做`smbshare`的地方供其他设备读取写入,那么就依照下列指令建立起这样一个目录结构,并赋予适当权限以便任何人均可对其进行修改编辑: ```bash mkdir ~/smbshare/ sudo chmod 777 ~/smbshare/ ``` 4. **调整SMB配置参数以适应实际应用场景的需求** 编辑位于/etc/samba/smb.conf结尾处追加自定义规则段落,使得外部能够识别到刚刚设立好的资源点。例如: ```ini [my_shared_folder] path = /home/user/smbshare available = yes valid users = @users read only = no browsable = yes public = yes writable = yes ``` 5. **重启Samba守护进程让更改生效** 修改完成后保存退出编辑模式,随后发出信号通知后台正在运行的服务刷新缓存加载新的策略表单: ```bash sudo systemctl restart smbd.service ``` 此时此刻,无论是在局域网内的哪台机器上面都应该能顺利浏览到刚才所公布的公共区域了。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值