CentOS7下Samba的安装与配置

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介:

一、Samba简介

    Samba是在Linux和UNIX系统上实现SMB协议的一个免费软件,由服务器及客户端程序构成。SMB(Server Messages Block,信息服务块)是一种在局域网上共享文件和打印机的一种通信协议,它为局域网内的不同计算机之间提供文件及打印机等资源的共享服务。SMB协议是客户机/服务器型协议,客户机通过该协议可以访问服务器上的共享文件系统、打印机及其他资源。通过设置“NetBIOS over TCP/IP”使得Samba不但能与局域网络主机分享资源,还能与全世界的电脑分享资源。

   Samba最大的功能就是可以用于Linux与windows系统直接的文件共享和打印共享,Samba既可以用于windows与Linux之间的文件共享,也可以用于Linux与Linux之间的资源共享。


二、关闭SELinux和防火墙

a、临时关闭(不用重启机器): 

1
2
# setenforce 0                       ##设置SELinux 成为permissive模式  (关闭SELinux)
# setenforce 1                       ##设置SELinux 成为enforcing模式     (开启SELinux)

    

b、修改配置文件需要重启机器:

1
# vi /etc/selinux/config

将SELINUX=enforcing 改为SELINUX=disabled(需重启机器)


c、可自己做策略开放相应端口,这里我直接关闭:

1
2
# systemctl status firewalld.service       ##查看防火墙状态
# systemctl stop firewalld.service         ##关闭防火墙


三、安装Samba服务


①直接yum安装

1
# yum install samba samba-client


②启动并查看Samba

1
2
# systemctl start smb nmb        ##注:NMB对客户端提供NetBIOS服务
# systemctl status smb nmb

wKiom1YIn3-z1Q_4AANaemQDXIs178.jpg


四、配置Samba服务

①配置

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
# vi /etc/samba/smb.conf
=================== Global Settings[全局选项] ==============================
[global]
#
workgroup = WORKGROUP                ##设定Samba Server所要加入的工作组或域
server string = Samba Server Version % v         ##设定注释,宏%v表示显示Samba的版本号
netbios name = zhi                 ##设置Samba Server的NetBIOS名称
 
map to guest = bad user              ##开启匿名访问
     
# ----------------- Logging Options [日志选项]-----------------------------
log  file  /var/log/samba/log .%m    ##设置日志文件存储位置及名称,宏%m(主机名),表示对每台                                      访问Samba Server的机器都单独记录一个日志文件
max log size = 50              ##设置Samba Server日志文件的最大容量,单位为KB,0代表不限制
# ---------------- Standalone Server Options[独立运行进程] ---------------------
security = share             ##共享级别:共享目录只能被授权的用户访问
passdb backend = tdbsam      ##建立安全账户管理数据库
# ----------------- Printing Options[打印选项]-----------------------------
#        load printers = yes          ##设置是否在启动Samba时共享打印机
#        cups options = raw           ##通用unix打印选项
#================== Share Definitions[共享参数] ==============================
  
[homes]                               ##设置用户宿主目录
         comment = Home Directories         ##描述该共享:家目录
         browseable = no                ##指定该共享是否可以浏览
         writable =  yes                   ##指定该共享路径是否可写
[printers]                           ##设置打印机宿主目录
         comment = All Printers          ##描述:所有打印机
         path =  /var/spool/samba        
         browseable = no
         guest ok = no                  ##指定该共享是否允许guest账户访问
         writable = no
         printable =  yes               ##指定是否可打印
[public]
         comment = Public Stuff       ##定义说明信息
         path =  /home/samba           ##共享目录路径
         public =  yes              ##指定该共享是否允许guest账户访问
         writable =  yes
         printable = no
         write list = +staff        ##允许写入该共享的用户

注:

1
2
3
+ =====》 只在本机的密码文件组中查找
& =====》只在nis服务中查找
@ =====》先通过NIS服务器查找,nis找不到再到本机查找


②测试语法

wKioL1YI4fbgDrxLAAEBy7DUqtQ703.jpg


③建立共享目录

1
2
3
# mkdir /home/samba
# cd /home/samba/
# touch samba.txt


五、测试

①在windows下输入\\192.168.10.128访问


wKiom1YI5lTi_lCoAACChSW6aCY629.jpg

②在Linux下输入smbclient //192.168.10.128/public访问

wKioL1YI57bhMCTCAADxzgkftL4653.jpg


③配置只允许个别用户访问

a、配置smb.conf,添加如下

1
2
3
4
5
6
7
8
[ time ]
         comment = Ashes Of Time
         path =  /share/time
         valid  users  = zhi
         write list = zhi
         printable = no
         create mask = 0755
         directory mask = 0755


b、建立共享目录、添加相应用户和组

1
2
3
4
5
6
# mkdir -p /share/time
# groupadd admin
# useradd zhi -s /sbin/nologin
# cd /share/time
# echo "12345" > abc.txt
# pdbedit -a -u zhi              ##新建Samba用户

wKiom1YI7JvT4mbKAAIhYBiBXdc292.jpg

1
2
# pdbedit -L               ##查看Samba用户列表
# systemctl restart smb nmb        ##重启Samba

注: 可使用命令smbpasswd -a + 用户名为该用户添加Samba密码,但用户必须是系统用户。


c、验证

windows客户端验证:

在"这台电脑"右键,"映射网络驱动器"

