Linux下部署Samba服务环境的操做记录

 

关于Linux和Windows系统之间的文件传输,不少人选择使用FTP,相对较安全,可是有时仍是会出现一些问题,好比上传文件时,文件名莫名出现乱码,文件大小改变等问题。相比较来讲,使用Samba做为文件共享,就省事简洁多了。Samba服务器通讯协议(Server Messages Block)就是是为了解决局域网内的文件或打印机等资源的共享服务问题,让多个主机之间共享文件变成愈来愈简单。下面简单介绍下,在Centos7下部署Samba服务的操做记录(测试机192.168.10.204):python

1)安装Sambalinux

[root@samba-server ~]# cat /etc/redhat-release 
CentOS Linux release 7.4.1708 (Core) 
[root@samba-server ~]# rpm -qa|grep samba
[root@samba-server ~]# yum install -y samba

2)安全角度考虑,须要设置防火墙策略(不要关闭防火墙)数据库

添加samba服务到防火墙策略中
[root@samba-server ~]# firewall-cmd --add-service samba --permanent
success
 
重启防火墙
[root@samba-server ~]# firewall-cmd --reload
success
 
查看samba服务是否添加到防火墙中:
[root@samba-server ~]# firewall-cmd --list-all|grep samba
  services: ssh dhcpv6-client samba
  
记住:必定要关闭selinux(不然会形成windows客户机链接Samba失败)
[root@samba-server ~]# vim /etc/sysconfig/selinux
.....
SELINUX=disabled

[root@samba-server kevin]# setenforce 0
[root@samba-server kevin]# getenforce 
Permissive

3)配置Samba服务文件vim

[root@samba-server ~]# cp /etc/samba/smb.conf /etc/samba/smb.conf.bak
[root@samba-server ~]# vim /etc/samba/smb.conf
# See smb.conf.example for a more detailed config file or
# read the smb.conf manpage.
# Run 'testparm' to verify the config is correct after
# you modified it.

[global]                                                   //全局配置
     workgroup = SAMBA
     security = user

     passdb backend = tdbsam

     printing = cups
     printcap name = cups
     load printers = yes
     cups options = raw

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

[printers]                                                 //共享打印机配置
     comment = All Printers
     path = /var/tmp
     printable = Yes
     create mask = 0600
     browseable = No

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

[kevin]                                                    //这个是共享文件夹标识,表示登陆samba打开时显示的文件夹名称。配置了多少个共享文件夹标识,登陆samba时就会显示多少文件夹。
       comment = please do not modify it all will          //comment是对该共享的描述,能够是任意字符串
       path= /home/kevin                                   //共享的路径
       writable = yes                                      //是否写入
       public = no                                         //是否公开

4)添加kevin帐号(如上配置中添加的内容)windows

设置为不予许登入系统,且用户的家目录为 /home/kevin(至关于虚拟帐号)的kevin帐号。
[root@samba-server ~]# useradd -d /home/kevin -s /sbin/nologin kevin

5)pdbedit 命令说明缓存

pdbedit 命令用于管理Samba服务的账户信息数据库,格式为:"pdbedit [选项] 账户"
第一次把用户信息写入到数据库时须要使用-a参数,之后修改用户密码、删除用户等等操做就再也不须要了。

pdbedit -L :查看samba用户
pdbedit -a -u user:添加samba用户
pdbedit -r -u user:修改samba用户信息
pdbedit -x -u user:删除samba用户

samba服务数据库的密码也能够用 smbpasswd 命令 操做
smbpasswd -a user:添加一个samba用户
smbpasswd -d user:禁用一个samba用户
smbpasswd -e user:恢复一个samba用户
smbpasswd -x user:删除一个samba用户

6)将kevin添加为samba用户安全

[root@samba-server ~]# id kevin
uid=1001(kevin) gid=1001(kevin) groups=1001(kevin)

[root@samba-server ~]# pdbedit -a -u kevin
new password:                              //设置kevin使用的samba帐号密码,好比123456
retype new password:                       //确认密码
Unix username:        kevin
NT username:          
Account Flags:        [U          ]
User SID:             S-1-5-21-33923925-2092173964-3757452328-1000
Primary Group SID:    S-1-5-21-33923925-2092173964-3757452328-513
Full Name:            
Home Directory:       \\samba-server\kevin
HomeDir Drive:        
Logon Script:         
Profile Path:         \\samba-server\kevin\profile
Domain:               SAMBA-SERVER
Account desc:         
Workstations:         
Munged dial:          
Logon time:           0
Logoff time:          Wed, 06 Feb 2036 23:06:39 CST
Kickoff time:         Wed, 06 Feb 2036 23:06:39 CST
Password last set:    Mon, 12 Mar 2018 18:07:58 CST
Password can change:  Mon, 12 Mar 2018 18:07:58 CST
Password must change: never
Last bad password   : 0
Bad password count  : 0
Logon hours         : FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF

