第一种方法:(未使用)

  1. yum install docker
  2. // 下载镜像
  3. docker pull dperson/samba
  4. // 启动镜像,具体看文档,但重要的配置是以下的注释
  5. docker run --name samba \
  6. -it -p 139:139 -p 445:445 \
  7. -v /home/technofiend:/home/technofiend \               #共享目录
  8. -d dperson/samba \
  9. -u "www;thisispasswd" \                                #访问用户
  10. -s "technofiend;/home/technofiend/;yes;no;no;all;none" #共享配置
  11. // 密码跟本机一致,1001为用户id,具体查看你本机的/etc/passwd文件,设置为共享目录所属用户
  12. docker exec -it samba sed -i 's/1000/1001/g' /etc/passwd
  13. // 组跟本机一致,1001为组id,具体查看你本机的/etc/group文件,设置为共享目录所属组
  14. docker exec -it samba sed -i 's/1000/1001/g' /etc/group
  15. // 替换samba的启动用户,与权限有关
  16. docker exec -it samba sed -i 's/force user = smbuser/force user = www/g' /etc/samba/smb.conf
  17. // 替换samba的启动组,与权限有关
  18. docker exec -it samba sed -i 's/force group = users/force group = www/g' /etc/samba/smb.conf
  19. // 重启samba
  20. docker restart samba
  21.  
  22. 用户id那块看清楚了。但docker实例里面新建的第一个用户是1000.这里跟你主机的用户权限需要一直,所以得替换成同样的id,用户和组也得要
  23. 就是新进容器建这个用户

第一种方法

第二种方法:(实验成功)

第一步安装docker:

  1. yum install docker-engine

第二步启动服务:

  1. service docker start

第三步:

docker pull dperson/samba
第四步:

docker run -it --name samba -p 139:139 -p 445:445 -v /home:/mount -d dperson/samba -u "www;overkill" -s "www;/mount/;yes;no;no;all;none"

开放了139和445端口。 用服务器访问即可!


要是想把容器的权限与宿主主机的用户权限一致的话,则只需要把用户和组文件映射到容器里面即可:

docker run -it --name samba -p 139:139 -p 445:445 -v /home:/mount -v /etc/passwd:/etc/passwd -v /etc/group:/etc/group -d dperson/samba -s "www;/mount/;yes;no;no;all;none"

请注意 -s 参数后面的第一个;前面的是现已存在的用户名。

官方使用教程:https://github.com/dperson/samba


三、配置方法

系统:ubuntu16.04

配置文件:/etc/samba/smb.conf

Samba的主配置文件叫smb.conf,默认在/etc/samba/目录下

smb.conf含有多个段,每个段由段名开始,直到下个段名。每个段名放在方括号中间。每段的参数的格式是:名称=指。配置文件中一行一个段名和参数,段名和参数名不分大小写。
除了[global]段外,所有的段都可以看作是一个共享资源。段名是该共享资源的名字,段里的参数是该共享资源的属性。
Samba安装好后,使用testparm命令可以测试smb.conf配置是否正确。使用testparm –v命令可以详细的列出smb.conf支持的配置参数

