科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网网络频道如何架设Samba服务器,用user共享方式

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

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

在Windows中,我们都知道网络邻居,是Windows共享资源的方式。Linux写Windows互访与共享资源的方式是利用Samba服务,其实我觉得它更象一个软件。

作者:巧巧读书 来源:巧巧读书 2008年6月23日

关键字: 网吧 网吧组网 网吧服务器架设

  • 评论
  • 分享微博
  • 分享邮件

  一点理论:

  在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

  多后就是点几下鼠标,设置一下就行了。试一下也没有什么难的。

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

  多谢。

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章