LinuxSir.cn,穿越时空的Linuxsir!

 找回密码
 注册
搜索
热搜: shell linux mysql
查看: 34933|回复: 80

如何架设Samba服务器,用user共享方式?

[复制链接]
发表于 2002-12-15 04:54:48 | 显示全部楼层 |阅读模式
如何架设Samba服务器,用user共享方式?

一点理论:

在Windows中,我们都知道网络邻居,是Windows共享资源的方式。Linux写Windows互访与共享资源的方式是利用Samba服务,其实我觉得它更象一个软件。Windows与Linux通过Samba,可以相互共享资源,是互为服务器和客户端的关系。比如当装有Windows操作系统的机器,向装有Linux系统的机器存取文件,那Windows应该是客户机,而Linux则是服务器;如果Linux的机器向Windows访问和存限文件及使用Windows提供的打印服务,这时应该说Windows是服务器,而Linux是客户机。

注意的事项:

1。如果在windows下不能加入linux的共享,可能出现在帐户上,要在linux和window的机器上都要建一个相同的用户,密码也要一样。否则不能访问。

2。如果在windows的网络邻居中,有时可能不会发现linux的共享。我们要自己在添加网络邻居中加上。要以\\linux的samba的主机名也就是netbios name中定义的\共享名。这样说可能新手弟兄不太懂。我说的也不太专业。呵。。。请仔细看本帖中的\\linsir01\win02类似的,还有\\linsir01\share;\\linsir01\win03之类的。

3。要在windows加上相关的协议;添加网络协议,把IPX/SPX以及NETBEUI两个协议加入。


操作环境:三台机器,两台win2000;一台是RH80.


一、查看是否Samba在系统中被安装了;这也是安装其它软件的操作步骤:注:以root登入,或者以root权限执行;

#rpm -qa | grep samba

samba-2.2.5-10
samba-swat-2.2.5-10
samba-common-2.2.5-10
samba-client-2.2.5-10

如果没有出现上面的三个安装包,我们就要在盘中把这些包找出来安装上;把光盘中凡是带有samba的都找出来,放到linux的一个临时的文件夹中。比如我们临时放到/tmp目录里。
然后执行:
#rpm -ivh samba*.rpm --nodeps --force

二、然后我们判断一下,是否samba服务已经启动,如果没有,我们就得打开。

一般说来,在系统默认的情况下,samba是不会启动的。但我们也应该懂得如何查看此服务是否启动了,这也是我们的一个操作的流程吧。使用查看进程命令:

#ps -aux | grep smb

在这里,我们要说明一点,为什么我们不用#ps -aux | grep samba命令呢,在下文可能就明白了,现在能记住就好了。不为什么,因为系统的服务就是smb,而非samba,samba只是一个名字而已。

如果用查看进程的命令,出现了第二行的样子。就是已经把samba服务打开了,如果没有出现,就是没有打开。

#ps -aux | grep smb
root      1719  0.0  0.3  4916 1820 ?        S    08:21   0:00 smbd -D

root      1849  0.0  0.1  4776  628 pts/1    S    08:48   0:00 grep smb

三、打开samba服务;

如果我们没有打开samba服务,我们应该用以下两种方法来打开,系统服务,一般打开方式都是如此。

1.用setup命令来打开,在#setup执行下去的时候,有个System serverices,然后移动键盘的上下键来选定[System serverices]项,然后把smb和swa两项前面加个*号,
表示已经选中了,意思就是自动启动这两个服务。或者用更直接的办法用命令进入[System serverices]的选择框中。
以上解释中用到的两个命令是:
#setup

#ntsysv

以这种方式,只是打开,但如果不重新启动,samba的服务也不能运行,我们还要用命令来执行,让机器不重新启动的情况下把samba服务执行起来,一般的情况下,我们要操作的
samba的命令都在/etc/rc.d/init.d/目录里,要用下面的方式来运行。

# /etc/rc.d/init.d/smb start
用了上面的命令,如果能看到下面的提示,就证明已经把samba启动了。

启动 SMB 服务:                                            [  确定  ]
启动 NMB 服务:                                            [  确定  ]

