This tutorial shows how to completely remove or uninstall a package in Ubuntu 12.10. These instructions should work for other versions of Ubuntu, it’s derivatives (Edubuntu, Kubuntu, Lubuntu, Xubuntu, Ubuntu Studio, Myhtbuntu) and other Debian based Linux distributions – but no guarantee is made.
This tutorial is definitely on the advanced rather than basic side of things, but if you are careful, it shouldn’t be a problem.
WARNING ! ! !
There is a small but real risk of data loss or making other programs or Ubuntu unusable.
It is advisable to ensure you have a backup before proceeding.
I am somewhat over emphasizing the risk, but anything can happen – there might be a power failure in the middle of uninstalling and this might leave your system in a funky state, or you might select a critical system file for deletion and this leaves your system unusable.
I don’t expect anything bad to happen, but I make no guarantees.
Note: the risk is about the same as applying software updates (old packages are removed and new packages are installed).
You can jump directly to the How To part here.
You would think that uninstalling a package would be as easy and straightforward as installing it – either enter sudo apt-get remove --auto-remove <package name>
at a command line or click Remove in the Ubuntu Software Center. Unfortunately, it is not:
The Problem
There are three types of packages: (1) simple, (2) with dependencies, (3) complicated.
Simple packages install only a single program file and that’s it. They are completely self contained and don’t depend on anything other than the core operating system being present. These types of packages are rare.
stella (an Atari 2600 emulator) is an example of a simple package.
Packages with dependencies need other files in order to work. When installing one of these packages, Ubuntu Software Center or apt-get determine what other files are needed and automatically installs them for you. Unfortunately, when you uninstall the package, the dependency files are usually left behind. Sometimes they can be removed by using the command sudo apt-get autoremove
, but that is an exception rather than the rule.
stellarium (a 3D planetarium / sky simulator) requires an additional file (stellarium-data) to be installed in order to work. When you uninstall it, it leaves behind stellarium-data. The good news is that stellarium-data can be uninstalled using sudo apt-get autoremove
.
abiword (a word processor) requires additional files (about 16) to be installed. One of these is ttf-lyx (a font). When you uninstall, abiword it will automatically uninstall some of the files, the remainder can be removed using sudo apt-get autoremove
, but the file ttf-lyx must explicitly removed.
Complicated packages (also called metapackages), typically, do not install any files. Instead, they are a collection of dependent packages. These are the hardest to clean up, since you have to uninstall each dependent package (along with its dependencies) separately.
lubuntu-desktop (a desktop environment based on the lxde interface) is an example of a package that installs several dependent packages. Each of those packages installs other packages and files. All told, about 189 files get installed. When you uninstall lubuntu-desktop, it only removes lubuntu-desktop (about 30kB). Using sudo apt-get autoremove
removes nothing else. All the extra files which were installed because lubuntu-desktop said it depended on them remain behind and they use up about about 321 MB of disk space.
These include packages like abiword, leafpad (a text editor), lubuntu-core, lxde-common, along with many, many other packages.
Note:The 30 kB and 321 MB are not typos, uninstalling lubuntu-desktop leaves behind about 99.99% of everything it installed.
Not only are various packages left behind after an uninstall, but also configuration data used by the removed package, directories (folders) and user data – all of these have to be manually removed.
Why Can’t Everything be Uninstalled?
My best guess is because it is a low priority:
-
Users want applications to install easily and work. In the (fairly distant) past, installing applications in Linux was a pain – users would install an application and it wouldn’t work, then they would discover they needed to install some other package to get it working, and then there were package incompatibilities (still a problem in Linuxland) and so on. Nowadays, most Linux distributions do a very good job in packaging applications for easy installation.
-
Hard disks are big. If you have a 500GB hard disk, will you really notice if 3MB or 50MB or even 1GB of data are cluttering it up? Probably not, the files cached by your Internet browser’s likely occupy more space on your hard disk.
-
It is not sexy. Who cares if a programmer wrote a really neat uninstaller? Probably no one. Programmers are more interested in “cool” apps. And since it is possible to manually uninstall all the unnecessary applications, there is no incentive to write a proper uninstaller.
-
Uninstallation should be a “rare” activity. Although, I think users are very likely to want to try out applications and uninstall them if they don’t like them or find it is not what they wanted.
- It is hard. If the user uninstalls something shortly after installing it, this is not too much of a problem because nothing much is likely to have happened on the system. But if the user chooses to uninstall something 2 years after they installed in – then there are numerous problems: (1) other applications may have been installed that depend on some of the same files (this makes deciding which files to uninstall complicated), (2) it is likely that updates and upgrades have been applied over time (the files and dependencies may have changed. Consider a program that originally depended on a file called cutting-edge-library, but later the developers switched to using mature-and-stable-library instead – this poses problems to the uninstallation program.
-
Finally, if the uninstaller breaks an application the user wants to keep, the user is going to be unhappy, so it is better to be very conservative when uninstalling.
All the information needed to uninstall an installed package is available (sometimes it takes a little poking around). The only information not available is which files and folders are created by an application – so cleaning up all the config data, application folders and user data is harder.
This is a long standing problem with Linux – many projects have been started (and abandoned) whose purpose was to clean up leftover files on the computer.
How to Completely Remove a Package
Quick Instructions
1) Open the aptitude log file (/var/log/apt/history.log
).
2) Locate the files that were installed.
3) Remove the files using sudo apt-get remove --auto-remove <file names>
NOTE: it is a good idea to ensure that you are not removing any extra files. This might happen if you (or someone else) has installed other packages or updates.
4) Locate and remove configuration files and data associated with the package. Most often, they will be found in /home/
and /home/.config/
directories.
Detailed Instructions
Finding Out Which Packages Were Installed
These instructions are for Ubuntu 12.10, using the Unity interface and the Terminal
application.
I expect the instructions to be similar for other environments, but no guarantee is made.
Instructions for opening a terminal can be found here.
Opening the Installation History Log File
All installation and uninstallation operations that happen using apt-get
or Ubuntu Software Center (or any of the aptitude
family of functions) are stored in /var/log/apt/history.log
. Examining the contents of this file allows us to determine which packages were installed.
1) Click on the Home Folder icon:
2) Click on File System:
3) Double-click on the var
folder:
4) Double-click on the log
folder:
5) Double-click on the apt
folder:
6) Double-click on the history.log
file – this should open it with gedit
, the default text editor in Ubuntu 12.10:
A Quick Overview of the history.log File
The history.log
file contains all the operations performed on your system using apt-get
(or any of the aptitude
family of programs)
Each block of operations contains:
- a Start-Date and End-Date (red) for the operation
- the operation performed (blue)
- additional information about the operation (green)
In our case, we are interested in the Install
information.
Finding the Installation Data
7) Search for the package you installed. If it was the last package you installed, then it will be at the end of the file. The records are stored with the newest operations towards the end (bottom) of the file and the oldest at the beginning (top) of the file.
Note: the history.log
file is archived monthly. If you don’t find the required install information in history.log
, then check the history.log.<number>.gz
files:
Double clicking the .gz file will open it with Archive Manager. Inside Archive Manager you double click on the file to open it with gedit
In the sample below, you can see I installed lubuntu-core
on 29-Oct-2012:
Start-Date: 2012-10-29 21:52:00
Commandline: apt-get install lubuntu-core
Install: lightdm-gtk-greeter:i386 (1.3.1-0ubuntu1), libobrender27:i386 (3.5.0-4, automatic), lxsession:i386 (0.4.9.1~git20120828-0ubuntu1, automatic), openbox-themes:i386 (1.0.2, automatic), libfm-data:i386 (1.0.1-0ubuntu1, automatic), libfm-gtk-bin:i386 (1.0.1-0ubuntu1, automatic), obconf:i386 (2.0.3+20110805+debian-1, automatic), lubuntu-default-settings:i386 (0.29), lubuntu-icon-theme:i386 (0.34, automatic), lxsession-data:i386 (0.4.9.1~git20120828-0ubuntu1, automatic), lubuntu-artwork:i386 (0.34), plymouth-theme-lubuntu-text:i386 (0.34), pcmanfm:i386 (1.0.1-0ubuntu1, automatic), lubuntu-core:i386 (0.45), libfm-gtk-data:i386 (1.0.1-0ubuntu1, automatic), libgif4:i386 (4.1.6-9.1ubuntu1, automatic), libfm-gtk3:i386 (1.0.1-0ubuntu1, automatic), lubuntu-lxpanel-icons:i386 (0.34, automatic), lubuntu-artwork-12-10:i386 (0.34, automatic), openbox:i386 (3.5.0-4), libglade2-0:i386 (2.6.4-1ubuntu2, automatic), gnome-icon-theme-full:i386 (3.6.0-0ubuntu2, automatic), elementary-icon-theme:i386 (2.7.1-0ubuntu6, automatic), lxmenu-data:i386 (0.1.2-2, automatic), libfm3:i386 (1.0.1-0ubuntu1, automatic), lxshortcut:i386 (0.1.2-3, automatic), lxpanel:i386 (0.5.10+git20120823-0ubuntu1), libid3tag0:i386 (0.15.1b-10build3, automatic), libimlib2:i386 (1.4.5-1ubuntu1, automatic), libmenu-cache1:i386 (0.3.3-1, automatic), libobt0:i386 (3.5.0-4, automatic), plymouth-theme-lubuntu-logo:i386 (0.34)
End-Date: 2012-10-29 21:57:50
8) Cut and paste the Install data into an editor. You can start a new document in gedit
by clicking on the Create a new document icon:
9) Edit the data to remove all unnecessary text.
The data has the following form: <package name>
:i386 (something in parentheses),
Only the package name is important. The :i386 (something in parentheses), needs to be deleted.
So libopenal1:i386 (1.13-2, automatic)
becomes libopenal1
after removing the extra information.
If you have a lot of text to edit (as in this example), you might consider using a text editor that offers regular expression matching – like LibreOffice Writer – for search and replace.
Using LibreOffice Writer 3.6.2.2, you can use one of the following regular expressions (I think they are complete, but they might miss the odd expression):
Use this if you are running the i386 version of Ubuntu:
:i386 \([0-9\~\.\+a-zA-Z\-, ]*\),?
Use this if you are running the amd64 version of Ubuntu:
:amd64 \([0-9\~\.\+a-zA-Z\-, ]*\),?
Let me know if you encounter a case where the regular expression doesn’t work.
Press Ctrl + H
to launch the Find and Replace dialog in LibreOffice Writer.
- Click on the More Options button (it will change to Fewer Options).
- Click on the Regular expressions box.
- Enter the regular expression into the Search for field.
- Click on the Replace All button.
10) Add the following to the start of the edited package list: sudo apt-get purge --auto-remove
. You should have something that looks like this:
sudo apt-get purge --auto-remove lightdm-gtk-greeter libobrender27 lxsession ...
I recommend use of the purge
option over the remove
option because purge removes some of the configuration data.
You can always use sudo apt-get remove --auto-remove
instead.
Note: if you are using LibreOffice Writer make sure that it does not autocorrect what you are entering.
Two very common problems are:
- the ‘s’ in
sudo
gets changed to UPPERCASE. The Linux command line is case sensitive, soSudo
is not the same assudo
. - the double minus (–) gets converted in a single DASH (–).
Either error will cause the uninstall script to fail.
11) Cut and paste this package list with the apt-get
command from step 10 into a Terminal
to completely uninstall the package.
To paste into a terminal, you need to right-click in the terminal and select the Paste option from the popup menu. Using the traditional shortcut Ctrl+V
will not work.
Detailed instructions on how to open a terminal can be found here.
It should look something like this (the exact list of files will depend on what you are uninstalling):
12) Press the Enter key and enter your password (this is your login password):
NOTE: when you type your password, nothing will happen on the screen. This is normal. As a security feature, Linux does not echo back any indication of the characters you are typing in.
Note: You will only be asked for your password if this is the first time in this terminal session that you are using sudo apt-get
.
13) Press the Enter key after entering your password and apt-get
will respond by showing which files are going to be uninstalled:
If you want to uninstall the files, then press the Enter key. If you don’t want to uninstall the files, type the N
key and then press the Enter key.
Note: if this was not the last package installed. Or if updates have been installed, I STRONGLY advise you to double-check the files being uninstalled to ensure they do not include any extra files.
WARNING ! ! !
This should work perfectly if the package you are uninstalling is the LAST package you (or anybody else) installed on your system. In other words: No one has installed anything else – not even updates – since this package was installed!
If other packages have been installed, if updates have been installed, then there is a RISK that those packages or updates may have a dependency on one or more of the packages you are uninstalling.
If you uninstall a package that some other package depends on, then that package will no longer function correctly.
Examining all package dependencies is very complicated. Proceed at your own risk – backups are strongly recommended.
Double Checking Your Uninstall Script
If the package you are uninstalling was not the last package installed, there is the risk that you will accidentally uninstall a package that some other application depends on.
Why Double Check?
For example, you install abiword. Abiword depends on the package ttf-lyx and it will be installed it if it is not already installed.
Later, you install cadabra. Cadabra also depends on ttf-lyx, but since it is already installed, it will use the installed copy instead of installing a new copy.
If you uninstall abiword using the technique above, it will explicitly uninstall ttf-lyx (which is also needed by cadabra – which was installed after abiword).
This will cause apt-get
to uninstall cadabra because cadabra depends on ttf-lyx.
To avoid this problem, it is necessary to double check that you are not removing any extra files.
Since apt-get
displays the files it is going to uninstall, it is a simple matter of checking that no additional files were added to the uninstallation:
Uninstalling Configuration Data
I don’t recommend doing this unless you know exactly what you are looking to delete.
The last thing left to do is to delete / remove all the configuration data.
Unfortunately, this is hard to do since there is no record of what files and folders the (now uninstalled) application put on your computer.
A good place to start is in your /home
directory and your /home/.config/
directory.
However, data, files, and folders could be squirreled away all over the place.
As you can see from these screenshots, it is not necessarily obvious what folders and files need deleting: