zoukankan      html  css  js  c++  java
  • Samba安装配置

    Samba简介

    Samba官网:http://www.samba.org
    SMB(Server Messages Block,信息服务块)是一种在局域网上共享文件和打印机的一种通信协议,它为局域网内的不同计算机之间提供文件及打印机等资源的共享服务。SMB协议是客户机/服务器型协议,客户机通过该协议可以访问服务器上的共享文件系统、打印机及其他资源。通过设置“NetBIOS over TCP/IP”使得Samba不但能与局域网络主机分享资源,还能与全世界的电脑分享资源。

    启动服务:# /etc/rc.d/init.d/smb start

    Samba有两个守护进程:smbd和nmbd
    1.smbd监听139TCP端口       smbd进程的作用是处理SMB请求包,负责用户验证和文件共享;
    2.nmbd监听137和138UDP端口  nmbd进程的作用是处理浏览共享和计算机名称解析;


    一、查看samba服务状态
        # rpm -qa | grep samba
        samba-common-3.0.33-3.39.el5_8 --------> 这个是samba通用配置包;
        samba-3.0.33-3.39.el5_8 ---------------> 这个是samba主服务包,如果没有需要安装上;
        samba-client-3.0.33-3.39.el5_8 --------> 这个是samba客户端工具包;

    二、安装samba主服务
        # yum install -y samba

    三、查找samba配置文件所在目录
        # rpm -ql samba-common | grep smb.conf
        /etc/samba/smb.conf ---------------------------------> 配置文件
        /usr/share/man/man5/smb.conf.5.gz

        或:
        # rpm -qc samba-common
        /etc/samba/lmhosts
        /etc/samba/smb.conf ---------------------------------> 配置文件
        /etc/security/pam_winbind.conf

        或:
        # find /etc/ -name smb*
        /etc/gnome-vfs-2.0/modules/smb-module.conf
        /etc/rc.d/init.d/smb --------------------------------> 启动脚本
        /etc/samba/smb.conf ---------------------------------> 配置文件
        /etc/samba/smbusers

    四、配置smb.conf文件
        # cp /etc/samba/smb.conf /etc/samba/BAK.smb.conf  先备份
        # vi /etc/samba/smb.conf                          编辑

        1.配置文件主要结构:

          [global]     设置全局环境选项

           # ----------------------- Network Related Options -------------------------
              # 工作组或域:
              workgroup = MYGROUP

              # Samba服务器描述:
              server string = Samba Server Version %v
           
              # netbios名称:
              ; netbios name = MYSERVER

              # 指定使用的网络接口卡
              ; interfaces = lo eth0 192.168.12.2/24 192.168.13.2/24

              # 允许访问的IP网段列表(★允许优先):
              ; hosts allow = 127. 192.168.12. 192.168.13.
     
              # 禁止访问的IP网段列表(★允许优先):
              ; host deny = 192.168.190 
              注:此处如果某IP段被同时指定了允许和禁止,则最终结果“很违背常规”,是允许优先。

           # --------------------------- Logging Options -----------------------------
              # 按每服务器模式切割日志文件
              # logs split per machine

              # 指定日志文件位置:
              log file = /var/log/samba/%m.log

              # 指定每个日志文件最大字节数
              # max 50KB per log file, then rotate

              # 日志文件最多占用空间:
              max log size = 50

           #============================ Share Definitions ==============================

           [homes]      设置用户宿主目录共享(如果不需要用户通过smb访问自己的宿主目录,将此区块整体注释掉即可;;;)

           [printers]   设置打印机共享(通常不用,将此区块整体注释掉即可;;;)

     
      2.【实验】添加我的共享目录:
         可参考[homes]区块,在配置文件的末尾添加共享目录区块配置信息:

         ####################### 设置我的共享目录 ##########################

         [wwwroot]
         # 指定我的共享目录描述
         comment = wwwroot directory

         # 指定共享目录路径
         path = /wwwroot

         # 设置共享目录对所有用户是否可见:
         browseable = yes

         # 设置共享目录是否可写权限(取与Linux系统对目录权限的交集!逻辑and)
         writable = yes

         # 设置有效访问用户(多个用户空格分开,%S 表示匹配所有用户)
         valid users = martin jack

         ###################################################################


      3.检查配置文件有无语法错误:
        # testparm


    五、查找smb服务启动脚本 并启动之
        1.查找smb服务启动脚本
          # find /etc/ -name smb
          /etc/rc.d/init.d/smb ------------------------> 启动脚本

          或:
          # rpm -ql samba | grep smb
          /etc/rc.d/init.d/smb ------------------------> 启动脚本
          /etc/samba/smbusers
          /usr/bin/mksmbpasswd.sh
          /usr/bin/smbcontrol
          /usr/bin/smbstatus

        2.启动SMB服务:
          # /etc/rc.d/init.d/smb start
          或:
          # service smb start

        3.设置开机自启动:
          # chkconfig --levels 235 smb on


    六、添加smb用户【必须是系统中已存在的用户,假如系统中已经有了一个名为martin的用户】,并设置密码
        # smbpasswd -a martin
        New SMB password:
        Retype new SMB password:

        主要选项解析:
        -a  add user     表示添加SMB用户
        -d  disable user 表示禁用SMB用户
        -e  enable user  表示开启SMB用用户
        -x  delete user  表示删除SMB用户

        注:不加任何参数表示修改现已有SMB用户的密码


    七、windows客户端登录:\192.168.1.xxx


    八、无法登录或无法访问故障排除:
        1.如果SELinux阻止了访问:

          首先查找过滤SELinux关于samba的策略选项:
          # setsebool -a | grep samba

          找到了samba_enable_home_dirs这项,将启设置为on即可:
          # setsebool -P samba_enable_home_dirs on
          # chcon -t samba_share_t /wwwroot/


        2.如果防火墙阻止了访问,先行关闭:
          # iptables -F

        3.如果可以登录却无写权限(假如对用户martin):
          # setfacl -m u:martin:rwx -R /wwwroot/
          # setfacl -m d:u:martin:rwx -R /wwwroot/

        4.【可选】为防止用户删除他人的数据文件,也可对共享目录设置粘着位权限
           # chmod o+t /wwwroot/
           # chmod 1775 /wwwroot/

           取消粘着位权限:
           # chmod o-t /wwwroot/
           # chmod 0775 /wwwroot/


    九、从服务端查看当前所有登录用户信息:
        # smbstatus
        Samba version 3.0.33-3.39.el5_8
        PID     Username      Group         Machine                       
        -------------------------------------------------------------------
        23427   martin        martin        pc           (192.168.10.1)


        查看samba的日志记录:
        # cat /var/log/samba/log.smbd


    十、清除windows本地会话

         方法1: Win7系统找到: 控制面板 -> 用户帐户和家庭安全 -> 凭据管理器
                   选择对应的凭据,然后点击“从保管库中删除”

         方法2: 开始 -> 运行cmd命令:
                  查看所有会话: > net use
                  清除所有会话: > net use * /delete /y
                  注:* 表示所有会话

  • 相关阅读:
    loj2042 「CQOI2016」不同的最小割
    loj2035 「SDOI2016」征途
    luogu2120 [ZJOI2007]仓库建设
    luogu3195 [HNOI2008]玩具装箱TOY
    51nod 1069 Nim游戏 + BZOJ 1022: [SHOI2008]小约翰的游戏John(Nim游戏和Anti-Nim游戏)
    HDU 5723 Abandoned country(最小生成树+边两边点数)
    BZOJ 1497: [NOI2006]最大获利(最大权闭合图)
    51nod 1615 跳跃的杰克
    SPOJ 839 Optimal Marks(最小割的应用)
    UVa 11107 生命的形式(不小于k个字符串中的最长子串)
  • 原文地址:https://www.cnblogs.com/martinzhang/p/3535011.html
Copyright © 2011-2022 走看看