Difference between revisions of "Installing Samba from the command line"

From Da Nerd Mage Wiki
Jump to navigation Jump to search
 
(23 intermediate revisions by the same user not shown)
Line 10: Line 10:
Basic Samba install & minimal configuration
Basic Samba install & minimal configuration


Create a test folder & file to be shared. (Assuming you'll replace '''USER''' with your own username...)
= Create a test folder & file to be shared. =
(Assuming you'll replace '''USER''' with your own username...)
* <code>mkdir ~/share</code>
* <code>mkdir ~/share</code>
* <code>touch ~/share/Foo</code>
* <code>touch ~/share/Foo</code>
Install Samba
 
= Install Samba =
* <code>sudo apt install samba -y</code>
* <code>sudo apt install samba -y</code>
Configure the test share
 
= Configure the test share =
* <code>sudo vi /etc/samba/smb.conf</code>
* <code>sudo vi /etc/samba/smb.conf</code>
== As a publicly accessible share ==
[New_share]
    comment= my share
    path = /home/'''USER'''/share
    force create mode = 0660        ; readable and writable by user and group
    force directory mode = 0770    ; readable, writable and searchable by user and group
    browseable  = yes
    Read only = no
    guest  ok = yes
'''Note:''' Files & folders placed in this share by an anonymous user will belong to '''nobody:nogroup'''.
:oddly, even as the owner of the share, you won't have direct control over these files/folders.
:So, it might be a good idea to add yourself to the '''nogroup''' group:
:* <code>sudo usermod -a -G nogroup '''USER'''</code>
== As a share requiring authentication ==


  [New_share]
  [New_share]
Line 23: Line 44:
     browseable  = yes
     browseable  = yes
     Read only = no
     Read only = no
     guest  ok = no         ; Change to 'yes' to allow anonymous access
     guest  ok = no
 
= Restart Samba =
While you're in there, if you don't have printer(s) connected to the machine, comment out or remove the '''[printers]''' and '''[print$]''' blocks


* <code>sudo systemctl restart smbd</code>
* <code>sudo systemctl restart smbd</code>
Set up usernames & passwords for Samba acess (Samba uses it's own password list.&nbsp; Therefore, you'll need to set up each user...)
 
= Set up usernames & passwords for Samba acess =
(Samba uses it's own password list.&nbsp; Therefore, you'll need to set up each user...)


For each user that will be allowed access ('''USER'''s must exist as users on the system),
For each user that will be allowed access ('''USER'''s must exist as users on the system),
* <code>sudo smbpasswd -a '''USER'''</code>
* <code>sudo smbpasswd -a '''USER'''</code>
Additional bits to install (Client & utils & such...)
 
* <code>sudo apt install cifs-utils samba-client -y</code>
= Additional bits to install =
Client & utils & such... (optional)
 
In order to be able to [[Mounting CIFS Shares  from the command line{{!}}mount CIFS (Samba, Windows...) shares]] from other servers
* <code>sudo apt install cifs-utils -y</code>
For some reason...
* <code>sudo apt install samba-client -y</code>
seems to be recommended. Gonna hafta research what that actually provides.
 
= Usage Notes =
'''NOTE:''' At this point, the share can be accessed, but you need to know where it is because Samba does not advertise it's presence.
'''NOTE:''' At this point, the share can be accessed, but you need to know where it is because Samba does not advertise it's presence.


You '''can''' see the shares from the machine by entering <code>smb://'''MACHINENAME'''/</code> into the address bar of your file browser.
:You '''can''' see the shares from the machine by entering <code>smb://'''MACHINENAME'''/</code> into the address bar of your file browser.
'''Also... SMB seems to get harder & harder to deal with.''' If just trying to get to the server results in '''Error: Failed to retrieve share list from server: Invalid argument''', it's because of some of the many changes done to the protocols over the years.
 
* <code>sudo vi /etc/samba/smb.conf</code>
& add
 
client min protocol = NT1
server min protocol = NT1
into the '''[global]''' section. (after the "'''workgroup ='''" line is recommended.)
 
== Show shares ==
* <code>sudo smbstatus --shares</code>
 
= Ongoing Research =
Still need to find a way for Samba to properly show up when browsing the network...
 
Hey SAMBA!  How about a solution to the whole "nobody:nogroup" stupidity???


[[Category:Linux]]
[[Category:Linux]]
[[Category: WIP]]

Latest revision as of 13:19, 24 September 2024

Proven on:
Logo Debian.png
11 (bullseye)


Basic Samba install & minimal configuration

Create a test folder & file to be shared.

(Assuming you'll replace USER with your own username...)

  • mkdir ~/share
  • touch ~/share/Foo

Install Samba

  • sudo apt install samba -y

Configure the test share

  • sudo vi /etc/samba/smb.conf

As a publicly accessible share

[New_share]
    comment= my share
    path = /home/USER/share
    force create mode = 0660        ; readable and writable by user and group
    force directory mode = 0770     ; readable, writable and searchable by user and group
    browseable  = yes
    Read only = no
    guest  ok = yes

Note: Files & folders placed in this share by an anonymous user will belong to nobody:nogroup.

oddly, even as the owner of the share, you won't have direct control over these files/folders.
So, it might be a good idea to add yourself to the nogroup group:
  • sudo usermod -a -G nogroup USER

As a share requiring authentication

[New_share]
    comment= my share
    path = /home/USER/share
    browseable  = yes
    Read only = no
    guest  ok = no

Restart Samba

While you're in there, if you don't have printer(s) connected to the machine, comment out or remove the [printers] and [print$] blocks

  • sudo systemctl restart smbd

Set up usernames & passwords for Samba acess

(Samba uses it's own password list.  Therefore, you'll need to set up each user...)

For each user that will be allowed access (USERs must exist as users on the system),

  • sudo smbpasswd -a USER

Additional bits to install

Client & utils & such... (optional)

In order to be able to mount CIFS (Samba, Windows...) shares from other servers

  • sudo apt install cifs-utils -y

For some reason...

  • sudo apt install samba-client -y

seems to be recommended. Gonna hafta research what that actually provides.

Usage Notes

NOTE: At this point, the share can be accessed, but you need to know where it is because Samba does not advertise it's presence.

You can see the shares from the machine by entering smb://MACHINENAME/ into the address bar of your file browser.

Also... SMB seems to get harder & harder to deal with. If just trying to get to the server results in Error: Failed to retrieve share list from server: Invalid argument, it's because of some of the many changes done to the protocols over the years.

  • sudo vi /etc/samba/smb.conf

& add

client min protocol = NT1
server min protocol = NT1

into the [global] section. (after the "workgroup =" line is recommended.)

Show shares

  • sudo smbstatus --shares

Ongoing Research

Still need to find a way for Samba to properly show up when browsing the network...

Hey SAMBA! How about a solution to the whole "nobody:nogroup" stupidity???