当然也可以用下面的方式,只是多了一步,不过进入/etc/rc.d/init.d/目录看一下也好,看里面都有什么,凡是我等菜鸟,也不能不看一下。

#cd /etc/rc.d/init.d/

然后再执行
#./smb start

然后了,那如何把samba的服务停下来呢?那就stop;如何重启samba服务器,那就restart了

如果是在/etc/rc.d/init.d目录中,我们就要执行
#./smb stop
#./smb restart

如果不在/etc/rc.d/init.d目录中,我们就要这样执行,上面已经有说过了。

# /etc/rc.d/init.d/smb stop
# /etc/rc.d/init.d/smb restart

2.运行如下的命令也有在X下打开

#redhat-config-services

然后也是选中smb和swat,然后保存一下。这个比较简单。如果您在smb这项,选中后,然后就点一下开始。这样就把smb服务打开了。


把服务打开了也启动起来了,我们还是要用查看进程命令来查看一下,samba服务是否在运行了。

#ps -aux | grep smb

如果还是没有下面这行,我觉得不太可能了。呵。。。。。

root      1719  0.0  0.3  4916 1820 ?        S    08:21   0:00 smbd -D


三、设置samba的配置文件

1.图形化的配置工具swat;

打开mozilla,或者konqueror以及gnome下的文件管理器,总之无论如何打开文件管理器就行了。在地址栏中输入
127.0.0.1:901就会出现一个提示框[SWAT@127.0.0.1:901]

在用户名下输入root用户名和密码就能进入图形置置界面了,这个比较简单。

1]点一下[Global]那项,就出来一个让我们设置的选项。我们只要简单的设置一下这些就行了,如果您对samba不太了解,建议不要改其它的东西。如果您按我在前面说的做,把smb.conf
文件有备份,那您改就改吧。。哈。。错了也没有什么,我们再恢复一下就OK了。。

Base Options

client code page 936 这样就能显示简体中文了用户组名。

[workgroup]这一项,就是在网络邻居中[Windows的称呼]中的工作组的名称,这一项我用的是MSHOME,因为我把其它的两台电脑也设置在了这个工作组。

[netbios name]这是出现在网络邻居中的主机名,我设置的linsir01,采用默认也行。出现的是Linux真正的主机名。

[security],设置为user

[encrypt passwords]设置为yes

2]点一下[shares],也看一下吧。这个也是比较重要的,我还是主要说几点要注意的。其实我们在局域网中用到的都比较简单的功能。简单的设置一下就行了。

点一下[choose share],有一个是[homes]的选项吧。点一下。。。然后。。。。看过来。。看一下和下面的差不多就行,其实不用改什么,了解一下就行。。

comment 这个选项可以不写

path 也可以不写

guest account  nobody 默认就行。

valid users %S

read only Yes

guest ok No


3]creat share 这一项就是要我们创建共享目录以及个人目录的,可能有的弟兄有点不解,为什么这样说呢??一步一步的来。。。。。

A。我们创建一个win02,在[ceate share]那个按钮的边上,有个空格。呵。。。可能您知道了吧,写个win02,然后按一下[create share]


comment win02

path /home/win02

username win02

guest accoun nobody

valid users win02

read only No

guest ok No

browseable Yes

available Yes

B。以相同的办法创建win03,目录也为/home/win03

C。然后我们再创建一个所有用户都能看共享的目录,也就是说,所有的用户都能写入,读取,执行。我就是把这个目录用来做windows机器软件安装的基地了。哈。。。

我们还是按照上面步骤A的样子,在[create share]上输入share, 对于名字来说,我们还是不要用太长的,否则测试通不过,可能是最多只有8个字节,所以我就用最简单的了。点到为止。

comment win and linux share

path /share

guest accoun nobody

read only No

guest ok Yes

browseable Yes

available Yes


这样就行了。。。

关于打印方面的,以linux的机器上的打印机,还是大家一起来研究吧。我安装成功了,可是windows打印东西,总是出乱码。所以在这里我就不说如何设置了。我成功了,再补充。


4]测试配制文件是否正确

[root@linuxsir01 root]# testparm
Load smb config files from /etc/samba/smb.conf
Processing section "[homes]"
Processing section "[printers]"
Processing section "[share]"
Processing section "[win03]"
Processing section "[win02]"
Loaded services file OK.
Press enter to see a dump of your service definitions

