Linux samba服务搭建
实验准备: 准备两台机器,server0(172.25.0.11)和deskop0(172.25.0.12),要求在server0上实现samba共享,在desktop0上访问共享。
- 1、允许marketing组里的用户对该目录有读写权限,其他用户只读。
- 2、samba执行的工作组为mycompany。
- 3、用户brian输入marketing组,要求用户rob不属于marketing组。
- 4、共享组的目录为 /smbshare
- 5、将共享组挂载到desktop0机器的/mnt/brian目录下
说明:本实验不用特定的环境,自己搭建两台Linux机器就可独立完成
配置server(server0)端
1、安装相应的服务包
[root@server0 ~]# yum install samba -y
2、建立共享目录并对共享目录授权
[root@server0 ~]# mkdir /smbshare
[root@server0 ~]# groupadd -r marketing
[root@server0 ~]# chgrp marketing /smbshare/
[root@server0 ~]# chmod 2775 /smbshare/
[root@server0 ~]# ll -d /smbshare/
drwxrwsr-x. 2 root marketing 6 Apr 17 22:48 /smbshare/
2775中的2代表在该目录下所有的目录或者文件夹继承组marketing的权限,允许root和marketing组只有只读的权限 设定selinux
[root@server0 ~]# semanage fcontext -a -t 'samba_share_t' '/smbshare(/.*)?'
[root@server0 ~]# restorecon -Rv /smbshare/
restorecon reset /smbshare context unconfined_u:object_r:default_t:s0->unconfined_u:object_r:samba_share_t:s0
3、修改配置文件
[root@server0 ~]# vim /etc/samba/smb.conf
... [global]
...
workgroup = mycompany --->更改工作组
... [smbshare]
path = /smbshare
write list = @marketing -->用@来表示组 ...
4、创建共享用户
[root@server0 ~]# useradd -s /sbin/nologin -G marketing brian
[root@server0 ~]# useradd -s /sbin/nologin rob
[root@server0 ~]# id brian
uid=1001(brian) gid=1001(brian) groups=1001(brian),990(marketing)
[root@server0 ~]# id rob
uid=1002(rob) gid=1002(rob) groups=1002(rob)
[root@server0 ~]#
5、将用户加入samba数据库中并设定密码
smbpasswd需要 samba-client的包支持
[root@server0 ~]# yum install samba-client -y
[root@server0 ~]# smbpasswd -a brian
New SMB password: -->redhat
Retype new SMB password:
Added user brian.
[root@server0 ~]# smbpasswd -a rob
New SMB password: -->redhat
Retype new SMB password:
Added user rob.
6、启动服务并设置防火墙
[root@server0 ~]# systemctl start smb nmb
[root@server0 ~]# systemctl enable smb nmb
ln -s '/usr/lib/systemd/system/smb.service' '/etc/systemd/system/multi-user.target.wants/smb.service'
ln -s '/usr/lib/systemd/system/nmb.service' '/etc/systemd/system/multi-user.target.wants/nmb.service'
[root@server0 ~]# firewall-cmd --permanent --add-service=samba
success
[root@server0 ~]# firewall-cmd --reload
success
[root@server0 ~]# firewall-cmd --list-all
public (default, active)
interfaces: eth0
sources:
services: dhcpv6-client samba ssh
ports:
masquerade: no
forward-ports:
icmp-blocks:
rich rules:
server端配置到此结束
配置client(desktop0)端
1、安装工具包
[root@desktop0 ~]# yum install cifs-utils
2、创建相应的挂载点并挂载目录
[root@desktop0 ~]# mkdir -p /mnt/brian
[root@desktop0 ~]# mount -o username=brian //172.25.0.11/smbshare /mnt/brian/
Password for brian@//172.25.0.11/smbshare: ****** ---> redhat
[root@desktop0 ~]# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/sda1 10G 3.1G 7.0G 31% /
devtmpfs 223M 0 223M 0% /dev
tmpfs 238M 0 238M 0% /dev/shm
tmpfs 238M 8.8M 230M 4% /run
tmpfs 238M 0 238M 0% /sys/fs/cgroup
//172.25.0.11/smbshare 10G 3.1G 7.0G 31% /mnt/brian
3、测试用户权限
brian用户
[root@desktop0 ~]# echo "Hello World" >> /mnt/brian/test.txt
[root@desktop0 ~]# cat !$
cat /mnt/brian/test.txt
Hello World
文件创建成功
[root@desktop0 ~]# ll !$
ll /mnt/brian/test.txt
-rw-r--r--. 1 1001 990 12 Apr 17 23:12 /mnt/brian/test.txt
此处出现1001和990的意思是本机没有1001和990这两个id,但是服务器上有,可以查看服务器上文件的所属组和用户
[root@server0 ~]# ll /smbshare/test.txt
-rw-r--r--. 1 brian marketing 12 Apr 17 23:12 /smbshare/test.txt
可以看到desktop0机器上,root用户创建的文件被改为了brian用户maretketing的权限
rob用户
[root@desktop0 ~]# mount -o username=rob //server0/smbshare /mnt/rob/
Password for rob@//server0/smbshare: ****** ---> redhat
[root@desktop0 ~]# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/sda1 10G 3.1G 7.0G 31% /
devtmpfs 223M 0 223M 0% /dev
tmpfs 238M 0 238M 0% /dev/shm
tmpfs 238M 8.8M 230M 4% /run
tmpfs 238M 0 238M 0% /sys/fs/cgroup
//172.25.0.11/smbshare 10G 3.1G 7.0G 31% /mnt/brian
//server0/smbshare 10G 3.1G 7.0G 31% /mnt/rob
创建文件失败
[root@desktop0 ~]# touch /mnt/rob/test.txt
touch: cannot touch ‘/mnt/rob/test.txt’: Permission denied
因为设定只允许marketing组的用户有写的权限,而rob不属于marketing组,所以无法创建
本实验到此结束
附:
rhce考试需要做的事
列出server0上的smb共享
smbclient需要samba-client包的支持
[root@desktop0 ~]# yum install samba-client -y
用brian用户列出server0机器的samba共享
[root@desktop0 ~]# smbclient -L //server0 -U brian
Enter brian's password:
Domain=[MYCOMPANY] OS=[Unix] Server=[Samba 4.1.1] Sharename Type Comment
--------- ---- -------
smbshare Disk
IPC$ IPC IPC Service (Samba Server Version 4.1.1)
brian Disk Home Directories
Domain=[MYCOMPANY] OS=[Unix] Server=[Samba 4.1.1] Server Comment
--------- -------
LOCALHOST Samba Server Version 4.1.1 Workgroup Master
--------- -------
MYCOMPANY LOCALHOST
但是考试时上述命令不会被记录,所以上述操作不会被评分,需要通过命令工具访问
[root@desktop0 ~]# smbclient //server0/smbshare -U brian
Enter brian's password:
Domain=[MYCOMPANY] OS=[Unix] Server=[Samba 4.1.1]
smb: \> ls
. D 0 Wed Apr 17 23:26:57 2019
.. D 0 Thu Apr 18 07:40:37 2019 40913 blocks of size 262144. 28330 blocks available
smb: \> ?
? allinfo altname archive backup
blocksize cancel case_sensitive cd chmod
chown close del dir du
echo exit get getfacl geteas
hardlink help history iosize lcd
link lock lowercase ls l
mask md mget mkdir more
mput newer notify open posix
posix_encrypt posix_open posix_mkdir posix_rmdir posix_unlink
print prompt put pwd q
queue quit readlink rd recurse
reget rename reput rm rmdir
showacls setea setmode stat symlink
tar tarmode timeout translate unlock
volume vuid wdel logon listconnect
showconnect tcon tdis tid logoff
.. !
smb: \> quit
Linux samba服务搭建的更多相关文章
- Linux 邮件服务搭建
Linux 邮件服务搭建 邮件服务针对,在大型企业使用的比较多,一般小型企业都会买一些邮件服务,或者使用一些免费的邮件服务,达到我们使用的需求,并且不需要自己维护,下面我就来简单安装一下两个邮箱的案例 ...
- Linux下samba服务搭建
参考: https://www.cnblogs.com/lxyqwer/p/7271369.html https://www.cnblogs.com/liulipeng/p/3406352.html ...
- samba服务搭建及管理
关闭防火墙 # /etc/init.d/iptables stop # chkconfig --level iptables off 关闭SELINUX # vim /etc/sysconfig/se ...
- Linux基础服务搭建综合
Linux服务综合搭建的文章目录 =============================================== 1.foundation创建yum仓库 2.部署DNS 3.将YUM源 ...
- 记一次linux samba服务问题调试
linux下samba服务加入windows域控后,samba共享名与合法用户名不应一致,否则无法访问此共享.
- 《samba服务搭建》RHEL6
Samba服务不仅可以实现linux和win之间的文件共享,也可以实现linux和linux之间的共享,samba的用户只限服务端本地用户使用. 本文的环境是selinux开启的情况下配置 Samba ...
- Linux Samba目录服务搭建与Java客户端访问
前言: 本文比较简略,只求快速入门,若要了解详情,推荐一篇文章:http://www.cnblogs.com/mchina/archive/2012/12/18/2816717.html 1,安装sa ...
- Linux samba 服务的配置
今天有个学生问我 samba 服务怎么配置,所以晚上特意研究一下怎么配置这个服务. 过程如下: sudo apt-get install samba samba-common // 安装 samba ...
- Linux - samba 服务
暂时关闭 iptables 防火墙 [root@sch01ar ~]# systemctl stop iptables.service 暂时关闭 firewall 防火墙 [root@sch01ar ...
随机推荐
- Scrapy实战篇(八)之爬取教育部高校名单抓取和分析
本节我们以网址https://daxue.eol.cn/mingdan.shtml为初始链接,爬取教育部公布的正规高校名单. 思路: 1.首先以上面的地址开始链接,抓取到下面省份对应的链接. 2.在解 ...
- 20175311 2018-2019-2 《Java程序设计》第五周学习总结
20175311 2018-2019-2 <Java程序设计>第5周学习总结 教材学习内容总结 抽象类和具体类的区别在于抽象类中有抽象方法而具体类中没有.且抽象类不能实例化. 接口:如果一 ...
- boolean表达式与在if条件中的运用
1.boolean语句 boolean 类型的数据 有两个值 false 和true; 2.在if判断的条件语句中 例如: boolean arn =false 在if 判断的括号中可以表示为 !a ...
- 对象名 'dbo.__MigrationHistory' 无效 错误解决
// 在数据库上下文的构造方法里 public GewPeAppContext() : base(ConnectionStrings.GewPeAppConnectionString) { // 添加 ...
- jquery datatable数据初始化
一个datatable的初始化问题,困扰了在下整整半天,最后在网上各位大神的帮助下,终于解决了. 首先分析一下我所遇到的问题: 在HTML上有个下拉框,我需要获取下拉框的值来从后台数据库中获取不同的数 ...
- Jmeter连接数据库方式
关系型数据库: 1.mysql: 方式:Database URL:jdbc:mysql://localhost:port/DBname?user=**&password=**&allo ...
- JavaScript数组方法--reduce、reduceRIght、reverse
今天写的reduce是比较复杂的一个数组方法,其实在这之前我也用过reduce,可是每次用起来总感觉不那么顺手,主要还是因为不熟,对reduce本身不熟.首先reduce这个单词翻译为中文,不那么直观 ...
- leetcode每日刷题计划-简单篇day9
Num 38 报数 Count and Say 题意读起来比较费劲..看懂了题还是不难的 注意最后的长度是sz的长度,开始写错写的len 在下次计算的时候len要更新下 说明 直接让char和int进 ...
- boost的named_mutex的一些坑
最近遇到一个问题,程序在a用户下运行后,然后注销windows,登陆b用户,发现程序奔溃,抓了下堆栈,发现了boost的named_mutex一些细节,记录下 #include <boost/i ...
- JAVA学习记录(二)————JAVA中的IO
Java中I/O操作主要是指使用Java进行输入,输出操作. Java所有的I/O机制都是基于数据流进行输入输出,这些数据流表示了字符或者字节数据的流动序列. 数据流是一串连续不断的数据的集合,就象水 ...