wKiom1YI8d_Bio2gAAFk5kqC_8o458.jpg

提示输入用户名密码

wKiom1YI8cyzPJw_AADMSDHvQQU635.jpg

输入后

wKioL1YI8wixQr7TAACsEWcAHBk300.jpg并会在这台电脑上显示

wKiom1YI80TimjrUAABGkMT6gPM738.jpg

错误:输入用户名、密码后弹出如下内容:

“指定的网络文件夹目前是以其他用户名和密码进行映射的。要用其他用户名和密码进行连接,首先请断开所有现有的连接到网络共享的映射。”

解决:使用命令net use查看

wKiom1YI9F3iqeLUAACmj0IRDHA309.jpg

然后使用命令net use * /delete结束所有连接,即可连接。

wKioL1YI9OGClvzhAACCAuA3fLM961.jpg


Linux客户端验证:

1
$  smbclient -L 192.168.10.128 -U zhi

wKiom1YI9k-xXJqlAAFd9-LDnAg333.jpg

1
$ smbclient  //192 .168.10.128 /time  -U zhi

wKiom1YI9z7AiwGLAADpN0KOoaw457.jpg

问题:能下载不能上传

wKiom1YI-xbzYRYIAACaKrbFdHE575.jpg

解决:

1
# setfacl -m u:zhi:rwx /share/time/      ##赋予用户写权限

wKiom1YI_XvBke0xAAEeBG8q_5I064.jpg

已经可以上传了


Linux进行挂载

1
2
3
sudo  apt-get  install  cifs-utils      ##网络文件共享系统套件
sudo  mkdir  /mnt/samba
sudo  mount  -t cifs  //192 .168.10.128 /time  /mnt/samba  -o username=zhi

wKioL1YJAUOAm2OqAAB6SKUrRgw012.jpg


Linux实现自动挂载

1
2
3
4
5
6
7
8
9
sudo  vi  /etc/fstab      ##添加如下
//192 .168.10.128 /time      /mnt/samba    cifs   credentials= /etc/samba/zhi . passwd  0 0
sudo  vi  /etc/samba/zhi . passwd          ##防止密码泄露,所以另建文件
username=zhi
password=abcdef
sudo  chmod  og=---  /etc/samba/zhi . passwd           ##设置该密码文件权限
sudo  umount  /mnt/samba                      ##卸载
sudo  mount  -a                        ##挂载fstab下的所有选项
ls  /mnt/samba/


附:Ubuntu下安装配置Samba的wiki:




本文转自  结束的伤感  51CTO博客,原文链接:http://blog.51cto.com/wangzhijian/1698879

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
1月前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第16天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括配置系统源、安装 SQL Server 2019 软件包以及数据库初始化,确保 SQL Server 正常运行。
|
1月前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第8天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统准备、配置安装源、安装 SQL Server 软件包、运行安装程序、初始化数据库以及配置远程连接。通过这些步骤,您可以顺利地在 CentOS 系统上部署和使用 SQL Server 2019。
|
1月前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第7天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统要求检查与准备、配置安装源、安装 SQL Server 2019、配置 SQL Server 以及数据库初始化(可选)。通过这些步骤,你可以成功安装并初步配置 SQL Server 2019,进行简单的数据库操作。
|
2月前
|
Linux 网络安全 数据安全/隐私保护
Linux系统之Centos7安装cockpit图形管理界面
【10月更文挑战第12天】Linux系统之Centos7安装cockpit图形管理界面
117 1
Linux系统之Centos7安装cockpit图形管理界面
|
1月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。通过具体案例,读者可以了解如何准备环境、下载源码、编译安装、配置服务及登录 MySQL。编译源码安装虽然复杂,但提供了更高的定制性和灵活性,适用于需要高度定制的场景。
120 3
|
1月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。
本文介绍了在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。内容涵盖准备工作、下载源码、编译安装、配置服务、登录设置及实践心得,帮助读者根据需求选择最适合的安装方法。
98 2
|
1月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
166 2
|
2月前
|
Linux 知识图谱
Centos7安装killall,fuser, killall,pstree和pstree.x11
通过上述步骤,您已在CentOS 7系统中成功部署了killall、fuser、pstree以及pstree.x11,为高效管理系统进程打下了坚实基础。更多关于服务器管理与优化的知识,获取全面技术支持与解决方案。
96 1
|
2月前
|
监控 安全 Linux
CentOS7下安装配置ntp服务的方法教程
通过以上步骤,您不仅能在CentOS 7系统中成功部署NTP服务,还能确保其配置合理、运行稳定,为系统时间的精确性提供保障。欲了解更多高级配置或遇到特定问题,提供了丰富的服务器管理和优化资源,可作为进一步学习和求助的平台。
191 1
|
1月前
|
存储 安全 Linux
VMware安装CentOS7
【11月更文挑战第11天】本文详细介绍了在 VMware 中安装 CentOS 7 的步骤,包括准备工作、创建虚拟机、配置虚拟机硬件和安装 CentOS 7。具体步骤涵盖下载 CentOS 7 镜像文件、安装 VMware 软件、创建和配置虚拟机硬件、启动虚拟机并进行安装设置,最终完成 CentOS 7 的安装。在安装过程中,需注意合理设置磁盘分区、软件选择和网络配置,以确保系统的性能和功能满足需求。
226 0