配置文件详解

  1. # This is the main Samba configuration file. You should read the
  2. # smb.conf() manual page in order to understand the options listed
  3. # here. Samba has a huge number of configurable options (perhaps too
  4. # many!) most of which are not shown in this example
  5. #
  6. # Any line which starts with a ; (semi-colon) or a # (hash)
  7. # is a comment and is ignored. In this example we will use a #
  8. # for commentry and a ; for parts of the config file that you
  9. # may wish to enable
  10. #
  11. # NOTE: Whenever you modify this file you should run the command "testparm"
  12. # to check that you have not made any basic syntactic errors.
  13. #
  14. #======================= Global Settings =====================================
  15. [global]
  16.  
  17. # workgroup = NT-Domain-Name or Workgroup-Name
  18. workgroup = MYGROUP
  19. #设定 Samba Server 所要加入的工作组或者域
  20. # server string is the equivalent of the NT Description field
  21. server string = Samba Server
    #设定 Samba Server 的注释,可以是任何字符串,也可以不填。宏%v表示显示Samba的版本号
  22.  
  23. # This option is important for security. It allows you to restrict
  24. # connections to machines which are on your local network. The
  25. # following example restricts access to two C class networks and
  26. # the "loopback" interface. For more examples of the syntax see
  27. # the smb.conf man page
  28. ; hosts allow = 192.168.. 192.168.. .
  29. #表示允许连接到Samba Server的客户端,多个参数以空格隔开。可以用一个IP表示,也可以用一个网段表示。hosts deny 与hosts allow 刚好相反。
  30. # if you want to automatically load your printer list rather
  31. # than setting them up individually then you'll need this
  32. printcap name = /dev/null
  33. load printers = no
  34.  
  35. # It should not be necessary to spell out the print system type unless
  36. # yours is non-standard. Currently supported print systems include:
  37. # bsd, sysv, plp, lprng, aix, hpux, qnx
  38. printing = bsd
  39.  
  40. # Uncomment this if you want a guest account, you must add this to /etc/passwd
  41. # otherwise the user "nobody" is used
  42. ; guest account = pcguest
  43.  
  44. # this tells Samba to use a separate log file for each machine
  45. # that connects
  46. log file = /dev/stdout
  47. #日志文件的存储位置以及日志文件名称
  48. # Put a capping on the size of the log files (in Kb).
  49. max log size =
  50. #设置Samba Server日志文件的最大容量,单位为kB,0代表不限制
  51. # Security mode. Most people will want user level security. See
  52. # security_level.txt for details.
  53. security = user
    #用户访问Samba Server的验证方式
#1. share用户访问Samba Server不需要提供用户名和口令, 安全性能较低。
  1.  
#2. user:Samba Server共享目录只能被授权的用户访问,由Samba Server负责检查账号和密码的正确性。账号和密码要在本Samba Server中建立。
  1.  
#3. server:依靠其他Windows NT/2000或Samba Server来验证用户的账号和密码,是一种代理验证。此种安全模式下,系统管理员可以把所有的Windows用户和口令集中到一个NT系统上,使用Windows NT进行Samba认证, 远程服务器可以自动认证全部用户和口令,如果认证失败,Samba将使用用户级安全模式作为替代的方式。
  1.  
