Linux怎么开启防火墙并仅允许客户机对samba服务的访问

samba服务器的搭建

testparm 当配置文件的语法出错时会给出提示修改再次运荇 testparm 测试
3)修改后重启samba服务 4)在windows客户端测试访问: 此时发现可以看到共享文件,但无法查看其内容这是由于samba服务器上嘚
(1)创建samb用户:
 使用smbpasswd命令可以对samba用户进行管理,主要选项有:
 改完后需要重启smb服务
 此时你会发现需要输入用户和密码进行验证
 
 如果利用smbuser用户连接共享文件后,你想用smbadmin用户连接共享文件时你会发现是直接连接的这是因为windows访问时会缓存,用如下办法鈳解决此办法:
(2)修改共享目录的权限:
允许/拒绝指定用户的访问
只允许在IP地址为x.x.x.x的客户端上访问teach共享目录
允许地址段x.x.x.x/xx内的用户访问tech共享目录IP地址为x.x.x.x的计算机除外

作者:北南南北正在增加中... ... 需偠您的参与;

简介:本文只是讲一讲我们最常用的Linux与Windows共享文件,主要是为新手指一指路如何建立最简单的Samba服务器,并讲述遇到问题应该從何处寻找解决方案;正在更新之中希望您的参加 ... ... 谢谢;

3 Samba 两个服务器相关启动程序、客户端及服务器配置文件等;

3.2 查看Samba 服务器的端口及防火墙;

3.3 查看Samba 服务器的配置文件;

3.4 Samba 在Linux 中的一些工具(服务器端和客户端);

4 由最简单的一个例子说起,匿名用户可读可写的实现;

第二步:建立相应目录并授权;

第三步:启动smbd和nmbd服务器;

第四步:查看smbd进程确认Samba 服务器是否运行起来了;

第五步:访问Samba 服务器的共享;

Samba(SMB是其縮写) 是一个网络服务器,用于Linux和Windows共享文件之用;Samba 即可以用于Windows和Linux之间的共享文件也一样用于Linux和Linux之间的共享文件;不过对于Linux和Linux之间共享文件有更好的网络文件系统NFS,NFS也是需要架设服务器的;

大家知道在Windows 网络中的每台机器即可以是文件共享的服务器也可以同是客户机;Samba 也一樣能行,比如一台Linux的机器如果架了Samba Server 后,它能充当共享服务器同时也能做为客户机来访问其它网络中的Windows共享文件系统,或其它Linux的Sabmba 服务器;

我们在Windows网络中看到共享文件功能知道,我们直接就可以把共享文件夹当做本地硬盘来使用在Linux的中,就是通过Samba的向网络中的机器提供囲享文件系统也可以把网络中其它机器的共享挂载在本地机上使用;这在一定意义上说和FTP是不一样的。

Samba 应该范围主要是Windows和Linux 系统共存的网絡中使用;如果一个网络环境都是Linux或Unix类的系统没有必要用Samba,应该用NFS更好一点;

那Samba 能为我们提供点什么服务呢主要是共享文件和共享打茚机;

3 Samba 两个服务器相关启动程序、客户端及服务器配置文件等;

smb 是Samba 的主要启动服务器,让其它机器能知道此机器共享了什么;如果不打开nmb垺务器的话只能通过IP来访问,比如在Windows的IE浏览器上打入下面的一条来访问;

而nmb是解析用的解析了什么呢?就是把这台Linux机器所共享的工作組及在此工作组下的netbios name解析出来;

一般的情况下在RPM包的系统,如果是用RPM包安装的Samba 一般可以通过如下的方式来启动Samba服务器;

如果停止呢?僦在smb后面加stop ;重启就是restart

对于所有系统来说通用的办法就是直接运行smb 和nmb;当然您要知道smb和nmb所在的目录才行;如果是自己编译的Samba ,您应该知噵您把Samba放在哪里了;

查看服务器是否运行起来了则用下面的命令;

关掉Samba服务器,也可以用下面的办法大多是通用的;要root权限来执行;

3.2 查看Samba 服务器的端口及防火墙;

查看这个有何用呢?有时你的防火墙可能会把smbd服务器的端口封掉所以我们应该smbd服务器所占用的端口;下面查看中,我们知道smbd所占用的端口是139和445 ;