如果出现上面样子的,就差不多了,如果有警告之类的,可能问题出现在[share]那一步中,可能名字太长了,不要超过8个字节。否则通不过

5]重新启动smb

[root@linuxsir01 root]# /etc/rc.d/init.d/smb restart
关闭 SMB 服务:                                            [  确定  ]
关闭 NMB 服务:                                            [  确定  ]
启动 SMB 服务:                                            [  确定  ]
启动 NMB 服务:                                            [  确定  ]

如果不成功,再试一下,或者找一下配制文件方面的问题。



四。创建议系统的用户和密码,以及smb的密码。

1.创建系统用户

[root@linuxsir01 root]# useradd win02

[root@linuxsir01 root]# useradd win03

2.创建系统用户的密码

[root@linuxsir01 root]# userpasswd win02

然后就是输入密码了。。。这个应该简单,没有什么难度才对。比如我们用oTimsinm


[root@linuxsir01 root]# userpasswd win03

这个也是一样的。。

五。创建win02的win03的用户名在smb的密码。

1]生成密码文件


[root@linuxsir01 root]# cat /etc/passwd | mksmbpasswd.sh > /etc/samba/smbpasswd

2]更改密码文件,我们要把除了win02与win03以外的用户全都删除。只留win02和win03两行。

3]创建win02的win03用户的smb密码,密码要与创建系统用户名的密码一样。比如我们上面说的oTimsinm。
[root@linuxsir01 root]# smbpasswd win02
New SMB password:在这里输入oTimsinm

我们用同样的方法创建win03的smb密码。

以下的工作就差windows机器的设置了,这也比较简单。

4]我们改变一下/share目录的权限。让所有的用户都可以读写和执行

[root@linuxsir01 root]# chmod 777 /share

当然这是不安全的作法,如果想限制一下权限,您可以试一下,就明白了。。。



六。windows机器的设置。

1]创建windows下的用户和密码。

因为我们在[Global]中设置的是user共享方式 ,也就是说,要用windows用户名来验证。说明白一点就是windows的必须设置一个与linux机器上完全相同的用户,密码也必须一致。

这种方式就是samba密码服务验证,我们在前面已经为win02和win03在linux的服务器上创建了系统用户名和密码,也创建了smb的密码。所以我们在这步中也要在windows机器上创建win02和win03两个用户。我这样说,也不知道能不能说明白,工作组,我们也用MSHOME吧。

在windows机器上创建win02和win03两个用户。如果有两台机器windows机器,那就太好了,一台一个。呵。。。。密码还和在linux机器上的win02与win03一样。

切记,否则通不过验证。计算机其实很听话,一步一步的来就OK了。


2]在windows的机器上,添加网络协议,把IPX/SPX以及NETBEUI两个协议加入。这个应该更简单。。。

3。把windows机器上的磁盘或者文件夹共享。这也比较简单。


七。在linux的机器上操作下面的命令,查看一下每台机器的

1.咱们先查看一下linux服务器的smb的情况。最好用IP来查看。。。。


[root@linuxsir01 root]# smbclient -L 192.168.0.1
added interface ip=192.168.0.1 bcast=192.168.0.255 nmask=255.255.255.0
added interface ip=192.168.0.2 bcast=192.168.0.255 nmask=255.255.255.0
Password:在这里,我们按两下回车就行了。。不要添什么密码。
Anonymous login successful
Domain=[MSHOME] OS=[Unix] Server=[Samba 2.2.5]

        Sharename      Type      Comment
        ---------      ----      -------
        homes          Disk      Home Directories
        share       Disk      win linux share
        epsonc40       Printer
        win03          Disk
        win02          Disk      win02 home
        IPC$           IPC       IPC Service (Samba Server)
        ADMIN$         Disk      IPC Service (Samba Server)

        Server               Comment
        ---------            -------
        LINSIR01             Samba Server
        LINUXSIR02

        Workgroup            Master
        ---------            -------
        MSHOME               LINSIR01

如果在linux的机器上看到最下面一行,可能就有点不对了。因为共享中没有我们在[Global]中设置的LINSIR01,所以共享一般不会成功。


