Linux文件服务NFS共享存储服务

本文涉及的产品
云防火墙,500元 1000GB
文件存储 NAS,50GB 3个月
简介: 本篇文章介绍一下NFS共享存储服务实验的步骤以及SSH远程服务的使用。

前言


 本篇文章介绍一下NFS共享存储服务实验的步骤以及SSH远程服务的使用。


一、NFS简介

 NFS(Network File System)网络文件系统,是Sun公司开发的,多用于Unix操作系统中,它是连 接在网络上的计算机之间共享文件的一种方法,使远程的文件使用如同使用本地文件一样没有什么区 别,更适合于字符命令方式完成网络之间的文件共享。Linux/Unix系统之间共享文件的一种协议NFS的客户端主要为Linux,支持多节点同时挂载以及并发写入,提供文件共享服务,为Web Server配置集群中的后端存储。

二、安装nfs-utils

 在centos7中需要先安装nfs-utils软件包来提供共享服务,用于NFS共享文件与访问。


[root@localhost ~]# rpm -q nfs-utils            //检查是否安装
[root@localhost ~]# yum -y install nfs-utils        //安装nfs-utils
[root@localhost ~]# systemctl start nfs-server        //启动服务
[root@localhost ~]# systemctl enable nfs-server      //开机自启


三、NFS的特点

●  不占本地工作站的磁盘空间   

●  通过同步写磁盘可以实现分布式处理功能   

●  利用字符命令方式,高性能,可灵活配置   

●  扩充新的资源或环境时不需要改变现有的工作环境

四、实验的步骤

1.服务端安装nfs-utils

2.创建共享目录

3.配置文件设置分享

4.启动服务

5.客户端安装nfs-utils

6.查看存储端共享

7.手动挂载

8.查看挂载

9.客户端验证共享目录的访问


1、服务端安装nfs-utils

[root@localhost ~]# rpm -q rpcbind nfs-utils     //查询是否安装
[root@localhost ~]# yum install -y nfs-utils      //安装nfs软件包

2、创建共享目录

[root@localhost ~]# mkdir -p /test/web       //创建文件夹作为待共享文件


3、配置文件设置分享

NFS的配置文件在/etc/exports,文件默认为空的,表示无任何共享。

在exports中配置共享文件格式为:共享文件位置    客户端IP(可以是一个网段)  (权限)。

例如:将服务器的/test/web文件共享给192.168.79.0/24网段,允许只读,配置如下

[root@localhost ~]# vim /etc/exports
/test/web   192.168.79.0/24  (ro)


●  ro:代表只读,o代表only

●  rw:代表读写


当文件需要共享给多个对象且分配不同的权限,只需要用空格隔开指定多个


4、关闭防火墙并启动服务

需要关闭防火墙以及Linux的防火墙,防止客户端无法访问,建议关闭开启自弃。

[root@localhost ~]# systemctl stop firewalld           //关闭防火墙
[root@localhost ~]# systemctl disable firewalld        //关闭防火墙开机自启
[root@localhost ~]# setenforce 0                        //关闭系统另一个防火墙   
[root@localhost ~]# vim /etc/selinux/config             //进入配置
SELINUX=disable                                            //关闭开机自启
[root@localhost ~]# systemctl start nfs-server                //启动nfs服务
[root@localhost ~]# systemctl enable  nfs-server            //设置开机自启
[root@localhost ~]# exportfs -v                        //检查NFS输出是否正常


4c001b6561c24efb983c8539ea3c2cc3.png


5、客户端安装nfs-utils并启动

客户端如果要访问服务器分享的文件,也需要在主机上安装nfs-utils软件包。

[root@localhost ~]# yum -y install nfs-utils          //安装nfs-utils
[root@localhost ~]# systemctl start nfs-server.service     //启动nfs-utils
[root@localhost ~]# systemctl enable  nfs-server.service     //设置开机自启


6、查看存储端共享

[root@localhost ~]# showmount -e 192.168.79.130     //查案NFS服务器可用目录


26a785846cb14c3cb9d25b6f6ff8e3ec.png


