centos 7.0 安装samba配置

来源:互联网 发布:佛跳墙软件下载 编辑:程序博客网 时间:2024/06/05 21:16
在我们使用 Windows 作为客户机的时候,通常有文件、打印共享的需求。作为Windows 网络功能之一,通常可以在 Windows 客户机之间通过Windows Network 固有的功能实现这些要求。然而,通过 Samba 我们也可以让一台 CentOS 主机来兼容 Windows 网络,实现同样的功能,进而充分发挥 CentOS 主机的可用性。
本篇文档主要介绍怎样通过 Samba 服务器的构建实现 Windows 网络中的文件共享。
安装 Samba
首先,通过 yum 来在线安装 Samba 。
[root@sample ~]# yum -y install samba  ← 安装 SambaSetting up Install ProcessSetting up repositories—> Package samba.i386 0:3.0.10-1.4E.9 set to be updatedDownloading Packages:(1/2): samba-common-3.0.1 100% |=========================| 5.0 MB 00:04(2/2): samba-3.0.10-1.4E. 100% |=========================| 13 MB 00:11warning: rpmts_HdrFromFdno: V3 DSA signature: NOKEY, key ID 443e1821Public key for samba-common-3.0.10-1.4E.9.i386.rpm is not installedRetrieving GPG key from http://mirror.centos.org/centos/RPM-GPG-KEY-centos4Importing GPG key 0x443E1821 “CentOS-4 key <centos-4key@centos.org>”Key imported successfullyRunning Transaction TestFinished Transaction TestTransaction Test SucceededRunning TransactionInstalling: samba-common ######################### [1/2]Installing: samba ######################### [2/2]Installed: samba.i386 0:3.0.10-1.4E.9Dependency Installed: samba-common.i386 0:3.0.10-1.4E.9Complete!
配置 Samba
然后,通过编辑 /etc/samba/smb.conf ,根据需求配置 Samba。在这里,本文的原则是只将文件共享应用于内网,并让将要被共享的目录拥有充分的读写权限属性。
[root@sample ~]# vi /etc/samba/smb.conf  ← 编辑 Samba 的配置文件#======================= Global Settings =====================================[global]   ← 找到这一行(全局设置标签),在此行下面添加如下行:dos charset = CP936  ← 将 Windows 客户端的文字编码设置为简体中文 GB2312unix charset = utf8  ← 指定 Samba 所在的 CentOS 服务端新建文件或目录时的编码为 utf8display charset = CP936  ← 指定使用 SWAT(一种通过浏览器控制Samba的工具)时页面的默认文字编码directory mask = 0777  ← 指定新建目录的属性(以下4行)force directory mode = 0777directory security mask = 0777force directory security mode = 0777create mask = 0777  ← 指定新建文件的属性(以下4行)force create mode = 0777security mask = 0777force security mode = 0777workgroup = MYGROUP  ← 找到此行,将工作组名称改为 Windows 网络所定义的工作组名↓workgroup = WORKGROUP  ← 变为此状态,这里以Windows XP 默认的“WORKGROUP”为例; hosts allow = 192.168.1. 192.168.2. 127.  ← 找到此行,去掉行首的“;”,并制定访问限制↓hosts allow = 192.168.0. 127.  ← 变为此状态,指定内网IP地址及本地,只允许这两种情况的访问然后在配置文件的末尾填如下几行,定义公众共享目录:[public]comment = Public Stuffpath = /home/samba  ← 指定共享目录位置public = yeswritable = yes  ← 赋予共享目录写入权限的属性
接下来,创建将要通过 Samba 共享给 Windows 网络的专用目录。
在进行到服务端的连接之前,需要预先对用于登录 Samba 的用户进行设置。这里我们以 CentOS 中 Samba 标准的 Samba 用户数据库管理工具“smbpasswd”为例,创建用于登录 Samba 的用户数据。这里需要注意的一点:用 smbpasswd 才可以创建该用户在 Samba 用户数据库中的信息。
[root@sample ~]# smbpasswd -a centospub  ← 将系统用户 centospub(例)加入到 Samba 用户数据库New SMB password:  ← 输入该用户用于登录 Samba 的密码Retype new SMB password:  ← 再次确认输入该密码Added user centospub.
启动 Samba 服务
在启动 Samba 服务之前,首先将防火墙设置中 Samba 所用到的端口进行开放。有时你的防火墙可能会把smbd服务器的端口封掉,所以我们应该smbd服务器所占用的端口;下面查看中,我们知道smbd所占用的端口是139和445 ;
[root@sample ~]# netstat -tlnp |grep smbtcp 0 0 0.0.0.0:139 0.0.0.0:* LISTEN 10639/smbdtcp 0 0 0.0.0.0:445 0.0.0.0:* LISTEN 10639/smbd如果您有防火墙,一定要把这两个端口打开。如果不知道怎么打开。可能你和我一样是新手,还是把防火墙规则清掉也行;[root@sample ~]# iptables -F或[root@sample ~]# /sbin/iptables -F[root@sample ~]# /etc/rc.d/init.d/iptables restart  ← 重新启动 iptables ,使新的规则生效Flushing firewall rules:          [ OK ]Setting chains to policy ACCEPT: filter   [ OK ]Unloading iptables modules:       [ OK ]Applying iptables firewall rules:      [ OK ]
最后,设置开机启动 Samba 服务。
[root@sample ~]# vi /etc/rc.d/rc.local ← 编辑开机启动rc.local文件touch /var/lock/subsys/local/etc/rc.d/init.d/smb start ← 需启动Samba安装路径注意:我的这个路径是yum安装这些服务得到的路径,填写时要根据自己的安装路径,找不到可以借助whereis命令,主要是找到smb 启动文件。[root@sample ~]# /etc/rc.d/init.d/smb start  ← 启动 Samba 服务Starting SMB services:       [ OK ]Starting NMB services:       [ OK ]
从 Windows 客户端连接到 Samba 服务器
在服务端启动 Samba 服务后,我们就可以从 Windows 客户端通过 Windows 网络连接到 Samba。这里以 Windows XP 为例,说明如下连接过程:
1、从桌面打开“网上邻居”,并点击“查看工作组计算机”选项;
2、确认出现 Samba 服务端的连接,并双击该连接;(本站文档的主机名以 Sample 为例)
3、输入在服务端预先设置好的 Samba 用户的用户名及密码;(用户名同系统用户名,密码需要输入在通过 smbpasswd 为该系统用户设置的Samba 专用的密码。)
4、然后确认能够连接到 Samba 服务器,并出现根目录及 Samba 专用共享目录。
最后,在相应目录进行新建、修改以及删除文件的操作,测试相应权限的可操作性。