转载:
http://blog.csdn.net/wentasy/article/details/8142992
环境
RedHatLinux 9 + VWWare 8.0 + SSH 3.2.9
任务要求
使用Samba服务完成下面的任务:
假如公司有财务,技术,领导3个部门,我们分别为3个部门建立3个用户组为caiwu,network,lingdao;
三个部门里各有2个用户,我们建用户分别为caiwu01,caiwu02,network01,network02,lingdao01,lingdao02
1、首先服务器采用用户验证的方式,每个用户可以访问自己的宿主目录,并且只有该用户能访问宿主目录,并具有完全的权限,而其他人不能看到你的宿主目录
2、建立一个caiwu的文件夹,希望caiwu组和lingdao组的人能看到,network02也可以访问,但只有caiwu01有写的权限。
3、建立一个lindao的目录,只有领导组的人可以访问并读写,还有network02也可以访问,但外人看不到那个目录
4、建立一个文件交换目录exchange,所有人都能读写,包括guest用户,但每个人不能删除别人的文件。
5、建立一个公共的只读文件夹public,所有人只读这个文件夹的内容。
验证方法:
比如:以caiwu01用户登录SSH,然后用以下命令验证samba服务配置是否正确
smbclient //linuxIP/samba配置文件中中共享文件的名字
比如在SSH中输入以下命令:smbclient //192.168.78.100/share
相关命令
[plain] view plaincopy
1. 1.建立3个组:
2. groupadd caiwu;
3. groupadd network;
4. groupadd lingdao;
5.
6. 2.添加用户并加入相关的组当中:
7. useradd caiwu01 -g caiwu;
8. useradd caiwu02 -g caiwu;
9. useradd network01 -g network;
10. useradd network02 -g network;
11. useradd lingdao01 -g lingdao;
12. useradd lingdao02 -g lingdao;
13.
14. 3.使用smbpasswd为每个用户添加samba密码
15.
16. smbpasswd caiwu01;
17. smbpasswd caiwu02;
18. smbpasswd network01;
19. smbpasswd network02;
20. smbpasswd lingdao01;
21. smbpasswd lingdao02;
22.
23. 4.我们使用smbpasswd -a caiwu01的命令为6个帐户分别添加到samba用户中
24.
25. smbpasswd -a caiwu01;
26. smbpasswd -a caiwu02;
27. smbpasswd -a network01;
28. smbpasswd -a network02;
29. smbpasswd -a lingdao01;
30. smbpasswd -a lingdao02;
31.
32. 5.创建需要使用的目录:
33. mkdir /home/samba;
34. mkdir /home/samba/caiwu;
35. mkdir /home/samba/lingdao;
36. mkdir /home/samba/exchange;
37. mkdir /home/samba/public;
38.
39. 为了避免麻烦可以在这里把上面所有的文件夹的权限都设置成777
40. 通过samba灵活的权限管理来设置上面的5点要求.
41.
42.
43. 6.配置smb.conf
44.
45. smb.conf的配置文件
46. [global]
47. workgroup = bmit
48. #我的网络工作组
49. server string = Frank's Samba File Server
50. #我的服务器名描述
51. security = user
52. #使用用户验证机制
53. encrypt passwords = yes
54. smb passwd file = /etc/samba/smbpasswd
55. #使用加密密码机制,在win95和winnt使用的是明文
56.
57. 7.homes段满足第1条件
58.
59. [caiwu01]
60. comment = caiwu01
61. browseable = yes
62. writeable = yes
63. path = /home/caiwu01
64. valid users = caiwu01
65.
66. [caiwu02]
67. comment = caiwu02
68. browseable = yes
69. writeble = yes
70. path = /home/caiwu02
71.
72. [network01]
73. comment = network01
74. browseable = yes
75. writeable = yes
76. path = /home/network01
77. valid users = network01
78.
79. [network02]
80. comment = network02
81. browseable = yes
82. writeable = yes
83. path = /home/network02
84. valid users = network02
85.
86.
87. [lingdao01]
88. comment = lingdao01
89. browseable = yes
90. writeable = yes
91. path = /home/lingdao01
92. valid users = lingdao01
93.
94. [lingdao02]
95. comment = lingdao02
96. browseable = yes
97. writeable = yes
98. path = /home/lingdao02
99. valid users = lingdao02
100.
101.
102. 8.caiwu段满足我们的第2要求
103. [caiwu]
104. comment = caiwu
105. path = /home/samba/caiwu
106. public = no
107. valid users = @caiwu,@lingdao,network02
108. write list = caiwu01
109. printable = no
110. #caiwu段满足我们的第2要求
111.
112. 9.lingdao段能满足我们的第3要求
113. [lingdao]
114. comment = lingdao
115. path = /home/samba/lingdao
116. public = no
117. browseable = no
118. valid users = @lingdao,network02
119. printable = no
120.
121. #lingdao段能满足我们的第3要求
122.
123.
124. 10.exchage共享文件配置
125.
126. [exchage]
127.
128. comment = Exchange File Directory
129.
130. path = /home/samba/exchange
131.
132. public = yes
133.
134. writable = yes
135. #exchange段基本能满足我们的第4要求,但不能满足每个人不能删除别人的文件这个条件,即使里设置了mask也是没用,其实这个条件只要unix设置一个粘着位就行
136.
137. chmod -R 1777 /home/samba/exchange
138.
139. 注意这里权限是1777,类似的系统目录/tmp也具有相同的权限,这个权限能实现每个人能自由写文件,但不能删除别人的文件这个要求
140.
141. 11.这个public段能满足我们的第5要求
142.
143. [public]
144.
145. comment = Read Only Public
146.
147. path = /home/samba/public
148.
149. public = yes
150.
151. read only = yes
152.
153. #这个public段能满足我们的第5要求。