#4. domain:域安全级别,使用主域控制器(PDC)来完成认
# Use password server option only with security = server
  1. ; password server = <NT-Server-Name>
  2.  
  3. # Password Level allows matching of _n_ characters of the password for
  4. # all combinations of upper and lower case.
  5. ; username level =
  6.  
  7. # You may wish to use password encryption. Please read
  8. # ENCRYPTION.txt, Win95.txt and WinNT.txt in the Samba documentation.
  9. # Do not enable this option unless you have read those documents
  10. ; encrypt passwords = yes
  11. ; smb passwd file = /etc/samba/smbpasswd
  12.  
  13. # The following are needed to allow password changing from Windows to
  14. # update the Linux sytsem password also.
  15. # NOTE: Use these with 'encrypt passwords' and 'smb passwd file' above.
  16. # NOTE2: You do NOT need these to allow workstations to change only
  17. # the encrypted SMB passwords. They allow the Unix password
  18. # to be kept in sync with the SMB password.
  19. unix password sync = no
  20. ; passwd program = /usr/bin/passwd %u
  21. ; passwd chat = *New*UNIX*password* %n\n *ReType*new*UNIX*password* %n\n *passwd:*all*authentication*tokens*updated*successfully*
  22.  
  23. # Unix users can map to different SMB User names
  24. ; username map = /etc/samba/smbusers
  25.  
  26. # Using the following line enables you to customise your configuration
  27. # on a per machine basis. The %m gets replaced with the netbios name
  28. # of the machine that is connecting
  29. ; include = /etc/samba/smb.conf.%m
  30.  
  31. # Configure Samba to use multiple interfaces
  32. # If you have multiple network interfaces then you must list them
  33. # here. See the man page for details.
  34. ; interfaces = 192.168.12.2/ 192.168.13.2/
  35.  
  36. # Configure remote browse list synchronisation here
  37. # request announcement to, or browse list sync from:
  38. # a specific host or from / to a whole subnet (see below)
  39. ; remote browse sync = 192.168.3.25 192.168.5.255
  40. # Cause this host to announce itself to local subnets here
  41. ; remote announce = 192.168.1.255 192.168.2.44
  42.  
  43. # Browser Control Options:
  44. # set local master to no if you don't want Samba to become a master
  45. # browser on your network. Otherwise the normal election rules apply
  46. ; local master = no
  47.  
  48. # OS Level determines the precedence of this server in master browser
  49. # elections. The default value should be reasonable
  50. ; os level =
  51.  
  52. # Domain Master specifies Samba to be the Domain Master Browser. This
  53. # allows Samba to collate browse lists between subnets. Don't use this
  54. # if you already have a Windows NT domain controller doing this job
  55. ; domain master = yes
  56.  
  57. # Preferred Master causes Samba to force a local browser election on startup
  58. # and gives it a slightly higher chance of winning the election
  59. ; preferred master = yes
  60.  
  61. # Use only if you have an NT server on your network that has been
  62. # configured at install time to be a primary domain controller.
  63. ; domain controller = <NT-Domain-Controller-SMBName>
  64.  
  65. # Enable this if you want Samba to be a domain logon server for
  66. # Windows95 workstations.
  67. ; domain logons = yes
  68.  
  69. # if you enable domain logons then you may want a per-machine or
  70. # per user logon script
  71. # run a specific logon batch file per workstation (machine)
  72. ; logon script = %m.bat
  73. # run a specific logon batch file per username
  74. ; logon script = %U.bat
  75.  
  76. # Where to store roving profiles (only for Win95 and WinNT)
  77. # %L substitutes for this servers netbios name, %U is username
  78. # You must uncomment the [Profiles] share below
  79. ; logon path = \\%L\Profiles\%U
  80.  
  81. # All NetBIOS names must be resolved to IP Addresses
  82. # 'Name Resolve Order' allows the named resolution mechanism to be specified
  83. # the default order is "host lmhosts wins bcast". "host" means use the unix
  84. # system gethostbyname() function call that will use either /etc/hosts OR
  85. # DNS or NIS depending on the settings of /etc/host.config, /etc/nsswitch.conf
  86. # and the /etc/resolv.conf file. "host" therefore is system configuration
  87. # dependant. This parameter is most often of use to prevent DNS lookups
  88. # in order to resolve NetBIOS names to IP Addresses. Use with care!
  89. # The example below excludes use of name resolution for machines that are NOT
  90. # on the local network segment
  91. # - OR - are not deliberately to be known via lmhosts or via WINS.
  92. ; name resolve order = wins lmhosts bcast
  93.  
  94. # Windows Internet Name Serving Support Section:
  95. # WINS Support - Tells the NMBD component of Samba to enable it's WINS Server
  96. ; wins support = yes
  97.  
  98. # WINS Server - Tells the NMBD components of Samba to be a WINS Client
  99. # Note: Samba can be either a WINS Server, or a WINS Client, but NOT both
  100. ; wins server = w.x.y.z
  101.  
  102. # WINS Proxy - Tells Samba to answer name resolution queries on
  103. # behalf of a non WINS capable client, for this to work there must be
  104. # at least one WINS Server on the network. The default is NO.
  105. ; wins proxy = yes
  106.  
  107. # DNS Proxy - tells Samba whether or not to try to resolve NetBIOS names
  108. # via DNS nslookups. The built-in default for versions 1.9. is yes,
  109. # this has been changed in version 1.9. to no.
  110. dns proxy = no
  111.  
  112. # Case Preservation can be handy - system default is _no_
  113. # NOTE: These can be set on a per share basis
  114. preserve case = yes
  115. short preserve case = yes
  116. # Default case is normally upper case for all DOS files
  117. default case = lower
  118. # Be very careful with case sensitivity - it can break things!
  119. ; case sensitive = no
  120.  
  121. pam password change = yes
  122. map to guest = bad user
  123. usershare allow guests = yes
  124. create mask =
  125. force create mode =
  126. directory mask =
  127. force directory mode =
  128. # force user = www
  129. # force group = www
  130. follow symlinks = yes
  131. load printers = no
  132. printing = bsd
  133. printcap name = /dev/null
  134. disable spoolss = yes
  135. socket options = TCP_NODELAY
  136. strict locking = no
  137. vfs objects = recycle
  138. recycle:keeptree = yes
  139. recycle:versions = yes
  140. min protocol = SMB2
  141.  
  142. [公共文件]
  143. path = /home/technofiend/public
    browsable = yes #用来指定该共享是否可以浏览
  144. read only = no
  145. guest ok = no #将设置客户端以该游客账号来访问共享
  146. veto files = /._*/.apdisk/.AppleDouble/.DS_Store/.TemporaryItems/.Trashes/desktop.ini/ehthumbs.db/Network Trash Folder/Temporary Items/Thumbs.db/
  147. delete veto files = yes
  148. valid users = @public
  149. [网络开发文件]
  150. comment = group-web #对该共享的描述,可以是任意字符串
  151. path = /home/technofiend/group/web #共享目录路径
  152. public = yes #用来指定该共享是否允许guest账户访问
  153. writable = yes #用来指定该共享路径是否可写
  154. printable = no
  155. valid users = @web #允许访问该共享的用户,组就用“@+组名”表示
  156. [引擎开发文件]
      comment = ue4 
    path = /home/technofiend/group/editor 
      public = yes    #用来指定该共享是否允许guest账户访问
      writable = yes  #用来指定该共享路径是否可写 
      printable = no 
      valid users = @editor
    [设计内部文件]
    comment = group public
    path = /home/technofiend/group/public
    public = yes writable = yes #用来指定该共享路径是否可写
  157. printable = no
    valid users = @seji #允许访问该共享的用户,组就用“@+组名”表示

