Linux下的samba服务配置详解

在这里插入图片描述

一、Samba介绍

1.1 Samba简介

1.SMB(Server Messages Block,信息服务块)是一种在局域网上共享文件和打印机的一种通信协议,它为局域网内的不同计算机之间提供文件及打印机等资源的共享服务。
2.Samba是在Linux和UNIX系统上实现SMB协议的一个免费软件,由服务器及客户端程序构成。

1.2 CIFS和NFS简介

1.CIFS:common internet file system,微软基于SMB发布。
2.NFS:网络文件系统,英文Network File System(NFS),是由SUN公司研制的UNIX表示层协议(presentation layer protocol),能使使用者访问网络上别处的文件就像在使用自己的计算机一样。

二、Samba工具及特性

2.1 Samba相关包

①samba 提供smb服务
②samba-client 客户端软件
③samba-common 通用软件
④cifs-utils smb客户端工具
⑤samba-winbind 和AD相关

2.2 Samba相关服务进程

smbd 提供smb(cifs)服务 TCP:139,445
nmbd NetBIOS名称解析 UDP:137,138

2.3 相关工具及命令

  • 主配置文件:
/etc/samba/smb.conf 
  • 语法检查:

 testparm  [-v]  [/etc/samba/smb.conf]
  • 客户端工具:s
mbclient,pdbedit -L(列出Samba用户列表,读取passdb.tdb数据库文件)

三、搭建环境介绍

1.使用操作系统为RHEL8.0
2.Samba用户为三个(kitty,buer,alice),都可以浏览共享目录/share/,kitty和buer可以写入文件共享目录。
3.服务端hostname为control,客户端hostname为node1

四、Samba配置步骤

4.1 服务端操作

①在server端安装软件包

[root@control ~]# yum -y install samba samba-client
Updating Subscription Management repositories.
Unable to read consumer identity
This system is not registered to Red Hat Subscription Management. You can use subscription-manager to register.
Last metadata expiration check: 0:00:36 ago on Sun 02 May 2021 08:10:41 PM CST.
Dependencies resolved.
================================================================================================================================================
 Package                                   Arch                          Version                            Repository                     Size
================================================================================================================================================
Installing:
 samba                                     x86_64                        4.9.1-8.el8                        BaseOS                        708 k
 samba-client                              x86_64                        4.9.1-8.el8                        BaseOS                        636 k
Installing dependencies:
 samba-common-tools                        x86_64                        4.9.1-8.el8                        BaseOS                        461 k
 samba-libs                                x86_64                        4.9.1-8.el8                        BaseOS                        177 k

Transaction Summary
================================================================================================================================================
Install  4 Packages

Total size: 1.9 M
Installed size: 5.6 M
Downloading Packages:
Running transaction check
Transaction check succeeded.
Running transaction test
Transaction test succeeded.
Running transaction
  Preparing        :                                                                                                                        1/1 
  Installing       : samba-libs-4.9.1-8.el8.x86_64                                                                                          1/4 
  Running scriptlet: samba-libs-4.9.1-8.el8.x86_64                                                                                          1/4 
  Installing       : samba-common-tools-4.9.1-8.el8.x86_64                                                                                  2/4 
  Installing       : samba-4.9.1-8.el8.x86_64                                                                                               3/4 
  Running scriptlet: samba-4.9.1-8.el8.x86_64                                                                                               3/4 
  Installing       : samba-client-4.9.1-8.el8.x86_64                                                                                        4/4 
  Running scriptlet: samba-client-4.9.1-8.el8.x86_64                                                                                        4/4 
  Verifying        : samba-4.9.1-8.el8.x86_64                                                                                               1/4 
  Verifying        : samba-client-4.9.1-8.el8.x86_64                                                                                        2/4 
  Verifying        : samba-common-tools-4.9.1-8.el8.x86_64                                                                                  3/4 
  Verifying        : samba-libs-4.9.1-8.el8.x86_64                                                                                          4/4 
Installed products updated.

Installed:
  samba-4.9.1-8.el8.x86_64     samba-client-4.9.1-8.el8.x86_64     samba-common-tools-4.9.1-8.el8.x86_64     samba-libs-4.9.1-8.el8.x86_64    

Complete!

②创建samba共享目录/share,设置权限,并拷贝文件到共享目录

[root@control ~]# mkdir /share
[root@control ~]# ll /share
total 0
[root@control ~]# ll -ld /share
drwxr-xr-x. 2 root root 6 May  2 20:24 /share
[root@control ~]# chmod 777 /share
[root@control ~]# ll -ld /share
drwxrwxrwx. 2 root root 6 May  2 20:24 /share

[root@control ~]# cp /etc/passwd /share
[root@control ~]# cp /etc/group /share
[root@control ~]# ls /share
group  passwd


③创建samba用户

