Search This Blog

Saturday, 29 December 2012

Ubuntu fix - an epic

Much as in the "for the want of a nail the battle was lost", with its escalating list of consequences emanating from a minor incident, I decided earlier this week to resolve an issue I'd been experiencing with my Ubuntu server. It turned into a major undertaking.

The issue made itself apparent on (infrequent) reboots, where disk checks would typically advise that the home folder had errors and mount was difficult.

Unlike Windows (not something I thought I would find myself saying), disk checks - fsck - cannot be run when drives are mounted.

That means booting from USB or disk.

My server was not built with an optical drive - I didn't think I'd need one. As it turns out, when my son's Dell finally gave up the ghost, I salvaged its DVD writer and that is now in the caddy.

Problem 1 : There are two SATA data connections on my motherboard. Both of these are taken by existing HDDs. So I cannot connect the DVD drive.

Potential solution 1 : Run from USB. So I downloaded the image (on my Mac) and then followed the instructions to make a bootable USB stick - http://www.ubuntu.com/download/help/create-a-usb-stick-on-ubuntu

Put the USB in, booted. Didn't work.

Potential solution 2 : Copy the image (as downloaded) onto the USB, copy THAT on to the Ubuntu machine and use Start up Disk Creator. Also didn't work.

Potential (and actual) solution 3 : Attach an external disk drive to Ubuntu machine and use that. Using the image I'd already downloaded, I made a boot disk of Ubuntu 12.10 (machine is currently running 12.04). Boot up, hitting F11 to get to boot menu. Choose the optical drive to boot from.

This takes me into the Ubuntu start up disk. Boy is it slow.

Intention at this stage is still to run fsck and avoid the need for a reinstall. So through the drives I go, running fsck on them.

But that doesn't fix the errors. I get new and interesting messages. I search for solutions. I struggle....

Problem 2 : Can't fix the errors

Potential solution 4 : Reinstall.

There are, of course, numerous options when reinstalling. My data is backed up, so easiest is a clean reinstall.

That means a bit of disk partitioning first, as I want to have a separate swap partition and one for /home (concept being that in future I just update the system files). I also have to select a boot installer. I misunderstand this and choose the overall drive, NOT the part where the files reside.

So of course once the install has happened (which takes a LONG time), when I attempt to boot I get error messages from GRUB : Error 15 file not found

Well that shouldn't be too difficult to fix, should it? All I need to do is reboot, get into the GRUB menu and choose the right option.

Nope. This is Grub 2. It doesn't use ESC to skip out to menu. It uses Shift. Except it doesn't. I try both shift buttons, holding them down, pressing repeatedly. No joy.

Fair enough, I'll boot again using install disk, drop to Terminal and make the necessary edits.

So now I wait another eternity for disk boot to start. Then, due to the horrible Unity interface, Terminal is not immediately present as an option. So now the delight of Dashboard and its responsiveness of a glacier.

Into Terminal I go, and then start trying to take on board the logic I can see in numerous posts about Grub 2 and this error, all of which say something slightly different. None work for me.

Potential (and actual) solution 5 : reinstall again, but this time get the boot installer properly specified

Problem 3 : It boots - hooray! But.... it's STILL as slow as hell. This suggests the problems with speed were not related to the optical drive being external, but possibly due to 12.10 itself (and I have seen some posts to that effect)

Potential (and actual) solution 6 : install an earlier version.

I had an earlier disk of 11.04, so decided to start from this point and then update online.

This time, at least, I was aware of the options regarding bootloader. However, despite my best efforts, the installer seemed really keen to install on my 1TB internal drive, which is purely data, rather than my 120GB drive.

Aha, I'll get round that by physically disconnecting those drives and then adding them after and changing mount points if necessary.

We now actually reach a solution! (well, partial). The install worked, boot was speedy and all worked.

Next step - lots of updates, and a system upgrade to 11.10.

End of the story? Nowhere near.

Firstly, I needed to re-attach the drives and mount them. This meant editing my fstab also. Fortunately I'd backed up my old fstab, so could base on this.

The 1TB drive mounted and worked fine with fstab. My "other" 120GB drive (which houses videos), wants to be the same as my "home" and filesystem 120GB drive. I've not yet solved this issue.

There was then the matter of ensuring aspects of my previous install that worked well for me were also in place on my fresh install. And that I removed unnecessary items.

Unnecessary was pretty straightforward as this could all be done via Synaptic. Amongst others I removed Evolution and Thunderbird - I'm running the server for firewall management and for data storage, so much of the superfluous can go.

(Incidentally, I also discovered that "Installed (Residual Config)" applications can all be removed in Synaptic! Didn't realise this before)

As for adding apps, this meant:

  • Bleachbit
  • Calibre
  • GTKOrphan
  • StartUp-manager
  • Locale
  • Gparted

Next step, run Localepurge to clear unnecessary files, then Bleachbit and GTKOrphan to clear other files no longer needed.

See also http://ubuntuforums.org/showthread.php?t=1560872 and http://ubuntuforums.org/showthread.php?t=140920&highlight=deborphan

Then, as I'd saved my previous bash_history, copy this over to my new install so I can refer back to useful previous info.

I'd stated previously that I use the server for firewall management. Fortunately, I'd copied my three sets of iptables rules, so was able to restore them.

Which left backup usage. Connecting via Samba from my Mac was my previous method of access.

Samba is not installed at outset on Ubuntu, so had to install it. But there is Samba4 and Samba.

This may have caused me the problems I next experienced:

Problem 4 : Samba sharing not working

Samba installed and then smb.conf amended. Now, I hadn't made notes of how I'd done this before (nor, sadly, had I copied the config), but I can't remember it being as involved as this.

Essentially, any attempt at starting, restarting or stopping smbd was just not working ("restart: Unknown instance:")

Potential solution (and actual) 7 : completely remove Samba (all / any versions) and then reinstall.

This time I avoided the Samba 4 complications, and now

sudo restart smbd

and

sudo restart nmbd worked

Problem 5 : Back to the Mac, CTRL-K and choose server name. "The server cannot be found"

Potential (and actual) solution 8 : The Mac is looking for a static IP address. I have not yet assigned a static IP to the server. This I now do.

Problem 6 : The Mac is looking for a static IP address that now exists, but still no joy with Samba.

Potential solution 9 : Let's try and see if ssh works instead!

Problem 7 : ssh not installed by default

Potential (and actual) solution 10 : install ssh, and then $ sudo service ssh start.

Problem 8 : Host key verification fails!

Potential (and actual) solution 11 : http://stackoverflow.com/questions/4161548/how-to-establish-ssh-key-pair-when-host-key-verification-failed - ssh-keygen -R hostname

This deletes the offending key from the known_hosts

It works! I am connected on the network. So why not Samba?

Potential (and actual) solution 12 : Reference to https://help.ubuntu.com/12.04/serverguide/samba-fileserver.html finally got Samba working for me - and an rsync worked perfectly for me.

TODO:

  1. Issues with mounting the two 120GB drives
  2. Purchase and install a SATA PCI card to allow use of the optical drive
  3. Map the Ubuntu drives on Mac - http://osxdaily.com/2010/09/20/map-a-network-drive-on-a-mac/
  4. Amend smb.conf to remove duplication of home directories


LESSONS LEARNED:

  1. Backup MANY more of the config files
  2. Keep a full list (regularly updated) of the installed applications
  3. Keep a more recent set of install discs