SAMBA 的实现原理以及使用方法

一.SAMBA的起源

对于windows的网上邻居来讲,共享文件的方式用的是SMB和CIFS协议以及NETBIOS协议Linux/Unix之间用的是NFS协议。

但是Linux和Windows之间是不能共享的,所以澳大利亚国立大学的Andrew Tridgell,决定开发一款软件,这款软件就是为了实现不同的系统之间互相共享文件的,于是一款叫做SMB的软件横空出世了,但是这个名字不能被注册成商标,因为已经有SMB协议了,于是作者给名字上加了两个A,就成了我们即将使用的功能强的文件共享服务器

SAMBA

二.SAMBA的工作方式

SAMBA主要提供的是SMB/CIFS或者NETBIOS协议的。

所以只要使用了SAMBA,就能实现让Linux出现在Windows的网上邻居里,或者,让Windows的文件共享在Linux上--

一旦在linux上安装之后,有两个主要进程:

1.nmbd :提供NETBIOS 名称解析的

2.smdb : 提供文件共享的。

而由于NETBIOS协议对于windows来讲监听TCP的139端口和UDP的137,138端口 ,所以nmbd在linux上模拟出了udp的137和138端口,以及tcp的139端口,smdb上模拟出 tcp的445端口。而SAMBA将在Linux上同时监听这4个端口。 

三.认识SAMBA

SAMBA的软件都是”samba”开头的

        

SAMBA 的实现原理以及使用方法

         samba-client

         samba-common  这两个都是作为客户端使用的

         samba作为服务端使用

         samba-swat 基于图形的一个控制界面

                           

         安装完后,它的配置文件在 /etc/samba/smb.conf              

         而/etc/init.d/smb 脚本,实现了对于SAMBA的控制

         比如:/etc/init.d/smb start

小提醒:samba是一款接受selinux控制的软件,所以配置的时候一定要关闭selinux

四.安装并简单配置SAMBA

         1.安装:

         yum install samba -y

        

         安装完成之后在/etc/samba目录下

         主配置文件叫 smb.conf

                   小提醒:

                   这类文件里所有 以#开头的都是注释没意义

                   所有以“;”开头的都是可以去掉以启动的选项

                           

         2.配置:

                   配置文件主要有4个段组成:

                   1.全局配置段 [global]

                   2.家目录段[homes]

                   3.独立的共享段[printer]

                   4.自定义段[c_s]     

                  

         我们一段一段的来分析

         第一段:[global]:

                   workgroup = MYGROUP           定义工作组的

                   server string = Samba Server Version %v         这是用于当你通过网上邻居打开的时候,注释信息是什么

                   netbios name = XXX     显示在终端中的名字

                   security = user          这一项很关键,是用来定义SAMBA服务的安全级别的,安全级别主要有4个

                                     1.share:允许任何匿名用户直接访问

                                     2.user:默认:每一个用户访问的时候必须要提供账号和密码

                                     3.domain/server:通常意味着把用户的账号和密码在认证的时候是通过第三方集中的认证的。而不是直接通过系统来认证,比如有一个专门的认证服务器

                                     4.ads:通过主域控制器来认证的

                   passdb backend = tdbsam     所有的SAMBA用户的认证文件使用什么方式认证

                   load printers = yes    是否去尝试加载打印机

                   cups options =raw    通用打印系统,指定打印方式

                   hosts allow = XX.XX.XX.XX   定义访问控制列表

                                                       

         第二段:[homes]:

                   comment = Home Directories          说明信息

                  browseable = no     浏览,如果这个用户不是这个目录的属主的话,是否可以看到这个目录的,no表示只有属主才能看到

                   writable =yes     是否可以往里新建文件的。

 

         第三段:[printers]:

                   comment = All Printers

                   path = /var/spool/samba         打印池

                   browseable = no 

                   guest ok = no  打印机是否公开

                   writable = no  

                   printable = yes

                  

         第四段:我们定义一个自己的:[tools] 

                           中括号括起来的叫共享名

                   comment = My Tools

                   path = /share    用于定义在系统目录上真正的那个目录在什么地方

                   browseable = yes  是否可浏览

                   guest ok = yes  是否允许来宾账号

                   writable = yes 是否可写

         #       write list = XXX   定义一个列表决定用户/组是否可以写,定义组的时候,需要用 @组名

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://127.0.0.1/wyyfsd.html