Samba Client smbclient

Dieser Artikel wurde für die folgenden Ubuntu-Versionen getestet:

Zum Verständnis dieses Artikels sind folgende Seiten hilfreich:

  1. Ein Terminal öffnen

  2. Grundlagen über Samba

  3. FTP auf der Konsole, optional

Inhaltsverzeichnis
  1. Installation
  2. Kommandos eingeben
    1. Informationen eines Samba Servers abfrag...
    2. Anmeldung mit Benutzername und Kennwort
  3. Arbeiten mit der smbclient-Shell
    1. Häufig benutzte Shell-Befehle
    2. Kopieren ganzer Ordner
    3. Besonderheiten der Syntax
  4. Verwandte Befehle
  5. Links

Samba_Server/samba-logo.png smbclient ist ein Konsolenclient für SMB/CIFS-Freigaben. Damit ist auch ein Zugriff auf Freigaben möglich, ohne diese in das Dateisystem einhängen zu müssen. Ursprünglich als Test- und Debugging-Tool konzipiert, ist smbclient auch zu einer universellen Shell geworden, deren Befehlsvorrat dem von ftp[3] vergleichbar ist. smbclient ist oft die erste Hilfe, wenn mit Samba Probleme auftreten. Es ist aber auch dann von Vorteil, wenn man nur schnell und unkompliziert auf der Konsole eine Datei von Samba oder Windows hoch- oder herunterladen möchte. Oder einfach, wenn man allgemein dem direkten Weg mit Konsole oder Terminal den Vorzug vor aufwändigen grafischen Hilfsprogrammen gibt.

Die wichtigsten Operationen, die sich mit smbclient ausführen lassen, sind:

Grob lässt sich die Anwendung von smbclient in zwei Bereiche einteilen:

  1. Eingabe und Übermittlung von Kommandos

  2. Arbeiten mit einer Freigabe (Share) über die smbclient-Shell

Es würde den Rahmen eines Wiki-Artikels sprengen, auf alle Optionen und Befehle von smbclient einzugehen. Deshalb werden hier nur einige gängige Beispiele aufgeführt.

Hinweis: Der Begriff Samba Server wird im folgenden als Synonym für Freigaben des cifs Protokolls verwendet.

Installation

smbclient befindet sich im Paket

Paketliste zum Kopieren:

sudo apt-get install  smbclient 

Oder mit apturl installieren, Link: smbclient

Kommandos eingeben

Über smbclient lassen sich sowohl Kommandos an den Client selbst als auch an einen Samba Server übergeben. Die genaue Syntax variiert je nach Kommando, entspricht aber im Wesentlichen folgendem Schema:

# allgemein:
smbclient Option Zusatzangabe
# Beispiel:
smbclient -L //notebook/Daten 

Die Option legt das Kommando fest. Sie kann (wie üblich) in Kurz- oder Langform angegeben werden. Die Zusatzangabe kann ein Parameter und/oder der Adressat des Kommandos sein und ggf. noch weitere sekundäre Optionen enthalten. Manche Optionen sind auch nur in Verbindung mit anderen Kommandos möglich.

Nach der Eingabe der Kommando-Zeile erfolgt eine verdeckte Abfrage des Samba-Passworts. Mit der Zusatzoption -N lässt sich die Passwort-Abfrage unterdrücken. Gibt man kein Passwort ein, dann wird das Kommando anonym übermittelt. Viele, aber nicht alle Kommandos können anonym ausgeführt werden. Nach der Ausführung des Kommandos kehrt smbclient automatisch wieder in die Linux-Shell zurück, was am Prompt zu erkennen ist.

Im Folgenden werden einige häufig gebrauchte Kommandos beschrieben.

Informationen eines Samba Servers abfragen

Hinweis:

Ab Samba 4.7.0 / Bionic Beaver versucht smbclient die Verbindung im Dialekt SMB3_11 aufzubauen. Sofern der Samba Server nur Dialekte ab SMB2 akzeptiert, funktioniert das Browsing der Workgroup nicht mehr (smbclient -L <server>) (Fehlermeldung: Failed to connect with SMB1 – no workgroup available). Die Shares werden jedoch angezeigt.

Um die Freigaben (Shares) eines Samba Servers zu erfragen, kann folgender Befehl genutzt werden:

# allgemein:
smbclient -L //Server
# Beispiele:
smbclient -L //notebook/
smbclient -L //192.168.1.111/
smbclient -N -L //notebook/ 

Die Abfrage des Servers ist auch ohne Anmeldung (anonym) möglich. Unter Umständen sind dann aber nicht alle Freigaben zu sehen. Für den Server kann der Rechnername (netbios name) oder die IP angegeben werden. Man erhält dann eine Ausgabe folgender Art:

# mit Serverseitig aktiviertem Dialekt SMB1:

ubuntu@ubuntu:~$ smbclient -L localhost
WARNING: The "syslog" option is deprecated
Enter WORKGROUP\ubuntu's password: 

	Sharename       Type      Comment
	---------       ----      -------
	print$          Disk      Printer Drivers
	demo            Disk      
	IPC$            IPC       IPC Service (ubuntu server (Samba, Ubuntu))
Reconnecting with SMB1 for workgroup listing.

	Server               Comment
	---------            -------

	Workgroup            Master
	---------            -------
	WORKGROUP            UBUNTU

# ohne Serverseitig aktiviertem Dialekt SMB1:

ubuntu@ubuntu:~$ smbclient -L localhost
WARNING: The "syslog" option is deprecated
Enter WORKGROUP\ubuntu's password: 

	Sharename       Type      Comment
	---------       ----      -------
	print$          Disk      Printer Drivers
	demo            Disk      
	IPC$            IPC       IPC Service (ubuntu server (Samba, Ubuntu))
Reconnecting with SMB1 for workgroup listing.
protocol negotiation failed: NT_STATUS_INVALID_NETWORK_RESPONSE
Failed to connect with SMB1 -- no workgroup available

Anmeldung mit Benutzername und Kennwort

Mit der Option -U kann man sich persönlich anmelden. Das Kommando zur Anmeldung wird dem auszuführenden Kommando vorangestellt:

# allgemein:
smbclient -U benutzername -L //Server
# Beispiel:
smbclient -U Simon -L //notebook/ 

Der angegebene Benutzername muss nicht mit dem aktuellen Benutzernamen auf dem Client übereinstimmen, muss aber auf dem Server in der Samba-Benutzerdatenbank eingetragen sein (mittels smbpasswd).

Arbeiten mit der smbclient-Shell

Mit der Befehlszeile

# allgemein
smbclient //Server/Freigabe
# Beispiele
smbclient //notebook/Daten
smbclient //192.168.1.111/Daten 

kann man sich mit einer Freigabe auf dem angegebenen Server verbinden und dort eine smbclient-Shell öffnen. Man erhält dann eine Ausgabe folgender Art:

ubuntu@ubuntu:~$ smbclient //localhost/demo
WARNING: The "syslog" option is deprecated
Enter WORKGROUP\ubuntu's password: 
Try "help" to get a list of possible commands.
smb: \> 

Verzichtet man auf die Eingabe eines Passwortes, erfolgt die Anmeldung anonym, und man hat dann nur die Rechte, die bei der Freigabe einem Gast zukommen. Es ist aber auch möglich, sich mit Benutzername und Kennwort anzumelden:

smbclient -U Simon //notebook/Daten 

Der Prompt smb: \> macht deutlich, dass Samba eine Verbindung zwischen Linux und Windows herstellen möchte. In der smbclient-Shell ist für Pfadnamen sowohl die Windows-Syntax mit Backslash (\) als auch die Linux-Syntax mit Slash (/) zulässig.

Häufig benutzte Shell-Befehle

Kopieren ganzer Ordner

Nach dem Verbinden auf die Freigabe folgende Befehle ausführen, um ganze Ordner zu kopieren:

Ein erneutes Eingeben von recurse bzw. prompt stellt die Standardeinstellungen wieder her.

Besonderheiten der Syntax

Leerzeichen in Namen oder Parametern

Weil in Dateipfaden wahlweise Slash (/) oder Backslash (\) zulässig sind, kann ein Backslash nicht - wie in Linux üblich - zum "Escapen" von Leerzeichen oder anderen besonderen Zeichen verwendet werden. Zeichenketten, die solche Zeichen enthalten, müssen deshalb in (doppelte) Anführungszeichen gesetzt werden (Beispiel: cd \Daten\"neue Datei").

Syntaxfehler

Bei Syntaxfehlen verschiedener Art erfolgt in der smbclient-Shell meist die wenig informative Fehlermeldung

Not enough '\' characters in service

Es lohnt sich, zu überlegen, ob der Fehler nicht vielleicht von ganz anderer Art ist.

Verwandte Befehle

Mit im Paket smbclient enthalten sind noch folgende Routinen:

Wenn man smbclient zur Fehlersuche und zum Beheben von Problemen einsetzt, benötigt man häufig noch weitere Informationen über das Netzwerk oder die Netzwerk-Verbindung. Hierbei sind folgende weiteren Befehle hilfreich, die ebenfalls im Paket smbclient enthalten sind:

Einzelheiten zu diesen Befehlen finden sich in den entsprechenden Manpages.

Nützlich sind oft auch die logfiles, die sich im Verzeichnis /var/log/samba/ befinden.