NFS文件系统共享服务器实战
架设一台NFS服务器,并按照以下要求配置
准备
两台Linux虚拟机一台作为服务端server,一台作为客户端client
server IPV4:192.168.110.136/24 client IPV4:192.168.110.134/24
两台服务器都需要关闭防火墙和seLinux
服务端
[root@server ~]# systemctl stop firewalld
[root@server ~]# setenforce 0
[root@server ~]# getenforce
Permissive
客户端
[root@client ~]# systemctl stop firewalld
[root@client ~]# setenforce 0
[root@client ~]# getenforce
Permissive
服务端下载nfs-utils, rpcbind
[root@server ~]# yum install -y nfs-utils rpcbind
客户端下载nfs-utils
[root@client ~]# yum install -y nfs-utils
1、开放/nfs/shared目录,供所有用户查询资料
服务端 IPV4:192.168.110.136/24
[root@server ~]# mkdir -pv /nfs/shared #创建目录
mkdir: 已创建目录 '/nfs'
mkdir: 已创建目录 '/nfs/shared'
[root@server ~]# touch /nfs/shared/{1..5} #创建文件
[root@server ~]# cd /nfs/shared/
[root@server shared]# ll
总用量 0
-rw-r--r--. 1 root root 0 11月 8 23:32 1
-rw-r--r--. 1 root root 0 11月 8 23:32 2
-rw-r--r--. 1 root root 0 11月 8 23:32 3
-rw-r--r--. 1 root root 0 11月 8 23:32 4
-rw-r--r--. 1 root root 0 11月 8 23:32 5
[root@server shared]# cd
[root@server ~]# vim /etc/exports #定义NFS共享的配置文件/nfs/shared 192.168.110.134(ro,sync) # ro为只读,sync为数据会同步写入到硬盘中
[root@server ~]# systemctl start nfs-server #启动服务,也可以enable设置开机自启
[root@server ~]# exportfs -r #读取信息直接生效[root@server ~]# showmount -e #查看服务器端共享的目录
Export list for server:
/nfs/shared 192.168.110.134
客户端 IPV4:192.168.110.134/24
[root@client ~]# showmount -e 192.168.110.136 #查看服务器端共享的目录
Export list for 192.168.110.136:
/nfs/shared 192.168.110.134[root@client ~]# mkdir -pv /nfs/test #创建挂载目录
mkdir: 已创建目录 '/nfs'
mkdir: 已创建目录 '/nfs/test'[root@client ~]# mount -t nfs 192.168.110.136:/nfs/shared /nfs/test/ #挂载
[root@client ~]# cd /nfs/test/
[root@client test]# ll #查看
总用量 0
-rw-r--r--. 1 root root 0 11月 8 23:32 1
-rw-r--r--. 1 root root 0 11月 8 23:32 2
-rw-r--r--. 1 root root 0 11月 8 23:32 3
-rw-r--r--. 1 root root 0 11月 8 23:32 4
-rw-r--r--. 1 root root 0 11月 8 23:32 5
[root@client test]# touch 6
touch: 无法创建 '6': 只读文件系统
2、开放/nfs/upload目录,为192.168.110.0/24网段主机可以上传目录,并将所有用户及所属的组映射为nfs-upload,其UID和GID均为210
[root@server ~]# mkdir /nfs/upload/ -v #创建目录
mkdir: 已创建目录 '/nfs/upload/'[root@server ~]# touch /nfs/upload/{1..5}
[root@server ~]# vim /etc/exports #定义NFS共享的配置文件
/nfs/upload 192.168.110.0/24(rw,all_squash,anonuid=210,anongid=210)
# rw为可读写,all_squash:客户端所有用户创建文件时,客户端会将文件的用户 和组映射为匿名用户和组,anonuid=210,anongid=210将文件的用户和组映射为指定的UID和GID
[root@server ~]# exportfs -r
[root@server ~]# showmount -e
Export list for server:
/nfs/upload 192.168.110.0/24
[root@server ~]# useradd -r -u 210 nfs-upload
[root@server ~]# id nfs-upload
用户id=210(nfs-upload) 组id=210(nfs-ipload) 组=210(nfs-ipload)
[root@server upload]# chmod o+w /nfs/upload/ #赋权客户端
[root@client ~]# showmount -e 192.168.110.136
Export list for 192.168.110.136:
/nfs/upload 192.168.110.0/24
[root@client ~]# mount -t nfs 192.168.110.136:/nfs/upload /nfs/test2/
[root@client ~]# ll /nfs/test2/
总用量 0
-rw-r--r--. 1 root root 0 11月 9 00:15 1
-rw-r--r--. 1 root root 0 11月 9 00:15 2
-rw-r--r--. 1 root root 0 11月 9 00:15 3
-rw-r--r--. 1 root root 0 11月 9 00:15 4
-rw-r--r--. 1 root root 0 11月 9 00:15 5[root@client test2]# touch 6
[root@client test2]# ll
总用量 0
-rw-r--rw-. 1 root root 0 11月 9 00:15 1
-rw-r--rw-. 1 root root 0 11月 9 00:15 2
-rw-r--rw-. 1 root root 0 11月 9 00:15 3
-rw-r--rw-. 1 root root 0 11月 9 00:15 4
-rw-r--rw-. 1 root root 0 11月 9 00:15 5
-rw-r--r--. 1 nfs-upload nfs-ipload 0 11月 9 15:44 6
3、将/home/tom目录仅共享给192.168.110.136这台主机,并只有用户tom可以完全访问该目录
[root@server ~]# useradd tom
[root@server ~]# touch /home/tom/{1..5}
[root@server ~]# ll /home/tom/
总用量 0
-rw-r--r--. 1 root root 0 11月 9 15:48 1
-rw-r--r--. 1 root root 0 11月 9 15:48 2
-rw-r--r--. 1 root root 0 11月 9 15:48 3
-rw-r--r--. 1 root root 0 11月 9 15:48 4
-rw-r--r--. 1 root root 0 11月 9 15:48 5[root@server ~]# vim /etc/exports
/home/tom 192.168.110.134(rw)
[root@server ~]# chown tom /home/tom/[root@server ~]# chgrp tom /home/tom/
[root@server ~]# cd /home/
[root@server home]# ll
总用量 4
drwx------. 14 fox fox 4096 10月 22 14:09 fox
drwx------. 3 nfs-upload nfs-ipload 78 11月 9 00:21 nfs-upload
drwx------. 3 tom tom 123 11月 9 15:48 tom[root@server ~]# showmount -e
Export list for server:
/home/tom 192.168.110.134客户端
[root@client ~]# mount -t nfs 192.168.110.136:/home/tom /nfs/test/
[root@client ~]# ll /nfs/test
ls: 无法打开目录 '/nfs/test': 权限不够[root@client ~]# useradd tom
[root@client ~]# su - tom
[tom@client ~]$ ll /nfs/test/
总用量 0
-rw-r--r--. 1 root root 0 11月 9 15:48 1
-rw-r--r--. 1 root root 0 11月 9 15:48 2
-rw-r--r--. 1 root root 0 11月 9 15:48 3
-rw-r--r--. 1 root root 0 11月 9 15:48 4
-rw-r--r--. 1 root root 0 11月 9 15:48 5这里的的tom用户是指UID和GID都相同的用户
相关文章:

NFS文件系统共享服务器实战
架设一台NFS服务器,并按照以下要求配置 准备 两台Linux虚拟机一台作为服务端server,一台作为客户端client server IPV4:192.168.110.136/24 client IPV4:192.168.110.134/24 两台服务器都需要关闭防火墙和seLinux 服…...
CSS的概念和基本用法
CSS的作用: 页面美化和布局控制。 1.概念: Cascading Style Sheets 层叠样式表。 层叠:多个样式可以作用在同一个html的元素上,同时生效。 2.好处: (1).功能强大 (2).将内容展示和样式控制分离 * 降低耦合度…...

万字详解Java的三大特性:封装 | 继承 | 多态
前言:面向对象程序设计的三大特征就是:封装,继承,多态。在前文介绍了类和对象后,我们就可以继而学习什么是封装,怎么用类的子类来实现继承和多态 目录 一.面向对象的特性 1.封装性 2.继承性 3.多态性…...

TensorFlow学习笔记--(1)张量的随机生成
张量的生成 如何判断一个张量的维数:看张量的中括号有几层 0 1 2 :零维数列 [2 4 6] : 一维向量 [ [1 2 3] [4 5 6] ] : 二维数组 两行三列 第一行数据为 1 2 3 第二行数据为 4 5 6 以此类推 n维张量有n层中括号 tf.zeros(%指定一个张量的维数%) 生成一…...
如何防止IP和账户关联?
在当今信息时代,个人隐私安全变得尤为重要。保护个人IP地址和账户的隐私是防止隐私泄露、信息泄漏以及支付安全等问题的关键。VMLogin虚拟浏览器作为一种隐私工具,可以帮助您解决问题。本文将为您介绍如何使用它来保护隐私安全和防止IP和账户关联。 一、…...