[root@control ~]# groupadd it
[root@control ~]# useradd -g it kitty
[root@control ~]# useradd alice
[root@control ~]# useradd buer
[root@control ~]# smbpasswd -a kitty
New SMB password:
Retype new SMB password:
Added user kitty.
[root@control ~]# smbpasswd -a alice
New SMB password:
Retype new SMB password:
Added user alice.
[root@control ~]# smbpasswd -a buer
New SMB password:
Retype new SMB password:
Added user buer.

#查看samba用户列表
[root@control ~]# pdbedit -L
kitty:2034:
buer:2036:
alice:2035:

④编辑samba主配置文件
进入配置目录/etc/samba/smb.conf

[share]
      path = /share
      browseable = yes
      write list = @it,buer
      hosts allow = 192.168.200.0/24

测试配置文件语法

[root@control ~]# testparm /etc/samba/smb.conf
Load smb config files from /etc/samba/smb.conf
rlimit_max: increasing rlimit_max (1024) to minimum Windows limit (16384)
Processing section "[homes]"
Processing section "[printers]"
Processing section "[print$]"
Processing section "[share]"
Loaded services file OK.
Server role: ROLE_STANDALONE

Press enter to see a dump of your service definitions

# Global parameters
[global]
	printcap name = cups
	security = USER
	workgroup = SAMBA
	idmap config * : backend = tdb
	cups options = raw


[homes]
	browseable = No
	comment = Home Directories
	inherit acls = Yes
	read only = No
	valid users = %S %D%w%S


[printers]
	browseable = No
	comment = All Printers
	create mask = 0600
	path = /var/tmp
	printable = Yes


[print$]
	comment = Printer Drivers
	create mask = 0664
	directory mask = 0775
	force group = @printadmin
	path = /var/lib/samba/drivers
	write list = @printadmin root


[share]
	hosts allow = 192.168.200.0/24
	path = /share
	write list = @it buer

⑤启动samba服务

[root@control ~]# systemctl start smb
[root@control ~]# systemctl start nmb
[root@control ~]# systemctl enable nmb
Created symlink /etc/systemd/system/multi-user.target.wants/nmb.service → /usr/lib/systemd/system/nmb.service.
[root@control ~]# systemctl enable smb
Created symlink /etc/systemd/system/multi-user.target.wants/smb.service → /usr/lib/systemd/system/smb.service.

⑥防火墙放行服务

[root@control ~]# firewall-cmd --permanent --add-service=samba
success
[root@control ~]# firewall-cmd --reload 
success

⑦配置selinux安全标签

[root@control ~]# semanage fcontext -a -t samba_share_t '/share(/.*)?'
[root@control ~]# restorecon
restorecon        restorecon_xattr  
[root@control ~]# restorecon -vvFR /share
Relabeled /share from unconfined_u:object_r:default_t:s0 to system_u:object_r:samba_share_t:s0
Relabeled /share/passwd from unconfined_u:object_r:default_t:s0 to system_u:object_r:samba_share_t:s0
Relabeled /share/group from unconfined_u:object_r:default_t:s0 to system_u:object_r:samba_share_t:s0

4.2 在客户端操作

①客户端安装相关软件包

[root@node1 yum.repos.d]# yum -y install samba-client cifs-utils
Updating Subscription Management repositories.
Unable to read consumer identity
This system is not registered to Red Hat Subscription Management. You can use subscription-manager to register.
Repository AppStream is listed more than once in the configuration
Repository BaseOS is listed more than once in the configuration
AppStream                                                                                                       3.1 MB/s | 3.2 kB     00:00    
BaseOS                                                                                                          2.7 MB/s | 2.7 kB     00:00    
ansiable                                                                                                        0.0  B/s |   0  B     00:00    
Failed to synchronize cache for repo 'ansiable', ignoring this repo.
Dependencies resolved.
================================================================================================================================================
 Package                              Arch                           Version                               Repository                      Size
================================================================================================================================================
Installing:
 cifs-utils                           x86_64                         6.8-2.el8                             BaseOS                          93 k
 samba-client                         x86_64                         4.9.1-8.el8                           BaseOS                         636 k

Transaction Summary
================================================================================================================================================
Install  2 Packages

Total size: 729 k
Installed size: 2.3 M
Downloading Packages:
Running transaction check
Transaction check succeeded.
Running transaction test
Transaction test succeeded.
Running transaction
  Preparing        :                                                                                                                        1/1 
  Installing       : samba-client-4.9.1-8.el8.x86_64                                                                                        1/2 
  Running scriptlet: samba-client-4.9.1-8.el8.x86_64                                                                                        1/2 
  Installing       : cifs-utils-6.8-2.el8.x86_64                                                                                            2/2 
  Running scriptlet: cifs-utils-6.8-2.el8.x86_64                                                                                            2/2 
  Verifying        : cifs-utils-6.8-2.el8.x86_64                                                                                            1/2 
  Verifying        : samba-client-4.9.1-8.el8.x86_64                                                                                        2/2 