7、挂载


7.1、手动挂载

 我们需要挂载的是目录需要将整个目录挂载到本地目录上,如果web下有具体的文件也不可以直接挂载文件,挂载一定是挂载目录。


[root@localhost ~]# mount -t nfs 192.168.79.130:/test/web  /var/www/html


7.2、fstab自动挂载

修改/etc/fstab文件内容,加入NFS共享资源挂载设置文件系统格式为nfs。

/etc/fstab文件的每一行都遵循以下格式:

<device> <dir> <type> <options> <dump> <pass>


●  device:指定加载的磁盘分区或移动文件系统,除了指定设备文件外,也可以使用UUID、LABEL来指定分区;

●  dir:指定挂载点的路径;

●  type:指定文件系统的类型,包括ext2、ext3、reiserfs、nfs、vfat等

●  options:指定挂载的选项,默认为defaults,其他可用选项包括acl,noauto,ro等等;

●  dump:表示该挂载后的文件系统能否被dump备份命令作用;0表示不能,1表示每天都进行dump备份,2表示不定期进行dump操作。

●  pass:表示开机过程中是否校验扇区;0表示不要校验,1表示优先校验(一般为根目录),2表示为在1级别校验完后再进行校验;

[root@localhost ~]# vim /etc/fstab
192.168.79.130:/test/web  /var/www/html         nfs      defaults       0 0


7.3、强制卸载挂载

当服务器突然停止了nfs服务,这个时候客户端就会出现卡死的现象用普通的umount命令是无法卸载的。


[root@localhost ~]# umount -lf  /var/www/html


使用 umount 命令卸载,其中-l 选项表示解除正在繁忙的文件系统,-f 选项表示强制。


8、查看挂载

通过df命令来查看挂载情况,如下图所示,服务器下的/test/web已经被挂载到客户端主机的/var/www/html上了。

82445f5a68b34da28acccb1b1691f7c2.png


9、客户端验证共享目录的访问

首先在服务器创建一个文件,在文件中输入一些内容,这个时候客户端也同时可以访问该文件的内容。


9.1、服务器创建内容

[root@localhost ~]# echo "这里是nfs共享资源" >> /test/web/index.html     //编写内容到index文件


9.2、客户端查看共享文件内容

通过客户端来查看服务器的共享文件。


[root@localhost ~]# cat /var/www/html/index.html 
这里是nfs共享资源

SSH远程管理

 linux中ssh是“Secure Shell”的缩写,是建立在应用层和传输层基础上的一种安全协议,用于计算机之间的加密登录;ssh既可以远程联机服务器,又可以借助ssh协议来传输数据,提供更安全的SFTP服务。


1、查询SSH是否安装

[root@localhost ~]# rpm -qa | grep ssh            //查看是否安装ssh
openssh-clients-7.4p1-21.el7.x86_64
openssh-server-7.4p1-21.el7.x86_64
libssh2-1.8.0-4.el7.x86_64
openssh-7.4p1-21.el7.x86_64


如果没有安装使用命令:yum install openssh-server安装。


2.启动服务

[root@localhost ~]# systemctl start sshd    //启动服务
[root@localhost ~]# netstat -antp | grep sshd    //22端口提供SSH服务
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      980/sshd            
tcp6       0      0 :::22                   :::*                    LISTEN      980/sshd   
[root@localhost ~]# systemctl enable sshd    //开机自启


3、使用SSH远程管理


3.1、远程目标主机,并创建文件

[root@localhost ~]# ssh  root@192.168.79.128
The authenticity of host '192.168.79.128 (192.168.79.128)' can't be established.
ECDSA key fingerprint is SHA256:kkXlMjUlNdeXTvzRuJhng+yS34OH8Fi65CY7esfyr9g.
ECDSA key fingerprint is MD5:be:98:bf:4a:cd:d8:d5:48:62:b2:c2:e3:2c:9d:3a:d9.
Are you sure you want to continue connecting (yes/no)? yes
root@192.168.79.128's password:                             //这里输入目标用户的密码是秘闻输入
Last login: Mon Dec 12 15:04:30 2022 from 192.168.79.130
[root@localhost ~]# touch /test/130create            //创建一个文件
[root@localhost ~]# exit                            //退出登录
登出
Connection to 192.168.79.128 closed.


