ARgh, this should be so simple, but it isn’t. Trying to build a linux file server is complicated mainly because of the network naming (how do you file your server) and the administration of users. Here’s a quick guide for Ubuntu. It is amazing to me it took a whole day and a half to write this

Out of the box

Xubuntu as a client

Avahi supports Mac file sharing via afp (natively!). You can browse and you can connect from Xubuntu to a real Mac. Wow that is pretty cool.

  • It actually doesn’t work against Synology file servers which Mac’s can see
  • It doesn’t work against Time Capsule 2nd Generation at least even though they are AFP devices

Ubuntu as a server

If you are testing then you want to make sure that:

  • in a VMware virtual machine, make sure that the machine is a “full” peer. The default is to share with the Mac and this will put the VMware machine on 172...* usually. And we want it to be visible. However out of the box:
  • Change your hostname to something reasonable. Change your hostname in /etc/hostname and /etc/hosts and then reboot. The default is ubuntu which isn’t very good. To make the change permanent you run this where $new_hostname is whatever you pick and here’s a rough sketch of what is going on (although this script fails if the hostnames have strange characters loved by sed or bash like single or double quotes.


  • new_hostname=rich-ubuntu # Need the old hostname so easy to remove from /etc/hosts old_hostname=$(hostname) sudo hostname "$new_hostname" # change the hostname permanently sudo tee /etc/hostname <<<"$new_hostname" sudo sed -i "/^[!#].*$old_hostname/d" /etc/hosts sudo tee /etc/hosts <<<"127.0.0.1 $new_hostname"

    Avahi should already be installed but if you’ve change the hostname, you need to reboot so that it takes effect and you so you should be able to go to your Mac and browse

    • so try, ping rich-ubuntu.local and see if you get anything. This tells you the basic IP discover is working
  • Use the iPhone Discover application to see what properties are being offered by the system, by default with no Samba, it offers a single Bonjour service called the Workgroup manager service. Under the covers, Bonjour uses a DNS variant called mDNS-SD (multicast DNS service discovery). It is pretty simple, when you arrive on the network you respond to queries such as what file servers are there, then every client that is on the same subnet caches those responses. Since it is multicasting one packet essentially updates all the client on the network. It manages a special domain .local and overloads the TXT and other DNS records with information.

  • You can see if this is working by looking at /var/log/syslog and see if you get avahi events. Also run tcpdump and see if you can find avahi packets, although avahi-browse is easier to read.

  • As a kind of cool aside, if you put .local in your search entry in the network pane, then you can just type rich-ubuntu and not rich-ubuntu.local as a convenience.

  • An aside on how Avahi (aka Bonjour, aka Rendezvous works

    When a computer starts, it looks for an open IP address (probe and then take), then publishes it’s DNS address (an A record) and if there is no rejection takes it, then sends a multicast of SRV records for every service it has. The format of the service is:

    • The format of the services is the traditional reverse naming, so it starts with the domain, then the _protocol name, then the _service and then the (registered with the iana, then the user friendly name that is added a DNS SRV record Rich's file server._smb._tcp.local means in the domain local, over TCP/IP, is the protocol for server message blocks (the Window file server) and the name of the server is Rich's file server. The Apple file protocol name is _afpovertcp
  • In the SRV record is the TTL (time to live which is ignored) and the gold mind which is the actual hostname and port where you access the service. The PTR record is used to make it easy to take a general service like and point it at a particular instance so _printer._tcp.local. means any printer on the network and it can point to Rich's Printer._printer._local.

  • The TXT record is then used for multiple queues or things in the same SRV, so you can use it to further differentiate a SRV.

  • When a machine goes away, it will be around until it hits the TTL (time to live) in its A record which is why you see servers that no longer exist live a while.

  • IN the real world, the only service advertised is _workstation._tcp on port 9 which only the Synology servers we have (but not Mac OS X) advertises.

  • Install File Sharing

    Unlike Ubuntu, Xubuntu uses Xfce for windowing which uses the Thunar file manager as it’s environment and which uses Gigolo as a file sharing client.  The internet is littered with broken guides on how to make it all work. There seem to be a few approaches: a) Samba, b) Gigolo and c) Nautilus. I’ve tried Samba and it doesn’t seem to allow file sharing. Ubuntu uses Unity which is uses Gnome which uses the Nautilus file manager.
    But here is what you need to turn it on:

    • A huge problem with Xubuntu is that there appears to be no way to just search for a graphical application that I can find, so searching for “Share” doesn’t work. Instead, you have to know the name of the application and start it in Terminal. It is the Gnome application:

    shares-admin

    Then you have to choose Unlock at the bottom otherwise everything is greyed out. Then you need to pick a user name and a file location. Make sure to click off Read-only and it seems to work. Interestingly Avahi appears to update automatically. Sigh 24 hours to figure this out!

    File Sharing is embedded in Xubuntu ways that don’t work

    It is really a disadvantage working on a nth tier release. According to Distowatch, Mint (based on Ubuntu), Ubuntu and then Debian are the top three distributions. So be warned. Might try Mint.
     

    Install SSH

    Xubuntu doesn’t support ssh daemon by default, so to manage this file server, you need to:

    1. So you can administer the thing, get ssh with apt-get install openssl-server and then you can ssh in with the user account. On this machine with XFCE windows, it isn’t obvious, the name of the system is whoami and the name of the machine is hostname'. If you don't like these names, then there doesn't seem to be a graphical way to change this, so just do a sudoecho new-host-name > /etc/hostnameand then you need to also change/etc/hosts`

     

    Installing Samba didn’t work

    1. Installations include sudo apt-get install -y gksu system-config-samba which gives you Samba, the basic file sharing on a vanilla desktop version of Xubuntu. The firewall is turned off by default, but if you have it on, you open up the ports with sudo ufw allow samba
  • Now you want to create a share, you have to start the system-config-samba and set up the file share and the writable, visible and in our case we allow all users to access.

  • You will want to load up a disk and create some shares. This isn’t built into xubuntu, you need to do an sudo apt-get install gnome-disks and then from the terminal run gnome-disks and then create partitions. Note also that things like gnome-disks is graphical yet it isn’t automatically found. You need to start.

  •  

    1. You need to install and build netatalk with encription to be able to use AFS so it works with Macs too.

    I’m Rich & Co.

    Welcome to Tongfamily, our cozy corner of the internet dedicated to all things technology and interesting. Here, we invite you to join us on a journey of tips, tricks, and traps. Let’s get geeky!

    Let’s connect