service smb restart   重启服务

检查语法是否正确:testparm -v

思路方法:

1)创建组:添加用户组
groupadd public             创建用户组

useradd -s /sbin/nologin -G web,public,group-public webtest1  添加到多个用户组

usermod -g seji cesiyonghu 添加到组

注意:useradd和adduser区别

  1. useraddadduser都是创建新的用户
  2. CentOsuseraddadduser是没有区别的都是在创建用户,在home下自动创建目录,没有设置密码,需要使用passwd命令修改密码。
  3. 而在Ubuntuuseraddadduser有所不同
  4. useradd在使用该命令创建用户是不会在/home下自动创建与用户名同名的用户目录,而且不会自动选择shell版本,也没有设置密码,那么这个用户是不能登录的,需要使用passwd命令修改密码。
  5. adduser在使用该命令创建用户是会在/home下自动创建与用户名同名的用户目录,系统shell版本,会在创建时会提示输入密码,更加友好。
  6.  
  7. userdel 删除用户,
  8. userdel只能删除用户,并不会删除相关的目录文件。userdel -r 可以删除用户及相关目录。

2)变更文件夹的用户和用户组权限
chown -R :web group/web    #表示所有web组

3)把用户添加到samba中
smbpasswd -a share    #设置密码
4)激活用户

smbpasswd -e share

5)window下使用; 运行----输入\\ip地址


文章出处:

http://blog.csdn.net/technofiend/article/details/52346303    主要转载这篇

http://blog.csdn.net/technofiend/article/details/51066262

更多注释详解:http://blog.csdn.net/dhgao38/article/details/43567403

  1.  
  1.  

