Linux巩固篇012-Linux NFS文件共享

简介: 纸上得来终觉浅,绝知此事要躬行

前言

身为一个三年的运维工程师,从开发转测开再转运维,都是不断学习的过程,未必开发才是最优秀的,找到适合自己的职业不断深耕,你也会在自己的行业大放光彩,本系列依照《Linux就该这么学》系列随书学习练习操作,将一些课本上不顺畅的地方,全部以最简方式免费开源展示给大家,资源大家可以自行百度,也希望大家多关注刘遄老师的第二版关于centos8的丛书,学习最前沿的Linux相关技术。

常用命令汇总

Samba 文件共享服务

Samba经过简单配置就能够实现 Linux 系统与 Windows 系统之间的文件 共享工作。

1.下载Samba

[root@www ~]# yum -y install samba

2.查看一下相关参数的解析

[root@www ~]# cat /etc/samba/smb.conf

image.png

去掉相关多余的#内容

[root@www ~]# mv /etc/samba/smb.conf /etc/samba/smb.conf.bak

[root@www ~]# cat /etc/samba/smb.conf.bak | grep -v "#" | grep -v ";" | grep -v "^$" > /etc/samba/smb.conf

[root@www ~]# cat /etc/samba/smb.conf

配置共享资源

将以下参数写入到 Samba 服务程序的主配置文件中

image.png

pdbedit 命令用于管理 SMB 服务程序的账户信息数据库,一下为其命令参数

image.png

1.创建用于访问共享资源的账户信息

[root@www ~]# id root1

uid=1000(root1) gid=1000(root1) groups=1000(root1)

[root@www ~]# pdbedit -a -u root1

new password:输入想要设置的密码

retype new password:再次输入想要设置的密码

Unix username:        root1

NT username:          

Account Flags:        [U          ]

User SID:             S-1-5-21-1706039710-2410730677-667020181-1000

Primary Group SID:    S-1-5-21-1706039710-2410730677-667020181-513

Full Name:            root1

Home Directory:       \\www\root1

HomeDir Drive:        

Logon Script:          

Profile Path:         \\www\root1\profile

Domain:               WWW

Account desc:          

Workstations:          

Munged dial:          

Logon time:           0

Logoff time:          Wed, 06 Feb 2036 07:06:39 PST

Kickoff time:         Wed, 06 Feb 2036 07:06:39 PST

Password last set:    Wed, 21 Jun 2023 01:18:30 PDT

Password can change:  Wed, 21 Jun 2023 01:18:30 PDT

Password must change: never

Last bad password   : 0

Bad password count  : 0

Logon hours         : FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF

2.创建用于共享资源的文件目录

[root@www ~]# mkdir /home/database

[root@www ~]# chown -Rf root1:root1 /home/database

3.在 Samba 服务程序的主配置文件中写入共享信息,删了直接把里边替换成如下内容

[root@www ~]# vi /etc/samba/smb.conf

[global]

workgroup = MYGROUP

server string = Samba Server Version %v

log file = /var/log/samba/log.%m

max log size = 50

security = user

passdb backend = tdbsam

load printers = yes

cups options = raw

[database]

comment = Do not arbitrarily modify the database file

path = /home/database

public = no

writable = yes

4.重启Samba服务程序

[root@www ~]# systemctl restart smb

[root@www ~]# systemctl enable smb

Created symlink from /etc/systemd/system/multi-user.target.wants/smb.service to /usr/lib/systemd/system/smb.service.

如果开了防火墙,可以加输入如下命令关闭

[root@www ~]# iptables -F

[root@www ~]# service iptables save

Windows 访问文件共享服务

Samba 共享服务部署在 Linux 系统上, 并通过 Windows 系统来访问 Samba 服务

录入\\192.168.227.130(虚拟机的IP地址)

image.png

此处录入的是上一部分设置的访问共享资源的账户密码

image.png

验证一下,在虚拟机上录入如下命令

[root@www ~]# cd /home/database

[root@www database]# touch a

在Windows客户端访问打开

image.png

Linux 访问文件共享服务

造一个客户端(新打开一台其他的linux客户端),录入以下命令

[root@bogon ~]# yum install cifs-utils

不挂载可以直接访问:

[root@bogon ~]# smbclient 192.168.227.130/home/database -U root1

挂载访问:

[root@bogon ~]# vim auth.smb

username=root1 #服务端创建的用户

password=123 #服务端对应的用户密码

domain=MYGROUP

[root@bogon ~]# chmod 600 auth.smb

[root@bogon ~]# mkdir /database

[root@bogon ~]#  vim /etc/fstab

添加以下内容

//192.168.227.130/database                  /database               cifs credentials=/root/auth.smb 0 0

[root@localhost database]#  mount -a

[root@localhost database]# cd /database/

