Samba 安装及简单配置、windows访问linux的简单例子2008-01-21 15:30由于在安装rhel5的时候没哟安装到好Samba,现在只能从新安装了。
郁闷啊!(在init.d中没有发现smb和nmb这两个文件)还好在安装盘里能够找到安装文件。
这里就不说了(一堆samba开头的文件。
一阵狂点就行了。
呵呵……)1.查看系统默认的Linux samba版本号登录FEDORA10后,使用1[root@localhost ~] whereis samba2samba: /etc/samba /usr/lib/samba /usr/share/man/man7/samba.7.gz3[root@localhost ~] rpm qa samba4samba3.2.40.22.fc10.i3865[root@localhost ~]已经安装了Linux samba3.2.4版本,不需要再手工安装,这是系统默认装的,可以用service smb start启动samba服务;查找samba是否安装好rpm -qa|grep samba,如果有安装会出现samba-common-2.2.7a-7.9.0samba-client-2.2.7a-7.9.0samba-2.2.7a-7.9.0没有安装的话,可以:Yum -y install samba安装了所需的Samba服务器软件后就可以启动Samba服务了。
在命令行中输入service smb start命令即可重启Samba服务,如图7-4所示。
它同时启动了两项服务:SMB服务(也就是Samba服务)和NMB(NetBIOS Message Block,NetBIOS消息块)服务。
SMB服务是Samba 的主要服务,它让其他机器能知道此机器共享了什么;NMB服务可以通过主机名代替IP地址来访问局域网里的主机,就是把这台Linux机器所共享的工作组及在此工作组下的NetBIOS name解析出来。
如果不打开NMB服务器,则只能通过IP来访问。
(点击查看大图)图7-4 成功启动Samba服务的命令输出在正式配置Samba服务器之前,需要查看/etc/services文件中以netbios开头的记录。
如果这些记录前有#号或者没有这些记录,则用户无法访问Samba服务器上的共享资源。
可以用cat 命令结合grep命令直接在终端窗口中单独显示这些记录,只需在终端提示符下输入以下命令,正确的结果显示应如图7-5所示:cat /etc/services | grep netbios(点击查看大图)图7-5 显示/etc/services文件中包含netbios字符语句的输出结果Samba 两个服务器相关启动程序、客户端及服务器配置文件Samba 有两个服务器,一个是smb,另一个是nmbsmb 是Samba 的主要启动服务器,让其它机器能知道此机器共享了什么;如果不打开nmb服务器的话,只能通过IP来访问,比如在Windows的IE浏览器上打入下面的一条来访问而nmb是解析用的,解析了什么呢?就是把这台Linux机器所共享的工作组及在此工作组下的netbios name解析出来;一般的情况下,在RPM包的系统,如果是用RPM包安装的Samba ,一般可以通过如下的方式来启动Samba服务器;[root@localhost ~]# /etc/init.d/smb start启动 SMB 服务: [ 确定 ]启动 NMB 服务: [ 确定 ]如果停止呢?就在s mb后面加stop ;重启就是restart[root@localhost ~]# /etc/init.d/smb stop[root@localhost ~]# /etc/init.d/smb restar对于所有系统来说,通用的办法就是直接运行smb 和nmb;当然您要知道s mb和nmb所在的目录才行;如果是自己编译的Samba ,您应该知道您把Samba放在哪里了;[root@localhost ~]# /usr/sbin/smbd[root@localhost ~]# /usr/sbin/nmbd查看服务器是否运行起来了,则用下面的命令;[root@localhost ~]# pgrep smbd[root@localhost ~]# pgrep nmbd关掉Samba服务器,也可以用下面的办法,大多是通用的;要root权限来执行;[root@localhost ~]# pkill smbd[root@localhost ~]# pkill nmbd其中有些服务可以在系统--》管理中进行相关的设置查看Samba 服务器的端口及防火墙;查看这个有何用呢?有时你的防火墙可能会把smbd服务器的端口封掉,所以我们应该smbd服务器所占用的端口;下面查看中,我们知道smbd所占用的端口是139和445 ;[root@localhost ~]# 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@localhost ~]# iptables -F或[root@localhost ~]# /sbin/iptables -F在Windows中访问Linux Samba服务器共享文件的办法;这个简单吧,在网上领居,查看工作组就能看得到,或者在浏览器上输入如下的\\ip地址或计算机名这样就能看到这个机器上有什么共享的了,点鼠标操作完成;如果访问不了,不要忘记把Linux的防火墙规划清掉,或让相应的端口通过;说明:如果您的服务器是以share共享的,则无需用户名和密码就能挂载,如果出现要密码的提示,直接回车就行;您也可以用smbmount 来挂载,这样就无需用mount -t smbfs来指定文件系统的类型了;匿名用户可读可写的实现;第一步:更改smb.conf我们来实现一个最简单的功能,让所有用户可以读写一个Samba 服务器共享的一个文件夹;我们要改动一下smb.conf ;首先您要备份一下smb.conf文件;[root@localhost ~]# cd /etc/samba[root@localhost samba]# mv smb.conf smb.confBAK然后我们来重新创建一个smb.conf文件;[root@localhost samba]#touch smb.conf然后我们把下面这段写入smb.conf中;[global]workgroup = LinuxSirnetbios name = LinuxSir05server string = Linux Samba Server TestServersecurity = share[linuxsir]path = /opt/linuxsirwriteable = yesbrowseable = yesguest ok = yes注解:[global]这段是全局配置,是必段写的。
其中有如下的几行;workgroup 就是Windows中显示的工作组;在这里我设置的是LINUXSIR (用大写);netbios name 就是在Windows中显示出来的计算机名;server string 就是Samba服务器说明,可以自己来定义;这个不是什么重要的;security 这是验证和登录方式,这里我们用了share ;验证方式有好多种,这是其中一种;另外一种常用的是user的验证方式;如果用share呢,就是不用设置用户和密码了;[linuxsir] 这个在Windows中显示出来是共享的目录;path = 可以设置要共享的目录放在哪里;writeable 是否可写,这里我设置为可写;browseable 是否可以浏览,可以;可以浏览意味着,我们在工作组下能看到共享文件夹。
如果您不想显示出来,那就设置为browseable=noguest ok 匿名用户以guest身份是登录;第二步:建立相应目录并授权;[root@localhost ~]# mkdir -p /opt/linuxsir[root@localhost ~]# id nobodyuid=99(nobody) gid=99(nobody) groups=99(nobody)[root@localhost ~]# chown -R nobody:nobody /opt/linuxsir注释:关于授权nobody,我们先用id命令查看了nobody用户的信息,发现他的用户组也是nobody,我们要以这个为准。
有些系统nobody用户组并非是nobody ;第三步:启动smbd和nmbd服务器;运行"testparm”以检测smb.conf文件是否有错.10. 执行“service smb restart” 重新启动samba.11. 确认Fedora的Firewall没有禁止samba的文件共享.[root@localhost ~]# smbd[root@localhost ~]# nmbd第四步:查看smbd进程,确认Samba 服务器是否运行起来了;[root@localhost ~]# pgrep smbd1356413568访问Samba 服务器的共享;在Windows中,可以直接像访问其他windows用户一样本文资料来自/main/?q=node/158如果在访问Samba服务器的共享文件时XP出现了蓝屏的情况,将防火墙中的SELinux禁用就可以了。
或者你可以自己编译一个稳定的Samba在ubuntu下的chmod 777 的一个小技巧应用今天在使用ubuntu的时候即兴发挥,知道了一个小技巧。
虽然在别人看到可能是幼稚可笑的,可是对于我相当于试验成功了,总结到了点技术知识很实在。
在使用chmod777 让某些文件夹或者文件有读写的完全权限的时候,如果必须批量处理,比如里面一个文件夹php_100,里面又有着77个文件夹,而这77个文件夹各自又有一些小文件,包括图片,.php的文件,要让这些都有读写权限,可以依次一个个去弄,sudo chmod 777 * 这样就可以,可是太过于麻烦且效率低下。
所以可以换歌写法,用sudo chmod 777 */* 这样写,就可以让某文件夹下的所有文件夹包括各个文件夹下面的所有文件(图片文件,php文件,文本文件等等),都赋予了777(可读写权限)权限了。