Samba 介绍

Samba 安装

  • 查看是否已安装:

    • CentOS:rpm -qa | grep samba
    • Ubuntu:dpkg -l | grep samba
  • 安装:

    • CentOS 6:yum install samba samba-client samba-common
    • Ubuntu:sudo apt-get install -y samba samba-client

Samba 服务器配置文件常用参数

  • 配置文件介绍(记得先备份 cp /etc/samba/smb.conf /etc/samba/smb.conf.backup):sudo vim /etc/samba/smb.conf

    • 该配置解释:

      • 在 [global] 区域
        • workgroup = WORKGROUP #WORKGROUP表示Windows默认的工作组名称,一般共享给windows是设置为WORKGROUP,此字段不重要,无需与 Windows 的域保持一致
        • security = user #ubuntu下配置文件默认没有这句,这个是自己填上去的。表示指定samba的安全等级,安全等级分别有四种:share(其他人不需要账号密码即可访问共享目录)、user(检查账号密码)、server(表示检查密码由另外一台服务器负责)、domain(指定Windows域控制服务器来验证用户的账号和密码) 注: samba 4 不再支持 security = share (查看版本 smbd —version)
      • 在新区域区域
        • 当 security = share 使用下面这段,这段自己添加的,其中myshare这个名字表示其他机子访问该分享地址时用:file://该服务机IP/myshare
          1. [myshare]
          2. comment = share all
          3. path = /opt/mysamba #分享的目录,其中这个目录需要chmod 777 /opt/mysamba权限
          4. browseable = yes
          5. writable = yes
          6. public =yes
        • 当 security = user 使用下面这段,这段自己添加的,其中 myshare2 这个名字表示其他机子访问该分享地址时用:file://该服务机IP/myshare2
        • 可以返回的账号必须是系统已经存在的账号。先给系统添加账号:useradd user1,再用samba的设置添加账号:pdbedit -a user1,会让你设立该samba账号密码。列出账号:pdbedit -L
          1. [myshare2]
          2. comment = share for users
          3. path = /opt/mysamba2 #分享的目录,其中这个目录需要chmod 777 /opt/mysamba权限
          4. # (不一定要 777 权限,只要登录 samba 的用户是这个目录的用户即可,那么在 Windows 中的文件创建和写入都等同于 linux 的等价账户)
          5. browseable = yes
          6. writable = yes
          7. public = no
          8. read only = no
          9. guest ok = no # samba 4 拥有的
          10. create mask = 0646
          11. force create mode = 0646
          12. directory mask = 0747
          13. force directory mode = 0747
    • 一份成功的 samba 4 配置

      1. [global]
      2. workgroup = WORKGROUP
      3. passdb backend = tdbsam
      4. printing = cups
      5. printcap name = cups
      6. printcap cache time = 750
      7. cups options = raw
      8. map to guest = Bad User
      9. include = /etc/samba/dhcp.conf
      10. logon path = \\%L\profiles\.msprofile
      11. logon home = \\%L\%U\.9xprofile
      12. logon drive = P:
      13. max connections = 0
      14. deadtime = 0
      15. max log size = 500
      16. [share1]
      17. path = /home/<your path>
      18. browsable =yes
      19. writable = yes
      20. read only = no
      21. guest ok=no
      22. create mask = 0646
      23. force create mode = 0646
      24. directory mask = 0747
      25. force directory mode = 0747
  • 启动服务(CentOS 6、Ubuntu):
    • sudo service samba restart
    • service smb restart # 启动 samba
  • 启动服务(CentOS 7):
    • systemctl start smb.service # 启动 samba
    • systemctl enable smb.service # 激活
    • systemctl status smb.service # 查询 samba 状态(启动 samba 前后可以用查询验证)

Samba 登录及验证

  • 在 Windows 连接 Samba 之前,可在本地(linux)使用命令验证

    smbclient –L //localhost/<your samba share label> -U <your samba user> 接下来输入的 password 来自于 pdbedit -a user1 命令为该用户设置的密码,不一定是 linux 用户密码 来自 /etc/samba/smb.conf 文件中的标签,如上面的例子中有 //localhost/myshare2

    提示如下面,表示 Samba 服务启动成功

    1. Domain=[xxx1] OS=[Windows 6.1] Server=[Samba 4.6.2]
    2. Sharename Type Comment
    3. --------- ---- -------
    4. share1 Disk
    5. IPC$ IPC IPC Service (Samba 4.6.2)
    6. Domain=[xxx1] OS=[Windows 6.1] Server=[Samba 4.6.2]
    7. Server Comment
    8. --------- -------
    9. Workgroup Master
    10. --------- -------
    11. xxx2 xxx1
    12. WORKGROUP xxx3
  • Windows 登录 打开资源管理器 -> 映射网络驱动器 -> 文件夹 填写上述 smbclient –L 命令后面加的路径 -> 弹出用户名密码对话框 -> 登录成功

Samba 登录失败

  • linux 防火墙

  • Windows 用户密码都正确,错误提示‘未知的用户名和密码。’ regedit 打开注册表,删除键值 HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\Lsa 中的 LMCompatibilityLevel,无需重启计算机

Samba 资料