Installed products updated.

Installed:
  cifs-utils-6.8-2.el8.x86_64                                          samba-client-4.9.1-8.el8.x86_64                                         

Complete!

②使用smbclient工具测试kitty和alice用户是否可以查看共享文件夹

[root@node1 yum.repos.d]# smbclient -L //192.168.200.150 -U kitty%redhat

	Sharename       Type      Comment
	---------       ----      -------
	print$          Disk      Printer Drivers
	share           Disk      
	IPC$            IPC       IPC Service (Samba 4.9.1)
	kitty           Disk      Home Directories
Reconnecting with SMB1 for workgroup listing.

	Server               Comment
	---------            -------

	Workgroup            Master
	---------            -------
	SAMBA                CONTROL
[root@node1 yum.repos.d]# smbclient -L //192.168.200.150 -U alice%redhat

	Sharename       Type      Comment
	---------       ----      -------
	print$          Disk      Printer Drivers
	share           Disk      
	IPC$            IPC       IPC Service (Samba 4.9.1)
	alice           Disk      Home Directories
Reconnecting with SMB1 for workgroup listing.

	Server               Comment
	---------            -------

	Workgroup            Master
	---------            -------
	SAMBA                CONTROL

③创建samba认证用户文件smbur,使用alice作为认证用户

[root@node1 yum.repos.d]# echo "username=alice" >> /etc/samba/smbur.txt
[root@node1 yum.repos.d]# echo "password=redhat" >> /etc/samba/smbur.txt

④编辑/etc/fstab文件,使挂载共享目录永久生效

[root@node1 yum.repos.d]# cat /etc/fstab 

#
# /etc/fstab
# Created by anaconda on Fri Mar 19 22:21:55 2021
#
# Accessible filesystems, by reference, are maintained under '/dev/disk/'.
# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info.
#
# After editing this file, run 'systemctl daemon-reload' to update systemd
# units generated from this file.
#
UUID=b7190d80-906f-4b9d-9ab4-5a503ecaea2c /                       xfs     defaults        0 0
UUID=525a30a7-d484-4ed5-9f38-f827f54e29ff /boot                   xfs     defaults        0 0
UUID=e6cf8733-5eec-4942-9429-c3e9087b6ff0 swap                    swap    defaults        0 0


//192.168.200.150/share /media cifs defaults,credentials=/etc/samba/smbur.txt,multiuser,sec=ntlmssp 0 0
[root@node1 yum.repos.d]# df -h
Filesystem               Size  Used Avail Use% Mounted on
devtmpfs                 970M     0  970M   0% /dev
tmpfs                    984M     0  984M   0% /dev/shm
tmpfs                    984M  9.1M  974M   1% /run
tmpfs                    984M     0  984M   0% /sys/fs/cgroup
/dev/nvme0n1p3            18G  4.0G   14G  23% /
/dev/nvme0n1p1           495M  140M  356M  29% /boot
tmpfs                    197M  4.0K  197M   1% /run/user/0
/dev/sr0                 6.7G  6.7G     0 100% /mnt/cdrom
//192.168.200.150/share   13G  8.5G  4.1G  68% /media

五、测试用户的权限情况

5.1 检查用户挂载权限

检查在/media目录下以alice用户挂载权限

[root@node1 yum.repos.d]# cd /media/
[root@node1 media]# touch file1
touch: cannot touch 'file1': Permission denied
[root@node1 media]# ls
group  passwd

5.2 切换本地admin用户

切换本地admin用户,以kitty和buer这两个samba用户访问测试权限