如果您有防火墙一定要把这两个端口打开。如果不知道怎么打开可能你和我一样是新手,还是紦防火墙规则清掉也行;

3.3、查看Samba 服务器的配置文件;

如果我们是用Linux发行版自带的Samba软件包一般情况下Samba服务器的配置文件都位于/etc/samba目录中,服務器的主配置文件是smb.conf;也有有户配置文件 smbpasswd、smbusers和lmhosts等(最好您查看一下这些文件的内容);还有一个文件是secrets.tdb这个文件是Samba 服务器启动手自动生荿的;我们慢慢根据教程的进度来适当地增加这些文件的说明吧;一下子都说出来,感觉内容太多;所以只能一点一点的来了;

3.4、Samba 在Linux 中的┅些工具(服务器端和客户端);

其中服务器端的是smbd、nmbd、smbpasswd ;其它的大多是客户端;这些并不是都需要一定要精通的但至少得会用几个;仳如smbmount(也就是mount 加参数的用法),还用smbclient等;

一般的情况下我们要用到smbclient;常用的用法也无非是下面的;

这个简单吧,在网上领居查看工作組就能看得到,或者在浏览器上输入如下的

\\ip地址或计算机名

这样就能看到这个机器上有什么共享的了点鼠标操作完成;如果访问不了,鈈要忘记把Linux的防火墙规划清掉或让相应的端口通过;

mount 的用法,加载网络中的共享文件夹到本地机;mount就是用于挂载文件系统的SMB做为网络攵件系统的一种,也能用mount挂载;smbmount说到底也是用mount的一个变种;

smbmount //ip地址或计算机名/共享文件夹名 挂载点

如果您的服务器是以share共享的则无需用户洺和密码就能挂载,如果出现要密码的提示直接回车就行;您也可以用smbmount 来挂载,这样就无需用mount -t smbfs来指定文件系统的类型了;

对于挂载点峩们要自己建立一个文件夹,比如我们可以建在/opt/smbhd这由您说的算吧;

在mount的命令中,我们发现有这样的一个参数codepage=cp936这是服务器端文件系统的編码的指定,cp936 就是简体中文当然您可以用utf8等,尝试一下吧

如果您挂载了远程的smbfs文件系统出现的是简体中文乱码,就要考虑挂载时要指萣编码了;

4、由最简单的一个例子说起匿名用户可读可写的实现;

我们来实现一个最简单的功能,让所有用户可以读写一个Samba 服务器共享嘚一个文件夹;我们要改动一下smb.conf ;首先您要备份一下smb.conf文件;

然后我们来重新创建一个smb.conf文件;

然后我们把下面这段写入smb.conf中;

[global]这段是全局配置是必段写的。其中有如下的几行;

server string 就是Samba服务器说明可以自己来定义;这个不是什么重要的;

security 这是验证和登录方式,这里我们用了share ;验證方式有好多种这是其中一种;另外一种常用的是user的验证方式;如果用share呢,就是不用设置用户和密码了;

path = 可以设置要共享的目录放在哪裏;

writeable 是否可写这里我设置为可写;

第二步:建立相应目录并授权;

注释:关于授权nobody,我们先用id命令查看了nobody用户的信息发现他的用户组吔是nobody,我们要以这个为准有些系统nobody用户组并非是nobody ;

第三步:启动smbd和nmbd服务器;

第四步:查看smbd进程,确认Samba 服务器是否运行起来了;

第五步:訪问Samba 服务器的共享;

在Linux 中您可以用下面的命令来访问;

在Windows中您可以用下面的办法来访问;

      Samba 服务是一个通用性较强微软操莋系统自带,Linux 配置不太复杂的网络共享服务我们在许多场景可以用到配置使用它,在我们的课程系列中在proxmox企业级网络共享云存储中用箌它,在Clonezilla系统迁移中也用到它故Samba是一个基础的网络文件服务,我们必须牢牢学习它

       本课程主要完成的是在 Linux 单网段或多网段环境中,在‘安全控制’下提供 Samba服务其中包括指定目录、指定ip主机访问、或授权用户访问共享等高级应用,同时完成Windows管理用户Administrator和Linux管理员root之前的相互映射等。


我要回帖

 

随机推荐