This repository has many dependencies that are pinned to Ubuntu 24.04.x. It will not work with older versions of Ubuntu.
These tools work with Ubuntu. You'll create either a Desktop (GNOME) installation, or a Server (no GUI) installation. Setup a basic Ubuntu machine using your preferred tools and techniques, then use these tools to configure your installation with a standard suite of look-and-feel, tools, and settings that I use in my workflows.
This script sets up a new Ubuntu Desktop VM with the following software and settings:
- Setup and configure zsh and vim
- Initialize the terminal profile and GNOME text editor with a nicer color scheme.
- Install the following packages from the ppa:
- build-essential
- ccache
- gnome-text-editor
- python3-pip
- python3-venv
- seahorse-nautilus
- tree
- zsh
- Install and configure OhMyZsh and the powerlevel10K theme.
- Configure the GNOME favorites in the application launcher.
- Tune system settings:
- Disable auto screen lock.
- Set idle timeout to 'never'.
- Disable Ubuntu auto-updates.
- Patch
/etc/fuse.conf
to un-commentuser_allow_other
. This permits running programs from the command line when you're inside a directory in the share point.
Once you complete the initial setup of your desktop installation, open a terminal and run these commands:
cd
sudo apt install git curl -y # just to be sure
git clone https://github.com/geozeke/ubuntu.git
./ubuntu/scripts/desktop_setup.py
From there, follow the on-screen instructions.
These two scripts work together to initialize and configure a Server version of Ubuntu (one without a desktop environment). An easy and elegant way to create a server VM like this is by using Multipass.
server_initialize.py
After creating and logging-in to the new VM, run these commands:
cd
sudo apt install git curl -y # just to be sure
git clone https://github.com/geozeke/ubuntu.git
./ubuntu/scripts/server_initialize.py -h
Follow the directions provided in the on-screen help.
server_configure.py
After initializing the server, login with the new user credentials you
created when you ran server_initialize.py
. Then run the commands
below. The script will setup vim and OhMyZsh. NOTE: For all
new Ubuntu instances, a default account is created called ubuntu
. When
you run this script you also have the option to delete the default
account.
cd
git clone https://github.com/geozeke/ubuntu.git # yes, do it again.
./ubuntu/scripts/server_configure.py -h
Follow the directions provided in the on-screen help.
Once the configuration script is complete, do this:
- Reboot the VM.
- Login with your new credentials.
- Change your login shell to zsh by running:
chsh
and entering/bin/zsh
when prompted. - Logout and log back in.
- You should be all set.
This script sets up and installs the incredibly helpful utility pyenv. This utility allows you to install and manage multiple versions of python, without breaking the system default installation.
~/ubuntu/scripts/pyenv_setup.py
This standalone script will install Docker Engine, which is the
underlying client-server technology that builds and runs containers
using Docker's components and services. It also installs Docker
Compose, and sets up the appropriate user permissions to run
docker without having to enter sudo
first.
~/ubuntu/scripts/docker_setup.py
This is a standalone script that allows you to install the necessary files and settings to create a pleasant visual experience in vi. It's useful if you've got a user account (with no sudo access) on a Linux server and you just want a better look-and-feel for vi.
~/ubuntu/scripts/vim_setup.py