# 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 ``` [myshare] comment = share all path = /opt/mysamba #分享的目录,其中这个目录需要chmod 777 /opt/mysamba权限 browseable = yes writable = yes public =yes ``` - 当 security = user 使用下面这段,这段自己添加的,其中 myshare2 这个名字表示其他机子访问该分享地址时用:file://该服务机IP/myshare2 - 可以返回的账号必须是系统已经存在的账号。先给系统添加账号:`useradd user1`,再用samba的设置添加账号:`pdbedit -a user1`,会让你设立该samba账号密码。列出账号:`pdbedit -L` ``` [myshare2] comment = share for users path = /opt/mysamba2 #分享的目录,其中这个目录需要chmod 777 /opt/mysamba权限 # (不一定要 777 权限,只要登录 samba 的用户是这个目录的用户即可,那么在 Windows 中的文件创建和写入都等同于 linux 的等价账户) browseable = yes writable = yes public = no read only = no guest ok = no # samba 4 拥有的 create mask = 0646 force create mode = 0646 directory mask = 0747 force directory mode = 0747 ``` - 一份成功的 samba 4 配置 ``` [global] workgroup = WORKGROUP passdb backend = tdbsam printing = cups printcap name = cups printcap cache time = 750 cups options = raw map to guest = Bad User include = /etc/samba/dhcp.conf logon path = \\%L\profiles\.msprofile logon home = \\%L\%U\.9xprofile logon drive = P: max connections = 0 deadtime = 0 max log size = 500 [share1] path = /home/ browsable =yes writable = yes read only = no guest ok=no create mask = 0646 force create mode = 0646 directory mask = 0747 force directory mode = 0747 ``` - 启动服务(CentOS 6): - `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 前后可以用查询验证) - 启动服务(Ubuntu 16.04.3 -- ljoaquin提供): - `sudo service smbd restart` ## Samba 登录及验证 - 在 Windows 连接 Samba 之前,可在本地(linux)使用命令验证 `smbclient –L //localhost/ -U ` 接下来输入的 password 来自于 `pdbedit -a user1` 命令为该用户设置的密码,不一定是 linux 用户密码 来自 `/etc/samba/smb.conf` 文件中的标签,如上面的例子中有 `//localhost/myshare2` 提示如下面,表示 Samba 服务启动成功 ``` Domain=[xxx1] OS=[Windows 6.1] Server=[Samba 4.6.2] Sharename Type Comment --------- ---- ------- share1 Disk IPC$ IPC IPC Service (Samba 4.6.2) Domain=[xxx1] OS=[Windows 6.1] Server=[Samba 4.6.2] Server Comment --------- ------- Workgroup Master --------- ------- xxx2 xxx1 WORKGROUP xxx3 ``` - Windows 登录 打开资源管理器 -> 映射网络驱动器 -> 文件夹 填写上述 `smbclient –L` 命令后面加的路径 -> 弹出用户名密码对话框 -> 登录成功 ## Samba 登录失败 - linux 防火墙 - Windows 用户密码都正确,错误提示‘未知的用户名和密码。’ regedit 打开注册表,删除键值 HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\Lsa 中的 LMCompatibilityLevel,无需重启计算机 ## Samba 资料 - - - - - - - -
最后修改:2022 年 05 月 27 日
如果觉得我的文章对你有用,欢迎打赏