[![logo](https://raw.githubusercontent.com/dperson/samba/master/logo.jpg)](https://www.samba.org) # Samba Samba docker container # What is Samba? Since 1992, Samba has provided secure, stable and fast file and print services for all clients using the SMB/CIFS protocol, such as all versions of DOS and Windows, OS/2, Linux and many others. # How to use this image By default there are no shares configured, additional ones can be added. ## Hosting a Samba instance sudo docker run -it -p 139:139 -p 445:445 -d dperson/samba OR set local storage: sudo docker run -it --name samba -p 139:139 -p 445:445 \ -v /path/to/directory:/mount \ -d dperson/samba ## Configuration sudo docker run -it --rm dperson/samba -h Usage: samba.sh [-opt] [command] Options (fields in '[]' are optional, '<>' are required): -h This help -c "" setup character mapping for file/directory names required arg: "" character mappings separated by ',' -i "" Import smbpassword required arg: "" - full file path in container -n Start the 'nmbd' daemon to advertise the shares -p Set ownership and permissions on the shares -r Disable recycle bin for shares -S Disable SMB2 minimun version -s "[;browse;readonly;guest;users;admins;wl]" Config a share required arg: ";" is how it's called for clients path to share NOTE: for the default values, just leave blank [browsable] default:'yes' or 'no' [readonly] default:'yes' or 'no' [guest] allowed default:'yes' or 'no' [users] allowed default:'all' or list of allowed users [admins] allowed default:'none' or list of admin users [writelist] list of users that can write to a RO share -t "" Configure timezone possible arg: "[timezone]" - zoneinfo timezone for container -u "[;ID;group]" Add a user required arg: ";" for user for user [ID] for user [group] for user -w "" Configure the workgroup (domain) samba should use required arg: "" for samba -W Allow access wide symbolic links The 'command' (if provided and valid) will be run instead of samba ENVIRONMENT VARIABLES (only available with `docker run`) * `CHARMAP` - As above, configure character mapping * `NMBD` - As above, enable nmbd * `SMB` - As above, disabel SMB2 minimun version * `TZ` - As above, set a zoneinfo timezone, IE `EST5EDT` * `WIDELINKS` - As above, allow access wide symbolic links * `WORKGROUP` - As above, set workgroup * `USERID` - Set the UID for the samba server * `GROUPID` - Set the GID for the samba server **NOTE**: if you enable nmbd (via `-n` or the `NMBD` environment variable), you will also want to expose port 137 and 138 with `-p 137:137/udp -p 138:138/udp`. ## Examples Any of the commands can be run at creation with `docker run` or later with `docker exec -it samba.sh` (as of version 1.3 of docker). ### Setting the Timezone sudo docker run -it -p 139:139 -p 445:445 -d dperson/samba -t EST5EDT OR using `environment variables` sudo docker run -it -e TZ=EST5EDT -p 139:139 -p 445:445 -d dperson/samba Will get you the same settings as sudo docker run -it --name samba -p 139:139 -p 445:445 -d dperson/samba sudo docker exec -it samba samba.sh -t EST5EDT ls -AlF /etc/localtime sudo docker restart samba ### Start an instance creating users and shares: sudo docker run -it -p 139:139 -p 445:445 -d dperson/samba \ -u "example1;badpass" \ -u "example2;badpass" \ -s "public;/share" \ -s "users;/srv;no;no;no;example1,example2" \ -s "example1 private;/example1;no;no;no;example1" \ -s "example2 private;/example2;no;no;no;example2" # User Feedback ## Issues If you have any problems with or questions about this image, please contact me through a [GitHub issue](https://github.com/dperson/samba/issues).