Viewing and Connecting to an SMB Samba Share on Windows/Linux/Unix -

Viewing and Connecting to an SMB Samba Share on Windows/Linux/Unix

This will give you the basic info needed to browse and connect to Samba shares from the command line.  From the GUI of Gnome or KDE etc, it is pretty standard and straight forward.  However, I've found very little guides on how to do it from the command line and if you're like me, a nerd who prefers command line for its simplicity and for remote use, this is the way to go.

First get a list of all the Samba/SMB shares on the target.

smbclient -L hostname (or IP address).

If you need to specify a specific username you would use:

smbclient -U username -L hostname 

If you are prompted for a password and you know one is not required, just hit enter (in this kind of case it doesn't matter what username you authenticate as).

The list of SMB Samba shares has been returned

Domain=[OURHOUSE] OS=[Unix] Server=[Samba 3.0.28-0.el4.9]

        Sharename       Type      Comment
        ---------       ----      -------
        DVDROMExternal  Disk
        dump            Disk
        driveshare      Disk

Connect to the chosen SMB Samba Share

smbclient \\\\hostname\\sharename

Yes, you read it right.  The first part before the hostname contains 4 backslashes \\\\

And the part before share name contains two backslashes \\

smb: \> ls
  .                                   D        0  Fri Feb 27 08:50:50 2009
  ..                                  D        0  Thu Jan  8 14:32:19 2009
  New Folder                          D        0  Sat Jan 26 16:24:54 2008
  test                                D        0  Sun Sep  7 18:29:26 2008
  fdsfd                               D        0  Sun Jan 27 11:37:55 2008

You'll be prompted with something like the above.  Note that I did type "ls" to get the list of folders.

The rest is pretty normal and straight forward for anyone who has ever used command line ftp.

An SMB share retrieval example:

If you want to download a file called "test" just type:

mget test

If you want to recursively get a bunch of directories just do this:

mget *

The recurse is obvious, it means to get a directory and recursively so that means everything inside.

The prompt takes away the annoying prompt, that means for each transfer you wont' be prompted to manually confirm.

An alternate and preferred way using SMB over CIFS

If that annoys you, you can simply mount the share on your local system and then browse, retrieve and make/write files as you like (assuming your permissions on the SMB server allow for it).

Others may have had different experiences but I can only get mounting with CIFS working by using the IP and not the hostname.

mount -t cifs // /mnt/cifs -o user=guest,pass=bla

If you try with the hostname dmesg will produce this message:

CIFS VFS: cifs_mount failed w/return code = -22

 Mounting SAMBA SMB CIFS shares at boot time by using /etc/fstab

Just add a line like this to /etc/fstab

// /mnt/cifs cifs        user=guest,pass=bla 0 0

Be sure to modify the user and pass options if you require a specific user and password to connect to the share.


  • PHP Migration from 5.3 to 5.4+ and dealing with deprecated functions
  • ffmpeg vidstab to stabilize video
  • userdel user userdel: cannot lock /etc/passwd; try again later.
  • mdadm how to mount inactive array
  • How to find and mount mdadm arrays automatically
  • M2Crypto.SSL.Checker.WrongHost: Peer certificate subjectAltName does not match host, expected, got
  • [Wed Sep 20 15:34:44 2017] [notice] suEXEC mechanism enabled (wrapper: /usr/sbin/suexec) [Wed Sep 20 15:34:44 2017] [error] Init: Unable to read server certificate from file /www/ssl-certs/server.crt [Wed Sep 20 15:34:44 2017] [error] SSL Library Err
  • linux how to answer yes to copy
  • linux cp and mv will not overwrite due to alias!
  • ERROR 2006 (HY000) at line 567: MySQL server has gone away
  • vbulletin 4.2.5 after upgrading from 3.6 white screen fatal php errors
  • iptables v1.4.7: can't initialize iptables table `NAT': Table does not exist (do you need to insmod?) Perhaps iptables or your kernel needs to be upgraded.
  • Linux and FreeBSD how to set time and date
  • FreeBSD/OpenBSD OpenVPN Client error "Cannot allocate TUN/TAP dev dynamically"
  • kdenlive - No LADSPA plugins were found! Check your LADSPA_PATH environment variable. [producer_xml] failed to load transition "qtblend"
  • /usr/bin/supermin-helper exited with error status 1. To see full error messages you may need to enable debugging. See at /usr/bin/virt-list-partitions line 177.
  • Linux Unable to mount cifs/smb share in /etc/fstab
  • MySQL: table is marked as crashed solultion
  • bash Linux how to get first or last letters of a word
  • l2tp ipsec VPN Error Sep 12 18:16:25 vps pluto[7299]: ERROR: asynchronous network error report on eth0 (sport=500) for message to port 20640, complainant Connection refused [errno 111, origin ICMP type 3 code 3 (not authenticated