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

时间:2022-12-12 19:55:34

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

  • 作者简介:一名99年软件运维应届毕业生,正在自学云计算课程。
  • 宣言:人生就是B(birth)和D(death)之间的C(choise),做好每一个选择。
  • 创作不易,动动小手给个点赞加关注吧,有什么意见评论区告诉我,一起学习。 

文章目录

 前言

一、NFS简介

二、安装nfs-utils

三、NFS的特点

四、实验的步骤

1、服务端安装nfs-utils

2、创建共享目录

3、配置文件设置分享

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

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

6、查看存储端共享

 7、挂载

7.1、手动挂载

7.2、fstab自动挂载

7.3、强制卸载挂载

8、查看挂载

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

9.1、服务器创建内容

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

 SSH远程管理

1、查询SSH是否安装

2.启动服务

3、使用SSH远程管理

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

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

总结


 前言

        本篇文章介绍一下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输出是否正常

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

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服务器可用目录

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

 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上了。

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

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可以得到是远程了目标主机的。

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

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

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

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

 创建成功!!!


总结

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