[root@localhost database]# ll

total 0

-rw-r--r--. 1 root root 0 Jun 21 01:55 a

NFS(网络文件系统)

NFS(网络文件系统)服 务可以将远程 Linux 系统上的文件共享资源挂载到本地主机的目录上,从而使得本地主机 (Linux 客户端)基于 TCP/IP 协议,像使用本地主机上的资源那样读写远程 Linux 系统上的共 享文件。

1.下载NFS

[root@www ~]# yum install -y nfs-utils

2.关闭防火墙或者取消防火墙策略

iptables -F

service iptables save

3.NFS服务器上建立用于 NFS 文件共享的目录

[root@www ~]# mkdir /nfsfile

[root@www ~]# chmod -Rf 777 /nfsfile

[root@www ~]# echo "learn linux" > /nfsfile/readme

4.NFS配置文件

image.png

NFS 客户端地址与权限之间没有空格

[root@www ~]# vim /etc/exports

/nfsfile 192.168.227.*(rw,sync,root_squash)

5.重启服务

[root@www ~]# systemctl restart rpcbind

[root@www ~]# systemctl enable rpcbind

[root@www ~]# systemctl start nfs-server

[root@www ~]# systemctl enable nfs-server

Created symlink from /etc/systemd/system/multi-user.target.wants/nfs-server.service to /usr/lib/systemd/system/nfs-server.service.

6.客户端验证

showmount 命令

image.png

[root@localhost ~]# showmount -e 192.168.227.130

Export list for 192.168.227.130:

/nfsfile 192.168.227.*

[root@localhost ~]# mkdir /nfsfile

[root@localhost ~]# mount -t nfs 192.168.227.130:/nfsfile /nfsfile

[root@localhost ~]# cat /nfsfile/readme

learn linux

永久挂载

[root@localhost ~]# vim /etc/fstab

192.168.227.130:/nfsfile /nfsfile nfs defaults 0 0

autofs 自动挂载服务

autofs 自动挂载服务是一种Linux系统守护进程,当检测到用户视图访问一个尚未挂载的文件系统时,将自动挂载该文件系统(在客户端实现下部分命令)。

1.下载autofs

[root@www ~]# yum install -y autofs

2.配置autofs

[root@www ~]# vim /etc/auto.master

在第七行加入如下命令

/media /etc/iso.misc

[root@www ~]# vim /etc/iso.misc

iso -fstype=iso9660,ro,nosuid,nodev :/dev/cdrom

#光盘设备挂载到/media/iso 目录中,可将挂载目录写为 iso

#-ftype 为文件系统格式参 数

#iso9660 为光盘设备格式

#ro、nosuid 及 nodev 为光盘设备具体的权限参数

#/dev/cdrom要挂载的设备名称。

3.重启autofs

[root@www ~]# systemctl start autofs

[root@www ~]# systemctl enable autofs

Created symlink from /etc/systemd/system/multi-user.target.wants/autofs.service to /usr/lib/systemd/system/autofs.service.

4.验证

cd /media/iso

如果能看到相关目录即可验证成功

df -h会挂载上iso

这个我这环境已经调的不能再用了,并没有实现这一步,查了很多也没发现怎么改正,建议再空白环境试验此步骤。

结语

简问简答

1.实现 Linux 系统与 Windows 系统之间的文件共享,能否使用 NFS 服务?

答:不可以,应该使用 Samba 服务程序,NFS 服务仅能实现 Linux 系统之间的文件共享。

2.用于管理 Samba 服务程序的独立账户信息数据库的命令是什么?  

答:pdbedit 命令用于管理 Samba 服务程序的账户信息数据库。

3.简述在 Windows 系统中使用 Samba 服务程序来共享资源的方法。

答:在开始菜单的输入框中按照\\192.168.10.10 的格式输入访问命令并回车执行即可。在 Windows 的“运行”命令框中按照“\\192.168.10.10”的格式输入访问命令并按回车键即可。

4.简述在 Linux 系统中使用 Samba 服务程序来共享资源的步骤方法。

答:首先应创建密码认证文件以及挂载目录,然后把挂载信息写入到/etc/fstab 文件中,最后执行 mount -a 命令挂载使用。

5.如果在 Linux 系统中默认没有安装 NFS 服务程序,则需要安装什么软件包呢?

答:NFS 服务程序的软件包名字为 nfs-utils,因此执行 yum install nfs-utils 命令即可。

6.在使用 NFS 服务共享资源时,若希望无论 NFS 客户端使用什么帐户来访问共享资源,都 会被映射为本地匿名用户,则需要添加哪个参数。

答:需要添加 all_squash 参数,以便更好地保证服务器的安全。

7.客户端在查看到远程 NFS 服务器上的共享资源列表时,需要使用哪个命令?