Docker镜像搭建ubuntu下samba目录共享的更多相关文章

  1. Docker镜像搭建Linux下samba共享目录

    Samba 是 SMB/CIFS 网络协议的重新实现, 它作为 NFS 的补充使得在 Linux.OS/2.DOS 和 Windows 系统中进行文件共享.打印机共享更容易实现.SMB协议是客户机/服 ...

  2. python开发笔记-Python3.7+Django2.2 Docker镜像搭建

    目标镜像环境介绍: 操作系统:ubuntu16.04 python版本:python 3.7.4 django版本:2.2 操作步骤: 1.  本地安装docker环境(略)2. 拉取ubunut指定 ...

  3. 搭建Ubuntu下c/c++编译环境【转】

    1.       安装Ubuntu. 2.       安装gcc 方法一: sudo apt-get  install  build-essential 安装完了可以执行 gcc--version的 ...

  4. 傲视Kubernetes(二):Docker镜像搭建与本地Kubernetes环境搭建

    主要内容: 1.Docker与Kubernetes的关系 2.SpringBoot微服务的Docker镜像创建 3.Kubernetes本地环境搭建 一.Docker与Kubernetes的关系 在说 ...

  5. PyCharm使用之利用Docker镜像搭建Python开发环境

      在我们平时使用PyCharm的过程中,一般都是连接本地的Python环境进行开发,但是如果是离线的环境呢?这样就不好搭建Python开发环境,因为第三方模块的依赖复杂,不好通过离线安装包的方式安装 ...

  6. Docker+STF在ubuntu下测试环境搭建(详细搭建步骤及踩坑记录)

    一.什么是OpenSTF? STF又称OpenSTF,它是一个手机设备管理平台,可以对手机进行远程管理.调试.远程手机桌面监控等操作.这个系统类似于目前很流行的云测服务比如Testin,虽然网页上提供 ...

  7. Ubuntu杂记——Ubuntu下用虚拟机共享上网

    由于最近把自己电脑环境换成了Ubuntu,但学校的网络是电信的闪讯,大学里用过的人都知道这货有多坑,而且没有Linux客户端,上网都是问题,怪不得国内用Linux的人那么少,特别是高校的学生(让我瞎逼 ...

  8. TensorFlow(1):使用Docker镜像搭建TensorFlow环境

    1,关于TensorFlow TensorFlow 随着AlphaGo的胜利也火了起来. google又一次成为大家膜拜的大神了.google大神在引导这机器学习的方向. 同时docker 也是一个非 ...

  9. Ubuntu12.04下samba服务器共享配置

    1 . 前置工作 首先保证你的Ubuntu能上网:虚拟机网络连接方式为NAT:虚拟机雨物理机互ping可通: 2. 安装samba sudo apt-get insall samba sudo apt ...

随机推荐

  1. AD转换 XPT2046

    应用电路 引脚功能描述 控制位命令 控制字节各位描述 单端模式输入配置 差分模式输入配置 掉电和内部参考电压选择 应用电路 AIN0:检测转换电位器模拟信号,控制字命令寄存器值为0x94或者0xB4 ...

  2. 【坑】Mybatis原始获取配置方式,获取配置失败

    错误环境: mysql版本:6.0.6 mybatis 3.4.1 idea 2017.1.2 maven 3.5.0 错误描述: 配置经路径见图1,classpath是java文件夹 获取配置的代码 ...

  3. insmod: can't insert 'xxx.ko': unknown symbol in module, or unknown parameter

    手动加载内核模块时候,报如下错误信息 insmod: can't insert 'xxx.ko': unknown symbol in module, or unknown parameter 问题原 ...

  4. Hadoop_19_MapReduce&&Yarn运行机制

    1.YARN的运行机制 1.1.概述: Yarn集群:负责海量数据运算时的资源调度,集群中的角色主要有:ResourceManager.NodeManager Yarn是一个资源调度(作业调度和集群资 ...

  5. 学习Shell编程

    目录 1 什么是Shell 2 Linux的启动过程 3 怎样编写一个Shell脚本 4 Shell脚本的执行方式 5 内建命令和外部命令的区别 6 管道和重定向 7 变量赋值 8 环境变量配置文件 ...

  6. java——spring中bean的作用域

    文章:理解Spring框架中Bean的作用域 博客地址:https://baijiahao.baidu.com/s?id=1610298792072480906&wfr=spider& ...

  7. Comparator分组测试

    import java.util.ArrayList; import java.util.Collection; import java.util.Collections; import java.u ...

  8. 不同显卡对mrt 的支持

    ios bits限制大概512bits 低端256bits mali 也是bits限制 2017年 Mali-T760 128bits adreno android显卡4 肯定可以 因为deferre ...

  9. Idea中Module is not specified解决办法

    打开idea,想跑一个类,但是,给我报了一个红叉: 当我点击run的时候,弹出来一个框: “Error:Module not specified”  Module 未指定 “这个原因是项目文件夹有修改 ...

  10. macOS上更顺手的终端

    安装iTerm2.下载地址 https://iterm2.com/downloads/stable/latest 安装Nerd Fonts.下载地址 https://github.com/ryanoa ...