摘要:0、架设Samba服务器的前提;Linux是一个多用户的操作系统,对任何服务器的架设与都用户、用户组及权限相关,这是操作的基请看如下
摘要:0、架设Samba服务器的前提;Linux是一个多用户的操作系统,对任何服务器的架设与都用户、用户组及权限相关,这是操作的基础。Samba服务器也不例外,对这些知识的掌握也是极为重要的。在Windows系统上虽然也能架共享...
0、架设Samba服务器的前提;
Linux是一个多用户的操作系统,对任何服务器的架设与都用户、用户组及权限相关,这是操作的基础。Samba服务器也不例外,对这些知识的掌握也是极为重要的。在Windows系统上虽然也能架共享文件服务器,但它的权限控制实在令人不敢恭维。如果我们用Windows系统来架网络共享文件系统,就是点鼠标也能把我们点迷糊了。但在Linux中,我们可以轻松的改一改配置文件,不到几分钟就能建好自己的Samba服务器。哪个更容易,只有你知道;
对于Samba服务器的架设,有的弟兄简单的认为,只要把改一下配置文件,创建好相应的目录就行了。其实并不是这样的,还要深入的工作,比如目录的权限和归属,也就是说能让哪个用户和用户组有读写权。只有把配置文件和共享目录的权限结合起来,才能架好Samba服务器;
1Samba简介
Samba(SMB是其缩写)是一个网络服务器,用于Linux和Windows共享文件之用;Samba即可以用于Windows和Linux之间的共享文件,也一样用于Linux和Linux之间的共享文件;不过对于Linux和Linux之间共享文件有更好的网络文件系统NFS,NFS也是需要架设服务器的;
大家知道在Windows网络中的每台机器即可以是文件共享的服务器,也可以同是客户机;Samba也一样能行,比如一台Linux的机器,如果架了SambaServer后,它能充当共享服务器,同时也能做为客户机来访问其它网络中的Windows共享文件系统,或其它Linux的Sabmba服务器;
我们在Windows网络中,看到共享文件功能知道,我们直接就可以把共享文件夹当做本地硬盘来使用。在Linux的中,就是通过Samba的向网络中的机器提供共享文件系统,也可以把网络中其它机器的共享挂载在本地机上使用;这在一定意义上说和FTP是不一样的。
Samba用的netbios协议,如果您用Samba不成功,
Linux与Windows、Linux和Linux
2Samba功能和应用范围
Samba应该范围主要是Windows和Linux系统共存的网络中使用;如果一个网络都是Linux或Unix类的系统,没有必要用Samba,应该用NFS更好一点;
那Samba能为我们提供点什么服务呢?主要是共享文件和共享打印机;
3Samba两个服务器相关启动程序、客户端及服务器配置文件等;
3.1Samba有两个服务器,一个是smb,另一个是nmb;
smb是Samba的主要启动服务器,让其它机器能知道此机器共享了什么;如果不打开nmb服务器的话,只能通过IP来访问,比如在Windows的IE浏览器上打入下面的一条来访问;
smb:\>ls
说明:登录到Samba服务器上,就可以用smbclient的一些指令,可以象用FTP指令一样上传和下载文件;
smbclient命令说明
命令说明
?或help[command]提供关于帮助或某个命令的帮助
mputfile1file2filen向服务器上传多个文件
3.5.2在Windows中访问LinuxSamba服务器共享文件的办法;
这个简单吧,在网上领居,查看工作组就能看得到,或者在浏览器上输入如下的
\\ip地址或计算机名
这样就能看到这个机器上有什么共享的了,点鼠标操作完成;如果访问不了,不要忘记把Linux的防火墙规掉,或让相应的端口通过;
3.5.3在Linux中smbfs文件系统的挂载;
mount的用法,加载网络中的共享文件夹到本地机;mount就是用于挂载文件系统的,SMB做为网络文件系统的一种,也能用mount挂载;smbmount说到底也是用mount的一个变种;
mount挂载smbfs的用法;
mount-tsmbfs-ocodepage=cp936,username=用户名,password=密码,-l//ip地址/共享文件夹名挂载点
smbmount//ip(地址或计算机名/共享文件夹名,挂载点)
◆说明:如果您的服务器是以share共享的,则无需用户名和密码就能挂载,如果出现要密码的提示,直接回车就行;您也可以用smbmount来挂载,这样就无需用mount-tsmbfs来指定文件系统的类型了;
对于挂载点,我们要自己建立一个文件夹,比如我们可以建在/opt/smbhd,这由您说的算吧;
在mount的命令中,我们发现有这样的一个参数codepage=cp936,这是服务器端文件系统的编码的指定,cp936就是简体中文,当然您可以用utf8等,尝试一下吧。
如果您挂载了远程的smbfs文件系统出现的是简体中文乱码,就要考虑挂载时要指定编码了;
4、由最简单的一个例子说起,匿名用户可读可写的实现;
◆第一步:更改smb.conf
我们来实现一个最简单的功能,让所有用户可以读写一个Samba服务器共享的一个文件夹;我们要改动一下smb.conf;首先您要备份一下smb.conf文件;
[root@localhost~]#cd/etc/samba
guestok=yes
◆注解:[global]这段是全局配置,是必段写的。其中有如下的几行;
workgroup就是Windows中显示的工作组;在这里我设置的是LINUXSIR(用大写);
security这是验证和登录方式,这里我们用了share;验证方式有好多种,这是其中一种;另外一种常用的是user的验证方式;如果用share呢,就是不用设置用户和密码了;
[linuxsir]这个在Windows中显示出来是共享的目录;
Password://注:直接按回车
5、复杂一点的用户共享模型(适合10人左右的小型企业);
比如一个公司有五个部门,分别是linuxsir,sir01,sir02,sir03,sir04。我们想为这家公司设计一个比较安全的共享文件模型。每个用户都有自己的网络磁盘,sir01到sir04还有共用的网络硬盘;所有用户(包括匿名用户)有一个共享资料库,此库为了安全是只读的;所有的用户(包括匿名用户)要有一个临时文件终转的文件夹.......
5.1共享权限设计实现的功能;
1)linuxsir部门具有管理所有SMB空间的权限;
6)还要有一个空间,让所有用户可以写入,能删除等功能,在权限上无,用于公司所有用户的临时文档终转等;
5.2在服务器上创建相应的目录;
[root@localhost~]#mkdir-p/opt/linuxsir
[root@localhost~]#fingerlinuxsir
◆5.3.3添加samba用户,并设置密码;
我们用的方法是先添加用户,但添加的这些用户都是虚拟用户,因为这些用户是不能通过SHELL登录系统的;另外值得注意的是系统用户密码和Samba用户的密码是不同的。如果您设置了系统用户能登入SHELL,可以设置用户的Samba密码和系统用户通过SHELL登录的密码不同。
我们通过smbpasswd来添加Samba用户,并设置密码。原理是通过读取/etc/passwd文件中存在的用户名。
[root@localhostsir01]#smbpasswd-alinuxsir
我也试用过很多的Linux发行版,但是最后定下了Debian,现在就是用Debian6在写评论,相反,我一点也不觉得Debian界面丑,干净,简约。刚刚下载了Debian7(wheezy)testing,正在安装中。
tags:打印机共享不了