分类: LINUX
2008-11-28 16:35:33
在使用有 Unix系统的操作环境中,人们常常碰到与 Windows系统之间交换文件的问题。遇到这种情况时第一个能想到的就是大家最熟悉的 FTP了。 FTP虽然能够提供文件的交互但是如果没有安装图形化的客户端只能以命令行方式操作,这样使用起来就需要记一些命令,相对来说就比较繁琐了。那么有没有其它更方便的选择呢?随着 Unix系统的发展前辈们提出了 SAMBA这种方式,利用安装在 Unix系统上的 SAMBA服务我们可以象使用 Windows的网上邻居一样在它们直接以拖拽的方式进行文件的交换了。目前 SAMBA有很多开源的实现可供用户使用,那么具体到 Solaris10 ,它在系统安装的时候已经包含了 SAMBA,只需要简单的配置就可以使用了。
二、配置 SAMBA
在这一节中将结合具体的实例来一步一步的描述 SAMBA的配置和使用。
Samba服务器包含两个Daemon,nmbd和smbd。smbd是 samba的内核,是建立对话,验证客户和提供文件系统和打印服务的基础;
nmbd则处理所有的名字注册和解析请求,实现了网络浏览的功能;它的任务是向局域网广播Samba服务器所提供的服务;Nmbd使得Samba服务器显示在windows操作系统的网络邻居中,允许用户浏览可以通过samba使用的资源。
缺省OpenSolaris并没有使能Samba服务。
# svcs -v | grep samba
# ps -eaf | grep mbd
Samba的共享方式包括share、user、server、domain 和ads。本文主要主要介绍share和user的共享方式。
2.1 配置share方式
采用share方式,用户不需要输入帐号和密码就可以登陆samba服务器。其配置步骤为:
1) 创建一个Samba共享目录
# mkdir -p /export/home/smbshare
2) 创建Samba配置文件
# cp /etc/sfw/smb.conf-example /etc/sfw/smb.conf
3) 编辑配置文件smb.conf
===== ===== /usr/sfw/smb.conf ==========
security = share
[homes]
comment = Home Directories
browseable = yes
writable = yes
path = /export/home/smbshare
guest ok = yes
guest account = user1
这里用户是通过默认的user1来登陆的。用户登陆之后,可以看到user1
所共享的文件和所有系统共享文件,其他用户共享的文件能够看得到,但是不一定能够使用或者进的去。如果不设置guest
account的话,则用户就以默认的nobody进行登陆,只能够使用系统设置的共享文件。其他用户设置的文件不一定能够使用。
4) 启动Samba服务
# svcadm enable samba
# svcs | grep samba
online1:19:02svc:/network/samba:default
# ps -eaf | grep mbd
root 24453 1 0 01:19:02 ? 0:00 /usr/sfw/bin/smbd -D
root 24450 1 0 01:19:02 ? 0:00 /usr/sfw/bin/nmbd -D
root 24454 24453 0 01:19:02 ? 0:00 /usr/sfw/bin/smbd -D
2.2 配置user方式
配置成user方式需要提供用户名和密码进行验证。这里Samba用户必须是
Solaris系统用户。而对同一个用户来说,samba密码和系统密码不必一定相同。
1) 添加一个系统用户(用已经存在的也可以)
# useradd -d /export/home/andy -m -s /usr/bin/bash andy
2) 用smbpasswd添加Samba用户
# /usr/sfw/bin/smbpasswd -a andy
New SMB password:
Retype new SMB password:
Added user andy.
# /usr/sfw/bin/smbpasswd -e andy
Enabled user andy
3) 编辑配置文件smb.conf
===== ===== /usr/sfw/smb.conf ==========
security = user
[homes]
comment = Home Directories for %S
valid users = %S# 只有所有者能访问该共享
browseable = no# 该共享对其它用户不可见
writable = yes
create mask = 0640# 创建文件时的权限掩码
directory mask = 0750# 创建目录时的权限掩码
这里%S通配符可以扩展成实际的共享名。这样andy共享的注释将是 “Home Directories for andy”。
4) 重新启动Samba服务
# svcadm restart samba
从其它系统上用samba访问该Solaris机器时,如果输入的用户名是
andy,密码是Samba密码,就能看到/export/home/andy 下的内容。
三、Solaris访问 Windows的共享资源
Samba包中已经包括了smbclient、smbmount等的实用程序。smbclient程序提供了一个类似FTP
的模式界面,允许用户共享Windows、Linux的资源,还可以用户列出服务器上的可用共享资源。smbmount类似mount命令,将
Windows的共享目录安装到Linux的本地目录。
1) 查询网络上的Samba服务器
# /usr/sfw/bin/findsmb
每个找到的服务器都会显示其 IP 地址、NetBIOS 名称、工作组名称、操作系统、以及 SMB 服务器版本。
2) 列出Samba服务器上的可用资源
# /usr/sfw/bin/smbclient -L
如果是 user共享方式,就要加“-U
# /usr/sfw/bin/smbclient -L
Password:
如果是 share共享方式,可以不必理会用户和密码,要求输入密码时直接回车即可。
3) 连接Samba共享
# /usr/sfw/bin/smbclient //
例如要访问上文中的share共享时,可用
# /usr/sfw/bin/smbclient //hostname/homes
Password:
Domain=[MYGROUP] OS=[Unix] Server=[Samba 3.0.21b]
smb:>
要访问上文中的user共享时,可用
# /usr/sfw/bin/smbclient //hostname/andy -U andy
Password:
Domain=[MYGROUP] OS=[Unix] Server=[Samba 3.0.21b]
smb:>
连接后,就能象FTP用户一样上传和下载文件。用put表示上传,用get表示下载。键入help获得可用的命令列表。