答:使用 showmount 命令即可看到 NFS 服务器上的资源共享情况。

8.简述 autofs 服务程序的作用。

答:实现动态灵活的设备挂载操作,而且只有检测到用户试图访问一个尚未挂载的文件系 统时,才自动挂载该文件系统。

如果想根据教程实践的朋友们可以通过阿里云ecs服务器免费试用和低价购买,入口如下

入口一:新人免费试用

入口二:大学生免费试用

入口三:低价服务器购买

入口四:低价服务器购买2

入口五:建站特惠购买

目录
相关文章
|
8月前
|
Linux 开发工具
7种比较Linux中文本文件的最佳工具
7种比较Linux中文本文件的最佳工具
7种比较Linux中文本文件的最佳工具
|
6月前
|
存储 数据管理 Linux
区分Linux中.tar文件与.tar.gz文件的不同。
总之,".tar"文件提供了一种方便的文件整理方式,其归档但不压缩的特点适用于快速打包和解压,而".tar.gz"文件通过额外的压缩步骤,尽管处理时间更长,但可以减小文件尺寸,更适合于需要节约存储空间或进行文件传输的场景。用户在选择时应根据具体需求,考虑两种格式各自的优劣。
1038 13
|
7月前
|
安全 Linux
Linux赋予文件000权限的恢复技巧
以上这些步骤就像是打开一扇锁住的门,步骤看似简单,但是背后却有着严格的逻辑和规则。切记,在任何时候,变更文件权限都要考虑安全性,不要无谓地放宽权限,那样可能
230 16
|
8月前
|
Linux
【Linux】 Linux文件I/O常见操作技巧
以上就是Linux文件I/O操作的一些技巧,接纳它们,让它们成为你在Linux世界中的得力伙伴,工作会变得轻松许多。不过记住,技巧的运用也需要根据实际情况灵活掌握,毕竟,最适合的才是最好的。
264 28
|
7月前
|
存储 Linux 数据处理
深入剖析Linux中一切即文件的哲学和重定向的机制
在计算机的奇妙世界中,Linux的这套哲学和机制减少了不同类型资源的处理方式,简化了抽象的概念,并蕴藏着强大的灵活性。就像变戏法一样,轻轻松松地在文件、程序与设备之间转换数据流,标准输入、输出、错误流就在指尖舞动,程序的交互和数据处理因此变得既高效又富有乐趣。
126 4
|
8月前
|
Ubuntu Linux
"unzip"命令解析:Linux下如何处理压缩文件。
总的来说,`unzip`命令是Linux系统下一款实用而方便的ZIP格式文件处理工具。本文通过简明扼要的方式,详细介绍了在各类Linux发行版上安装 `unzip`的方法,以及如何使用 `unzip`命令进行解压、查看和测试ZIP文件。希望本文章能为用户带来实际帮助,提高日常操作的效率。
1749 12
|
9月前
|
Linux Shell
Linux系统下快速批量创建和删除文件的方法
总的来说,使用shell脚本来批量处理文件是一种非常强大的工具,只要你愿意花时间学习和实践,你会发现它能大大提高你的工作效率。
526 19
|
7月前
|
Linux
linux文件重命名命令
本指南介绍Linux文件重命名方法,包括单文件操作的`mv`命令和批量处理的`rename`命令。`mv`可简单更改文件名并保留扩展名,如`mv old_file.txt new_name.txt`;`rename`支持正则表达式,适用于复杂批量操作,如`rename 's/2023/2024/' *.log`。提供实用技巧如大小写转换、数字序列处理等,并提醒覆盖风险与版本差异,建议使用`-n`参数预览效果。
|
10月前
|
监控 Linux
Linux基础:文件和目录类命令分析。
总的来说,这些基础命令,像是Linux中藏匿的小矮人,每一次我们使用他们,他们就把我们的指令准确的传递给Linux,让我们的指令变为现实。所以,现在就开始你的Linux之旅,挥动你的命令之剑,探索这个充满神秘而又奇妙的世界吧!
191 19
|
9月前
|
缓存 Linux
如何创建Linux交换文件?Linux交换文件最新创建方法
Swap是Linux中的虚拟内存空间,用于在物理内存不足时将非活动进程移至磁盘,从而优化活动进程的性能。通过创建交换文件(如1GB),可灵活调整交换空间而无需重新分区。步骤包括:使用`fallocate`或`dd`创建文件、设置权限 (`chmod 600`)、格式化 (`mkswap`)、启用交换 (`swapon`)、修改`/etc/fstab`以持久化配置,以及调整`vm.swappiness`值(默认60,建议从10开始)来平衡内存与交换的使用。最后通过`swapon -s`检查状态并重启生效。此方法适用于VPS和专用服务器,需以root用户操作。
259 2