通过查看ip可以得到是远程了目标主机的。

89622468643340d79ddcfac724d97f25.png


3.2、使用目标主机查看文件是否创建成功

[root@localhost ~]# ls /test
130create  192.168.79.130  dir  log.txt  m  mountmsg  share.txt  tengine

a30ac94ea1a143fdbb75f31a018dcff5.png


创建成功!!!


总结


 通过本篇文章学习NFS共享文件的操作。

相关实践学习
基于ECS和NAS搭建个人网盘
本场景主要介绍如何基于ECS和NAS快速搭建个人网盘。
阿里云文件存储 NAS 使用教程
阿里云文件存储(Network Attached Storage,简称NAS)是面向阿里云ECS实例、HPC和Docker的文件存储服务,提供标准的文件访问协议,用户无需对现有应用做任何修改,即可使用具备无限容量及性能扩展、单一命名空间、多共享、高可靠和高可用等特性的分布式文件系统。 产品详情:https://www.aliyun.com/product/nas
相关文章
|
11天前
|
Linux 数据安全/隐私保护 Windows
命令方式:window向linux传文件
【10月更文挑战第6天】本文介绍了如何在Linux系统中通过命令`ip a`获取IP地址,并在Windows系统下使用CMD命令行工具和SCP命令实现文件传输。示例展示了如何将D盘中的`mm.jar`文件上传至IP地址为192.168.163.122的Linux系统的/up/目录下,最后在Linux系统中确认文件传输结果。
167 65
|
18天前
|
Linux Shell
Linux系统文件默认权限
Linux系统文件默认权限
34 2
|
10天前
|
Linux 开发工具 数据安全/隐私保护
linux异常一:feng 不在 sudoers 文件中,此事将被报告。yum提示Another app is currently holding the yum lock; waiting for
这篇文章介绍了在CentOS 7系统中安装Docker时遇到的两个常见问题及其解决方法:用户不在sudoers文件中导致权限不足,以及yum被锁定的问题。
23 2
linux异常一:feng 不在 sudoers 文件中,此事将被报告。yum提示Another app is currently holding the yum lock; waiting for
|
6天前
|
Linux Shell 数据库
Linux文件查找新姿势:总有一种你没见过
文件查找是Linux用户提升工作效率的关键技能。本文介绍了几种不常见的文件查找方法,包括使用`find`结合`column`美化输出、利用`locate`和`mlocate`快速查找、编写Shell脚本自动化任务、使用现代工具`fd`以及结合`grep`和`rg`进行内容搜索。此外,还推荐了几款图形界面搜索工具。掌握这些技巧,让你的文件查找更加高效便捷。
28 2
|
11天前
|
Ubuntu Linux 网络安全
Linux中服务管理问题
【10月更文挑战第4天】
11 2
|
13天前
|
Linux C++
Linux c/c++文件的基本操作
在Linux环境下使用C/C++进行文件的基本操作,包括文件的创建、写入、读取、关闭以及文件描述符的定位。
13 0
Linux c/c++文件的基本操作
|
18天前
|
移动开发 Linux
Linux 文件与目录管理
Linux 文件与目录管理
17 3
|
13天前
|
Linux C++
Linux c/c++文件虚拟内存映射
这篇文章介绍了在Linux环境下,如何使用虚拟内存映射技术来提高文件读写的速度,并通过C/C++代码示例展示了文件映射的整个流程。
30 0
|
13天前
|
Linux C++
Linux c/c++文件移动
这篇文章介绍了在Linux环境下,使用C/C++语言通过命令方式和文件操作方式实现文件移动的方法。
43 0
|
14天前
|
应用服务中间件 Linux Shell
Linux 配置 Nginx 服务的详细步骤,绝对干货
Linux 配置 Nginx 服务的详细步骤,绝对干货
43 0