分类: LINUX
2010-05-30 15:07:44
「原因」:以前在公司实习,研发部5个人,有一台linux服务器(由经理管理,另外四个人可以登录,只对自己的家目录有读写权限和一些共享目录,对其他人的家目录可读不可写)。所有人都可以通过samba访问共享目录,可以通过ssh登录服务器,读写相关文件。这几天在看linux基础内容,正好看到相关部分,同时就想我作为管理者如何实现上述要求。
「目标」
1. samba部分:
1)我作为管理者具有管理所有samba共享空间的权限;
2)其他用户拥有自己的空间,并且除了自身及管理者有权限以外,对其它用户具有绝对隐私性;
3)管理者和其他用户拥有一个共同的读写权限的空间;
2. ssh部分:
1)可以登录服务器;
2)只对自己的家目录有读写权限,对其他只有读权限;
「过程」:说来也巧,在google的时候,发现上北南南北有写过符合我samba部分要求的文章()。于是,老老实实,从头到尾自习的学习了一下,并且已在ubuntu9.04下实现samba部分的目标。在此,向北南南北致以敬意!
「samba相关知识总结」:
1. 用途:1)实现Linux与windows之间文件贡献;2)linux与linux之间共享文件(不过二者之间用NFS更好)
2. 使用协议:
3. 2个服务器:smb和nmb,smb告诉其他机器我共享了什么;而nmb负责ip地址与主机名之间的解析
「详细过程」:以下均参考来自北南南北的。
1、用户共享模型(适合10人左右的小型企业);
比如一个公司有五个部门,分别是linuxsir,sir01,sir02,sir03,sir04。我们想为这家公司设计一个比较安全的共享文件模型。每个用户都有自己的网络磁盘,sir01到sir04还有共用的网络硬盘;所有用户(包括匿名用户)有一个共享资料库,此库为了安全是只读的;所有的用户(包括匿名用户)要有一个临时文件终转的文件夹... ....
1.1 共享权限设计实现的功能;
1)linuxsir部门具有管理所有SMB空间的权限;
2)sir01到sir04拥有自己的空间,并且除了自身及linuxsir有权限以外,对其它用户具有绝对隐私性;
3)linuxsir01到linuxsir04拥有一个共同的读写权限的空间;
4) 所有用户(包括匿名用户)有一个有读权限的空间,用于资料库,所以不要求写入数据。
5)sir01到sir04还有一个共同的空间,对sir01到sir04的用户来说是隐私的,不能让其它用户来访问。
6) 还要有一个空间,让所有用户可以写入,能删除等功能,在权限上无限制 ,用于公司所有用户的临时文档终转等;
1.2 在服务器上创建相应的目录;
[root@ubuntu ~]# mkdir -p /opt/linuxsir
[root@ubuntu ~]# cd /opt/linuxsir
[root@ubuntu /opt/linuxsir]# mkdir sir01 sir02 sir03 sir04 sirsharero sir0104rw sirallrw
[root@ubuntu /opt/linuxsir]# ls
sir01 sir0104rw sir02 sir03 sir04 sirallrw sirsharero
注:功用如下:
/opt/linuxsir 这是管理员目录,负责管理其下所有目录;
/opt/linuxsir/sir01 是sir01的家目录,用于私用,除了用户本身和linuxsir以外其它用户都是不可读不可写;
/opt/linuxsir/sir02 是sir02的家目录,用于私用,除了用户本身和linuxsir以外其它用户都是不可读不可写;
/opt/linuxsir/sir03 是sir03的家目录,用于私用,除了用户本身和linuxsir以外其它用户都是不可读不可写;
/opt/linuxsir/sir04 是sir04的家目录,用于私用,除了用户本身和linuxsir以外其它用户都是不可读不可写;
/opt/linuxsir/sirshare 所用用户(除了linuxsir有权限写入外)只读目录
/opt/linuxsir/sir0104rw 是用于sir01到sir04用户可读可写共用目录,但匿名用户不能读写;
/opt/linuxsir/sirallrw 用于所有用户(包括匿名用户)的可读可写;
1.3 添加用户用户组,设置相应目录家目录的权限;
1.3.1 添加用户组;
[root@ubuntu ~]# /usr/sbin/groupadd linuxsir
[root@ubuntu ~]# /usr/sbin/groupadd sir01
[root@ubuntu ~]# /usr/sbin/groupadd sir02
[root@ubuntu ~]# /usr/sbin/groupadd sir03
[root@ubuntu ~]# /usr/sbin/groupadd sir04
[root@ubuntu ~]# /usr/sbin/groupadd sir0104
1.3.2 添加用户;
注:Ubuntu中增加用户的命令与FC略有区别,用的是useradd,用法基本相同
[root@ubuntu~]# useradd -g sir01 -G sir0104 -d /opt/linuxsir/sir01 -s /sbin/nologin sir01
[root@ubuntu~]# useradd -g sir02 -G sir0104 -d /opt/linuxsir/sir02 -s /sbin/nologin sir02
[root@ubuntu~]# useradd -g sir03 -G sir0104 -d /opt/linuxsir/sir03 -s /sbin/nologin sir03
[root@ubuntu~]# useradd -g sir04 -G sir0104 -d /opt/linuxsir/sir04 -s /sbin/nologin sir04
[root@ubuntu~]# useradd -g linuxsir -d /opt/linuxsir -G linuxsir,sir01,sir02,sir03,sir04,sir0104 -d /opt/linuxsir -s /sbin/nologin linuxsir
为什么这样添加用户?请参考:
当然我们还得学会查看用户信息的工具用法,比如 用finger和id来查看用户信息,主要是看用户是否添加正确;比如;请参考
[root@ubuntu ~]# id linuxsir
[root@ubuntu ~]# finger linuxsir
1.3.3 添加samba用户,并设置密码;
我们用的方法是先添加用户,但添加的这些用户都是虚拟用户,因为这些用户是不能通过SHELL登录系统的;另外值得注意的是系统用户密码和Samba用户的密码是不同的。如果您设置了系统用户能登入SHELL,可以设置用户的Samba密码和系统用户通过SHELL登录的密码不同。
我们通过smbpasswd 来添加Samba用户,并设置密码。原理是通过读取/etc/passwd文件中存在的用户名。
[root@ubuntu sir01]# smbpasswd -a linuxsir
New SMB password: 注:在这里添加Samba用户linuxsir的密码;
Retype new SMB password: 注:再输入一次;
用同样的方法来添加 sir01、sir02、sir03、sir04的密码;
1.3.4 配置相关目录的权限和归属;
[root@ubuntu~]# chmod 755 /opt/linux
[root@ubuntu~]# chown linuxsir:linuxsir /opt/linuxsir
[root@ubuntu~]# cd /opt/linuxsir
[root@ubuntu~]# chmod 2770 sir0*
[root@ubuntu~]# chown sir01.linuxsir sir01
[root@ubuntu~]# chown sir02.linuxsir sir02
[root@ubuntu~]# chown sir03.linuxsir sir03
[root@ubuntu~]# chown sir04.linuxsir sir04
[root@ubuntu~]# chown linuxsir.sir0104 sir0104rw
[root@ubuntu~]# chown linuxsir.linuxsir sirshare
[root@ubuntu~]# chmod 755 sirshare
[root@ubuntu~]# chown linuxsir:linuxsir sirallrw
[root@ubuntu~]# chmod 3777 sirallrw
1.4 修改Samba配置文件 smb.conf;
配置文件如下,修改/etc/samba/smb.conf后,不要忘记重启smbd和nmbd服务器;(修改以前记得要备份smb.conf文件)
[global]
workgroup = Mshome
#我的工作
netbios name = ubuntu
server string = Linux Samba TestServer
security = share
client lanman auth = yes
#防止中文乱码
display charset = UTF-8
unix charset = UTF-8
dos charset = cp936
[linuxsir]
comment = linuxsiradmin
path = /opt/linuxsir/
create mask = 0664
#create mask是用户创建文件时的权限掩码;对用户来可读可写,对用户组可读可写,对其它用户可读;
directory mask = 0775
#directory mask 是用来设置用户创建目录时的权限掩码,意思是对于用户和用户组可读可写,对其它用户可读可执行;
writeable = yes
valid users = linuxsir
browseable = yes
[sirshare]
path = /opt/linuxsir/sirshare
writeable = yes
browseable = yes
guest ok = yes
[sirallrw]
path = /opt/linuxsir/sirallrw
writeable = yes
browseable = yes
guest ok = yes
[sir0104rw]
comment = sir0104rw
path = /opt/linuxsir/sir0104rw
create mask = 0664
directory mask = 0775
writeable = yes
valid users = linuxsir,@sir0104
#@sir0104是用户组;
browseable = yes
[sir01]
comment = sir01
path = /opt/linuxsir/sir01
create mask = 0664
directory mask = 0775
writeable = yes
valid users = sir01,@linuxsir
browseable = yes
[sir02]
comment = sir02
path = /opt/linuxsir/sir02
create mask = 0664
directory mask = 0775
writeable = yes
valid users = sir02,@linuxsir
browseable = yes
[sir03]
comment = sir03
path = /opt/linuxsir/sir03
create mask = 0664
directory mask = 0775
writeable = yes
valid users = sir03,@linuxsir
browseable = yes
[sir04]
comment = sir04
path = /opt/linuxsir/sir04
create mask = 0664
directory mask = 0775
writeable = yes
valid users = sir04,@linuxsir
browseable = yes
检查/etc/samba/smb.conf设置是否正确
[root@ubuntu ~]testparm /etc/samba/smb.conf
重启samba服务
[root@ubuntu ~]/etc/init.d/samba restart
「疑惑」
1. [root@ubuntu~]# chmod 2770 sir0*;2770是怎么算出来?
2. [root@ubuntu~]# chmod 3777 sirallrw;3777是怎么算出来?
3.security = share;security能否等于user?
4.为什么[sirsharero]字段中guest=OK?
「需要继续的工作」ssh部分未实现部分
1)可以登录服务器;
2)只对自己的家目录有读写权限,对其他只有读权限;