进入网络安全行业有哪些大公司推荐
随着互联网的普及和数字化进程的加速,网络安全问题日益凸显。从个人信息的泄露到国家基础设施的被攻击,网络安全已经不再只是一个技术问题,而是关乎到每个人、每个企业和国家的核心利益。在这场没有硝烟的战争中,一些大公司凭借其…...

OpenHarmony 社区运营报告(2023 年 10 月)
● 截至 2023 年 10 月,OpenHarmony 社区共有 51 家共建单位,累计超过 6200 名贡献者产生 24.2 万多个 PR,2.3 万多个 Star,6.1 万多个 Fork,59 个 SIG。 ● OpenHarmony 4.0 版本如期而至,开发套件同步升级…...
Mybatis二级缓存源码整理
添加配置mybatis-plus.configuration.cache-enabledtrue在mapper.xml文件中添加cache标签<cache size"10240" eviction"LRU"/>同一个事务中二级缓存不生效,会使用一级缓存,因为事务未提交。 执行流程部分 Configuration创建…...
如何在 HarmonyOS 对数据库进行备份,恢复与加密
数据库备份与恢复 场景介绍 当应用在处理一项重要的操作,显然是不能被打断的。例如:写入多个表关联的事务。此时,每个表的写入都是单独的,但是表与表之间的事务关联性不能被分割。 如果操作的过程中出现问题,开发者可…...

js实现向上、向下、向左、向右无缝滚动
向左滚动 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" content"widthdevice-width, ini…...
6 Hive引擎集成Apache Paimon
更多Paimon数据湖内容请关注:https://edu.51cto.com/course/35051.html 在实际工作中,我们通查会使用Flink计算引擎去读写Paimon,但是在批处理场景中,更多的是使用Hive去读写Paimon,这样操作起来更加方便。 前面我们…...
发布版本自动化记录版本功能方法
# 安装commitizennpm install --save-dev commitizen# 初始化Conventional Commits规范适配器npx commitizen init cz-conventional-changelog --save-dev --save-exact最后一步,需要在package.json中添加一个script"scripts": {..., // 此处省略其它配置…...

Elastic Stack 8.11:引入一种新的强大查询语言 ES|QL
作者:Tyler Perkins, Ninoslav Miskovic, Gilad Gal, Teresa Soler, Shani Sagiv, Jason Burns Elastic Stack 8.11 引入了数据流生命周期、一种配置数据流保留和降采样(downsampling) 的简单方法(技术预览版)…...
wx:for-item wx:for-index wx:for-key
wx:for-item wx:for-item , 数组当前项的变量名,默认为 item 作用:使用 (当前项变量名.属性名) 取得属性值每一项 <view wx:for"{{array}}"><view>{{item.name item.age }}</view> </view>等同于 &…...
老师还不会评课?这里有你需要的解决方案
优点: 1.课件制作: 老师的PPT设计得很新颖,插入的音乐视频都非常贴合课堂内容,看得出老师非常用心地进行了设计。 2.教师素养:老师的语言丰富、朗读能力很出色、板书设计很工整。 3.教师风格: xx老师上课激情澎湃/非常有亲和力…...

Talk | 马里兰大学博士生吴曦旸:分布式多智能体强化学习在复杂交通轨迹规划中的应用
本期为TechBeat人工智能社区第545期线上Talk! 北京时间11月09日(周四)20:00,马里兰大学博士生—吴曦旸的Talk已准时在TechBeat人工智能社区开播! 他与大家分享的主题是: “分布式多智能体强化学习在复杂交通轨迹规划中的应用”,介…...

2023年下半年架构案例真题及答案
案例的考点: 大数据架构 Lambda架构和Kappa架构 jwt特点 数据持久层,Redis数据丢失,数据库读写分离方案 Hibernat架构 SysML七个关系,填需求图 大数据的必选题: 某网作为某电视台在互联网上的大型门户入口&#…...