接着修改samba用户的家目录权限
[root@samba-server ~]# chown -Rf kevin.kevin /home/kevin

7)启动Samba服务bash

[root@samba-server ~]# systemctl start smb
[root@samba-server ~]# systemctl enable smb
Created symlink from /etc/systemd/system/multi-user.target.wants/smb.service to /usr/lib/systemd/system/smb.service.
[root@samba-server ~]# systemctl restart smb
[root@samba-server ~]# systemctl status smb
● smb.service - Samba SMB Daemon
   Loaded: loaded (/usr/lib/systemd/system/smb.service; enabled; vendor preset: disabled)
   Active: active (running) since Mon 2018-03-12 18:11:20 CST; 3s ago
 Main PID: 977 (smbd)
   Status: "smbd: ready to serve connections..."
   CGroup: /system.slice/smb.service
           ├─977 /usr/sbin/smbd
           ├─978 /usr/sbin/smbd
           ├─979 /usr/sbin/smbd
           └─980 /usr/sbin/smbd

Mar 12 18:11:19 samba-server systemd[1]: Starting Samba SMB Daemon...
Mar 12 18:11:19 samba-server systemd[1]: smb.service: Supervising process 977 which is not our child. We'll most likely not... exits.
Mar 12 18:11:20 samba-server smbd[977]: [2018/03/12 18:11:20.065982,  0] ../lib/util/become_daemon.c:124(daemon_ready)
Mar 12 18:11:20 samba-server systemd[1]: Started Samba SMB Daemon.
Mar 12 18:11:20 samba-server smbd[977]:   STATUS=daemon 'smbd' finished starting up and ready to serve connections
Hint: Some lines were ellipsized, use -l to show in full.

8)开始测试
先往共享路径/home/kevin里添加点内容服务器

[root@samba-server kevin]# touch test1 test2 test3
[root@samba-server kevin]# mkdir a1 a2 a3
[root@samba-server kevin]# ls
a1  a2  a3  test1  test2  test3

接着再windos 客户机本地测试。”Win+E键"打开,在最上面的"网络"地址栏输入“\\192.168.10.204”,而后回车,输入上面设置的samba帐号kevin及其密码,就能共享到linux上的/home/kevin下的文件了网络

链接上后,就能够在windows和linux直接进行文件夹的共享操做了,可让里面放点测试文件

若是在windows客户机上链接Samba出现网络错误:Windows 没法访问\\192.168.10.204\kevin,解决办法以下:

查看上下文的安全关系
[root@samba-server ~]# semanage kevin -a -t samba_share_t /home/kevin/
-bash: semanage: command not found

若是系统出现上面的报错 ,说明你系统里没有安装 semanage命令,下面开始安装semanage:

[root@samba-server ~]# yum provides /usr/sbin/semanage
Loaded plugins: fastestmirror
Loading mirror speeds from cached hostfile
 * base: mirror.0x.sg
 * epel: mirror.dmmlabs.jp
 * extras: mirror.0x.sg
 * updates: mirror.0x.sg
policycoreutils-python-2.5-17.1.el7.x86_64 : SELinux policy core python utilities        //这个是安装包
Repo        : base
Matched from:
Filename    : 

[root@samba-server ~]# yum install -y policycoreutils-python

而后再执行一次,执行完成后,不要忘了刷新上下文关系
[root@samba-server ~]# semanage fcontext -a -t samba_share_t /home/kevin
[root@samba-server ~]# restorecon -Rv /home/kevin

容许SElinux对于SMB用户共享家目录的布尔值

重启Samba
[root@samba-server ~]# systemctl restart smb

如何在windows本机访问samba时用切换另外一个用户登陆

方法以下:
1)按键ctrl+r,打开"运行",输入"cmd"
2)输入命令"net use * /delete",接着输入"Y",即先取消全部的net 链接
3)输入切换帐号的命令"net use \\192.168.10.204\IPC$ grace@123 /user:grace",即表示切换到grace帐号(密码为grace@123)

重置samba帐号密码

[root@samba-server ~]# smbpasswd -a kevin     //即重置kevin密码

======================================================
清理windows下链接linux的samba服务缓存

在安装配置linux服务器samba服务之初,samba服务不免会通过屡次修改配置/重启,在期间win的系统或许早已链接上了samba。samba修改配置修改后,特别是用户权限,再次从win登陆就很容易出现因缓存的权限缘由致使不容许访问或者操做。
这时通常要等好久会清理缓存,另外重启win也会清理。但这效率很低。用如下手动的方法能够实时清理。

