Minimal Ubuntu

  Last modified on Sunday 14 August 2016


Ubuntu 16.04 "Xenial Xerus" is the latest Long Term Support (LTS) release of the popular Linux operating system. I use Ubuntu's minimal install image to create a console-only base configuration that can be customized for various tasks and alternate desktops.

Let's go!

Below is a visual walk-through of a sample Ubuntu setup that makes use of an entire storage device divided into 3 partitions: an unencrypted root partition, and encrypted swap + home.

0. Prepare install media

Download the 64-bit xenial minimal installer (32-bit for older machines) and burn to CD or flash the image to a USB stick. [1] Using the minimal console installer vs. the graphical installer provides more options during setup. [2]

Minimal installer (requires network connection) downloads all the latest packages during setup.

1. Launch

Install Select Language Select Location Configure Keyboard Configure Keyboard Configure Keyboard Hostname Mirror Country Mirror archive Proxy

Contents of the installer are now loaded into memory and the USB stick can safely be removed. [3]

Full Name Username User password Verify password Encrypt home Configure clock Select time zone

2. Partitions

In the example below I create 3 partitions [4] on the disk:

  • sda1 is a 24GB root partition
  • sda2 is a 2GB LUKS encrypted swap partition using a random key
  • sda3 uses the remaining space as a LUKS encrypted home partition using a passphrase
Partitioning method Partition disks Partition table Free space New Partition Partition size Primary partition Beginning

Setting Mount options: relatime decreases write operations and boosts drive speed ...

Mount options Mount relatime Done with partition Free space New partition Partition size Primary partition Beginning Use as Encrypt volume Encrypt key Random key

If the hard disk has not been securely wiped prior to installing Ubuntu (using a utility like DBAN) you may want to configure Erase data: yes. Note, however, that depending on the size of the disk this operation can last several hours ...

Done with partition Free space New partition Partition size Primary partition Use as Encrypt volume Encrypt key Passphrase Done with partition Configure encrypted volumes Write changes Create encrypted volumes Devices to encrypt Finish Encrypt passphrase Verify passphrase Configure encrypt volume Mount point Mount home Mount options Mount relatime

Reserved blocks can be used by privileged system processes to write to disk - useful if a full filesystem blocks users from writing - and reduce disk fragmentation. On large, non-root partitions extra space can be gained by reducing the 5% default reserve set by Ubuntu to 1% ...

Reserved blocks Percent reserved Done with partition Finish Write changes

3. Install packages and finish up

No automatic updates

Alternative: For a home server setup I like to select Install security updates automatically for a device often running unattended ...

Install security updates

Select [*] standard system utilities and leave the remaining tasks unmarked if you wish to start with a minimal, console-only base configuration ready for further customization ... [5]

Software selection

Alternative: Or - again, for a home server - select the few extras included in [*] Basic Ubuntu server ...

Software selection

Packages are downloaded and the installer makes its finishing touches ...

GRUB UTC Finish install

4. First boot

System will display a passphrase prompt to unlock encrypted home partition ...

Enter encrypt passphrase Login

Login ... then run timedatectl to confirm system time+date is properly set.


After running a minimal install on my C720 Ubuntubook with encrypted swap + home partitions I ran into this issue: "Black screen instead of password prompt for boot encryption".

I had to enter my passphrase blind and ALT+F1 to console. When I tried removing the GRUB options splash and/or quiet I lost the ability to enter the passphrase at all and a hard reset was required.

Fix: Modify /etc/default/grub ...

# Force the kernel to boot in normal text mode with '=text'

... and update ...

$ sudo update-grub

Now it works! My chromebook is the only device I have run into this issue.

See: GNU gfxpayload

6. Network

Check which network interfaces are detected and settings ...

$ ip a

Wired interfaces are usually auto-configured by default and assigned an IP address courtesy of DHCP.

To assign a static address, deactivate the wired interface and create a new entry in /etc/network/interfaces. Sample entry for enp3s0 ...

# The primary network interface
auto enp3s0
#iface enp3s0 inet dhcp
iface enp3s0 inet static

Bring up|down interface with sudo if{up,down} enp3s0.

Create a temporary wireless interface connection to WPA2 encrypted access points manually using wpa_supplicant + wpa_passphrase + dhclinet. Sample setup of wlp1s0 ...

$ sudo ip link set wlp1s0 up            # bring up interface
$ iw dev wlp1s0 link                    # get link status
$ sudo iw dev wlp1s0 scan | grep SSID   # scan for access points
$ sudo -i                               # simulate a root login shell (for wpa_supplicant)
# wpa_supplicant -B -i wlp1s0 -c<(wpa_passphrase "MY_SSID" "MY_PASSPHRASE")   # connect to WPA/WPA2 ... '-B' sends the process to the background
# exit
$ sudo dhclient wlp1s0                  # obtain IP address

More permanent configurations may be set in /etc/default/interfaces. Sample setup [6] with a static IP address ...

iface wlp1s0 inet static
    wpa-ssid MY_SSID
    wpa-psk MY_PASSPHRASE

Alternative setup using DHCP ...

allow-hotplug wlp1s0
iface wlp1s0 inet dhcp
    wpa-ssid MY_SSID
    wpa-psk MY_PASSPHRASE

Once a link is established an optional network manager utility may be installed. Package network-manager-gnome provides the console nmcli and graphical nm-applet clients ...

$ sudo apt install network-manager-gnome

Comment out (deactivate) any entries in /etc/network/interfaces that will be managed by network-manager.

7. Where to go next ...

... is up to YOU. Yeehaw.

Happy hacking!


[1]An alternative is adding the image to a USB stick with multiple Linux installers.
[2]Specifically, the console installer provides a random key option for the encrypted swap partition.
[3]Recommended: Otherwise the partitioning tool may designate the USB device as primary (sda) storage and lead to broken partition layouts.
[4]For storage devices >=128GB I create separate root + swap + home partitions. Smaller devices get boot + swap + root partitions. Note encrypted root requires an unencrypted boot.
[5]The task selection menu can be run post-install using sudo tasksel.
[6]Multiple wireless static IP address setups can be created with iface wlp1s0_NAME inet static and [de]activated with sudo if{up.down} wlp1s0=wlp1s0_NAME.

More • ubuntulinuxserver