[root@node1 yum.repos.d]# cd /media/
[root@node1 media]# touch file1
touch: cannot touch 'file1': Permission denied
[root@node1 media]# ls
group  passwd
[root@node1 media]# useradd admin
[root@node1 media]# su - admin
[admin@node1 ~]$ cd /media
[admin@node1 media]$ cifscreds add -u kitty control
Password: 
[admin@node1 media]$ ls
group  passwd
[admin@node1 media]$ touch file1
[admin@node1 media]$ ls
file1  group  passwd
[admin@node1 media]$ cifscreds update  -u buer control
Password: 
[admin@node1 media]$ ls
file1  group  passwd
[admin@node1 media]$ touch file2
[admin@node1 media]$ ls
file1  file2  group  passwd
  • 7
    点赞
  • 57
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
### 回答1: 配置Samba服务器需要安装Samba软件包并编辑配置文件。 1. 安装Samba软件包:使用系统包管理器安装Samba,例如在Ubuntu/Debian系统中使用apt-get命令安装:sudo apt-get install samba 2. 编辑配置文件:sudo nano /etc/samba/smb.conf,修改共享文件夹的路径、用户名和密码。 3. 添加用户并设置密码:sudo smbpasswd -a 用户名 4. 重启Samba服务:sudo service smbd restart 5. 在客户端挂载共享文件夹:mount -t cifs //服务器IP地址/共享文件夹名称 挂载点 -o username=用户名,password=密码 以上步骤是配置Samba服务器的基本步骤,具体配置还需根据实际情况进行调整。 ### 回答2: Samba是一种为Linux系统配置服务器软件,它能够在Linux系统中分享文件和打印机。下面,将为大家介绍如何在Linux配置Samba服务器。 1.在Linux系统中安装Samba服务器 在Linux系统中安装Samba服务器非常简单。您可以使用以下命令在Linux系统中下载和安装Samba服务器: sudo apt-get update sudo apt-get install samba 2.创建共享目录 安装Samba服务器后,您需要创建共享目录。通过将目录设置为共享目录,可以轻松地在Linux系统中访问文件和打印机。 使用以下命令创建共享目录: sudo mkdir /samba/share 3.配置Samba配置Samba服务器,您需要编辑smb.conf文件。您可以使用以下命令编辑smb.conf文件: sudo nano /etc/samba/smb.conf 在smb.conf文件下,您可以设置Samba服务器的参数。其中,您需要指定您的共享目录名称、权限等信息。 在文件底部添加以下内容: [share] path = /samba/share available = yes valid users = user1, user2 read only = no browseable = yes 在这个例子中,将共享目录的名称设置为“share”,指定共享目录的路径为“/samba/share”,并指定可以访问共享目录的用户。 4.添加Samba用户 在配置Samba服务器时,您还需要添加Samba用户。您可以使用以下命令添加Samba用户: sudo smbpasswd -a user1 在这个例子中,添加的Samba用户为“user1”。 完成所有的步骤后,您可以重新启动Samba服务器,以确保您的配置已经生效: sudo service smbd restart 至此,Linux中的Samba服务配置完毕,您可以在其他计算机上通过网络访问共享目录和打印机,分享文件和打印机的过程变得非常简单。 ### 回答3: Samba是一种在Linux操作系统中使用的文件共享服务,它允许将Linux服务器上的文件和文件夹共享到Windows客户端上。接下来我们将讨论如何在Linux配置Samba服务器。 步骤一:安装Samba服务器 在Ubuntu、Debian、Fedora等Linux发行版上,安装Samba服务器非常简单,只需在终端输入以下命令即可: Ubuntu/Debian: sudo apt-get install samba Fedora: sudo dnf install samba 步骤二:配置Samba服务器 要配置Samba服务器,你需要编辑smb.conf文件,该文件包含了Samba服务器的所有配置信息。在大多数Linux发行版上,该文件位于/etc/samba目录下。 在编辑该文件之前,你可以先备份一份以防止出现问题。 sudo cp /etc/samba/smb.conf /etc/samba/smb.conf.bak 接着,需按照以下步骤进行配置: 1. 设置工作组名。 请确保服务器和客户端上共享文件的工作组名相同。找到smb.conf文件中的工作组部分,将其修改为: [global] workgroup = YOUR_WORKGROUP_NAME 2. 设置共享目录 在Samba服务器上,需要将想要共享的目录指定为一个共享(或称为共享名称),它相当于Windows上的“共享文件夹”。在[smb.conf]文件中,您可以通过添加以下行来配置共享名称: [share_name] comment = Share Description path = /path/to/share read only = no browseable = yes 变量说明: share_name:共享的名称,该名称将显示在Windows资源管理器中。 comment:该变量包含关于共享的注释。 path:该变量指定共享的完整路径。 read only:该变量用于设置共享是只读还是可写入,默认为只读。 browseable:该变量用于设置为是否允许在Windows资源管理器中浏览共享文件。 3. 创建Samba用户 与在Windows上一样,您需要添加Samba用户以控制用户对共享文件的访问级别。要创建Samba用户,请在终端中执行以下命令: sudo smbpasswd -a username 此命令将提示您输入新的Samba用户密码。 4. 重启Samba服务器 在更改完Samba配置文件后,您需要重启Samba服务器。 在终端中输入以下命令: sudo systemctl restart smbd 步骤三:测试Samba服务器 您可以使用Windows资源管理器或任何支持Samba协议的文件浏览器(如Nautilus或Thunar)访问共享文件。 打开任意一个文件浏览器,并在URL栏中输入以下内容: smb://server-ip/share_name (其中server-ip为Samba服务器的IP地址,share_name为共享名)。 输入用户名和密码以访问共享文件。 总结 以上是Samba服务器的基本配置,您可以根据需要调整其他Samba选项。Samba服务是一个非常方便的文件共享工具,它可以为Windows和Linux用户提供方便的文件共享体验。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

江湖有缘

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值