清理步骤:
1)打开win的命令行(ctrl+R,输入cmd)。
2)在命令行里输入net use,就会打印出当前缓存的链接上列表。
3)根据列表,一个个删除链接: net use 远程链接名称 /del
或者一次性所有删除:net use * /del

这样再次命令行输入samba服务地址的时候,就会从新让你输入访问的帐户和密码了。

======================================================
能够在一个samba环境下创建多个业务组的共享目录

好比:
建立一个运维部门的samba共享磁盘,能够看到全部的共享内容;
建立一个产品风控组的samba共享磁盘,只能看到本身组的共享内容;

[root@samba ~]# cd /etc/samba/
[root@samba samba]# ls
lmhosts  ops.smb.conf  smb.conf  smb.conf.bak  smbusers  chanpinfengkong.smb.conf
[root@samba samba]# diff smb.conf smb.conf.bak 
103d102
<         config file = /etc/samba/%U.smb.conf     #使用config file时,当用户访问Samba服务器,只能看到本身,其余在smb.conf中定义的共享资源都没法看到。

[root@samba samba]# cat ops.smb.conf 
[信息科技部-运维小窝]                                                  
       comment = please do not modify it all will        
       path= /data/samba                                                                 
       public = no         
       valid users = wangshibo,linan,@samba
       printable = no
       write list = @samba

[root@samba samba]# cat chanpinfengkong.smb.conf 
[产品风控组共享目录]                                                  
       comment = please do not modify it all will        
       path= /data/samba/产品风控组                                                            
       public = no         
       valid users = xiaomin,haokun,@samba
       printable = no
       write list = @samba


useradd建立以上的几个用户,并设置好用户家目录
[root@samba ~]# useradd wangshibo -d /data/samba -s /sbin/nologin
[root@samba ~]# useradd linan -d /data/samba -s /sbin/nologin
[root@samba ~]# useradd xiaomin -d /data/samba/产品风控组 -s /sbin/nologin
[root@samba ~]# useradd haokun -d /data/samba/产品风控组 -s /sbin/nologin
[root@samba ~]# cat /etc/passwd
......
wangshibo:x:507:508::/data/samba:/sbin/nologin
lijinhe:x:508:509::/data/samba:/sbin/nologin
......
xiaomin:x:1006:1006::/data/samba/产品风控组:/sbin/nologin
haokun:x:1007:1007::/data/samba/产品风控组:/sbin/nologin
chanpinfengkong:x:1010:1010::/home/chanpinfengkong:/bin/bash

将这几个用户添加到samba里
[root@samba ~]# pdbedit -a -u wangshibo
[root@samba ~]# pdbedit -a -u linan
[root@samba ~]# pdbedit -a -u xiaomin
[root@samba ~]# pdbedit -a -u haokun

[root@samba ~]# pdbedit -L
wangshibo:507:
linan:510:
xiaomin:1006:
haokun:1007:

建立chanpinfengkong组,将xiaomin和haokun添加到这个组内
[root@samba ~]# useradd chanpinfengkong
[root@samba ~]# usermod -G chanpinfengkong xiaomin
[root@samba ~]# usermod -G chanpinfengkong haokun

建立samba共享目录
[root@samba ~]# cd /data/
[root@samba data]# mkdir samba
[root@samba data]# mkdir samba/产品风控组
[root@samba data]# chown -R samba.samba samba
[root@samba data]# chmod -R 777 samba
[root@samba data]# setfacl -R -m g:chanpinfengkong:rwx samba/产品风控组

赋权脚本
[root@samba ~]# cat /opt/samba.sh 
#!/bin/bash

while [ "1" = "1" ]
do
   /bin/chmod -R 777 /data/samba
   /usr/bin/setfacl -R -m g:chanpinfengkong:rwx /data/samba/产品风控组
done

[root@samba ~]# nohup sh -x /opt/samba.sh &
[root@samba ~]# ps -ef|grep samba.sh
root      62836      1 16 May09 ?        14-23:47:39 sh -x /opt/samba.sh
root     185455 117471  0 15:41 pts/2    00:00:00 grep samba.sh

如上配置后,登陆samba:
1)用wangshibo,linan帐号登陆samba,能看到"/data/samba"下面全部的共享内容。
2)用xiaomin,haokun帐号登陆samba,只能看到"/data/samba/产品风控组" 下面的共享内容
3)若是还须要分更多的组,就如上面的"产品风控组"同样进行配置便可!
相关文章
相关标签/搜索