下面这个我是查看一台windows的机器情况;

[root@linuxsir01 root]# smbclient -L 192.168.0.8

added interface ip=192.168.0.1 bcast=192.168.0.255 nmask=255.255.255.0
added interface ip=192.168.0.2 bcast=192.168.0.255 nmask=255.255.255.0
session request to 192.168.0.8 failed (Called name not present)
session request to 192 failed (Called name not present)
Password:
Anonymous login successful
Domain=[MSHOME] OS=[Windows 5.0] Server=[Windows 2000 LAN Manager]

        Sharename      Type      Comment
        ---------      ----      -------
Error returning browse list: NT_STATUS_ACCESS_DENIED

        Server               Comment
        ---------            -------
        LINUXSIR02
        LINUXSIR03

        Workgroup            Master
        ---------            -------
        MSHOME               LINUXSIR03

具体说明的是什么,如果您不理解,请查看man或者其它资料。以后我在此文件中慢慢的补充吧。。


2.我们在windows的网络邻居上。添加网络邻居。前提是要以win02用户在windows机器上登入。然后。。。。

在网络邻居的位置中输入\\linsir01\win02。这样就行了。。。

win03呢。也是一样的。。。也必须在windows机器上以win03登入。

输入用户名和密码就行了,下次,我们再登录查看时,就不再需要输入用户名和密码了,这是在win2000里的;如果在win98中,因为系统只是提示密码。如果用户名和密码和linux上机器的win02或者win03的用户对不上,就没有办法登入。当然windows 98的用户win02想查看linux机器win02的文件夹的内容,在windows下必须以win02登入。

访问linux的share文件夹呢,我们也一样这样在网络邻居中输入

\\linsir01\share

这个咱们在前面已经说过了,作何人都有读写以及执行的权限。也就是说完全共享的。windows或者linux的用户,无论谁都有权限操作这里的任何文件。

那linux的机器如何查看windows机器上的共享文件呢。有时间我再来写一下,不过还是用下面这个软件比较方便。。

LinNeighborhood-0.6.2-1.i386.rpm

这个包,是我在Redhat 8.0 下编译的。在Redhat下应该没有任何问题。

下载后,解压和安装

#tar zxvf L*.tar.gz
#rpm -ivh LinNeighborhood-0.6.2-1.i386.rpm

运行命令,应该是
#LinNeighborhood
多后就是点几下鼠标,设置一下就行了。试一下也没有什么难的。

可能前面写的不太严谨,有可能有的地方不太对。请大家指正。我也会随时修改本帖。

多谢。
发表于 2002-12-15 10:57:07 | 显示全部楼层
GOOD 真不错
发表于 2002-12-15 17:02:50 | 显示全部楼层

查看网上邻居

查看网上邻居.对方是win98.
发表于 2002-12-15 17:14:16 | 显示全部楼层
你的smbclient装了吗?
rpm -qa |grep samba-client
有的话用smbclient -L 对方ip
发表于 2002-12-15 22:55:42 | 显示全部楼层
北南太好了,我要好好看,希望能够解决我的郁闷问题,谢谢北南:-)
发表于 2002-12-16 01:04:25 | 显示全部楼层
应该是三而.rpm包!
samba-common
samba-client
samba
依此安装...
你是不是少安了一个?
发表于 2002-12-20 13:15:42 | 显示全部楼层

help!!!!!!

我的是linux 系统,我能用我同学的98远程登陆我的linux吗?
也就是说98与linux能实现联机吗?
发表于 2002-12-20 13:34:29 | 显示全部楼层
能, 去网络版搜索samba找一找有关的贴子
发表于 2002-12-24 17:07:47 | 显示全部楼层
我按照上面的方法试了一下,挺好的!

在linux下可以 看到2000下的机器上的文件.
但是,在2000下和98下,能看到linux机器,但无法进入,能帮帮忙吗?
发表于 2002-12-24 18:04:13 | 显示全部楼层
兄弟,看看这个贴子,希望能够对你有所帮助,我曾经遇到过的郁闷问题
http://www.linuxsir.net/bbs/show ... 15&pagenumber=2
您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表