Java必考面试题,谈谈你对 Spring AOP 的理解
大家好,我是伍六七。 今天我们来学习 Spring 框架中最重要的概念之一:AOP。 这是一个 Java 程序员必考的面试题,大家好好理解。我们开始正文。 AOP 的概念 Spring AOP 是 Java 程序员们面试经常被问到的一个问题,但 AOP&#…...
BERT和ChatGPT简单对比
OpenAI发布了第一个版本的GPT(Generative Pretrained Transformer)模型在2018年6月。 谷歌的BERT模型(Bidirectional Encoder Representations from Transformers)是在2018年10月发布的。 BERT和ChatGPT都是由人工智能研究实验室…...

又一重要合作,创邻科技华为云联营产品正式发布
近日,创邻科技旗下的“Galaxybase高性能图平台”正式入驻华为云云商店联营商品,创邻科技成为华为云在数据库与缓存领域的联营联运合作伙伴。通过联营联运模式,双方合作能够深入产品、生态、解决方案等多个领域,助力各行业用户数字…...
MySQL 隔离级别:脏读、幻读及不可重复读的原理与示例
一、MySQL 隔离级别 MySQL 提供了四种隔离级别,用于控制事务之间的并发访问以及数据的可见性,不同隔离级别对脏读、幻读、不可重复读这几种并发数据问题有着不同的处理方式,具体如下: 隔离级别脏读不可重复读幻读性能特点及锁机制读未提交(READ UNCOMMITTED)允许出现允许…...

React19源码系列之 事件插件系统
事件类别 事件类型 定义 文档 Event Event 接口表示在 EventTarget 上出现的事件。 Event - Web API | MDN UIEvent UIEvent 接口表示简单的用户界面事件。 UIEvent - Web API | MDN KeyboardEvent KeyboardEvent 对象描述了用户与键盘的交互。 KeyboardEvent - Web…...
Robots.txt 文件
什么是robots.txt? robots.txt 是一个位于网站根目录下的文本文件(如:https://example.com/robots.txt),它用于指导网络爬虫(如搜索引擎的蜘蛛程序)如何抓取该网站的内容。这个文件遵循 Robots…...

Spring数据访问模块设计
前面我们已经完成了IoC和web模块的设计,聪明的码友立马就知道了,该到数据访问模块了,要不就这俩玩个6啊,查库势在必行,至此,它来了。 一、核心设计理念 1、痛点在哪 应用离不开数据(数据库、No…...

分布式增量爬虫实现方案
之前我们在讨论的是分布式爬虫如何实现增量爬取。增量爬虫的目标是只爬取新产生或发生变化的页面,避免重复抓取,以节省资源和时间。 在分布式环境下,增量爬虫的实现需要考虑多个爬虫节点之间的协调和去重。 另一种思路:将增量判…...

算法笔记2
1.字符串拼接最好用StringBuilder,不用String 2.创建List<>类型的数组并创建内存 List arr[] new ArrayList[26]; Arrays.setAll(arr, i -> new ArrayList<>()); 3.去掉首尾空格...
Pinocchio 库详解及其在足式机器人上的应用
Pinocchio 库详解及其在足式机器人上的应用 Pinocchio (Pinocchio is not only a nose) 是一个开源的 C 库,专门用于快速计算机器人模型的正向运动学、逆向运动学、雅可比矩阵、动力学和动力学导数。它主要关注效率和准确性,并提供了一个通用的框架&…...
基于Java Swing的电子通讯录设计与实现:附系统托盘功能代码详解
JAVASQL电子通讯录带系统托盘 一、系统概述 本电子通讯录系统采用Java Swing开发桌面应用,结合SQLite数据库实现联系人管理功能,并集成系统托盘功能提升用户体验。系统支持联系人的增删改查、分组管理、搜索过滤等功能,同时可以最小化到系统…...

基于SpringBoot在线拍卖系统的设计和实现
摘 要 随着社会的发展,社会的各行各业都在利用信息化时代的优势。计算机的优势和普及使得各种信息系统的开发成为必需。 在线拍卖系统,主要的模块包括管理员;首页、个人中心、用户管理、商品类型管理、拍卖商品管理、历史竞拍管理、竞拍订单…...

抽象类和接口(全)
一、抽象类 1.概念:如果⼀个类中没有包含⾜够的信息来描绘⼀个具体的对象,这样的类就是抽象类。 像是没有实际⼯作的⽅法,我们可以把它设计成⼀个抽象⽅法,包含抽象⽅法的类我们称为抽象类。 2.语法 在Java中,⼀个类如果被 abs…...