Skip to main content

HOWTO: An organized way to install programs @ your home folder

Installing stuff in linux usually requires root access .. this is true especially when the program which you want to install is a later version that the one that already installed in the system ..

As for some people, they might not want to pollute their RPM/DEB/put-a-packaging-system-here installations with installation from source tarballs and making the system hard to maintain using their distribution's package tools

However, it is not impossible for users to seamlessly install/upgrade programs into their own home folder, leaving the main system untouch .. you only need the program's source code , a compiler , and the development libraries ...

NOTE: This method may work with most programs out there that uses the ./configure script, however, some applications might refuse to work in this environment.

NOTE2: This article is targeted to people who already know their way when using linux. Its not targeted to newbies. However, I wont stop newbies from trying this. Its a good learning experience ;-)

NOTE3: I will not be responsible to whatever damage it might cost you .. Try it at your own risk .. However, I dont think this will damage the whole system because u only work in your home folder without using root .. Normally if you do messed up, you'll only make the user unusable, just delete the user and create a new one.


Before starting to install any programs using this method, we'll need to modify some PATH settings first.

First create these folders in your home folder : ~/bin , ~/local/ , ~/local/bin , ~/local/sbin , ~/local/etc , ~/local/opt , ~/local/lib , ~/local/share , ~/local/var ; These folders will be where you install your compiled programs

Then, open ~/.bash_profile and change this line (or similar)


into this


This will make the installed programs in your home folder have higher priority when executing it without full path.

Logoff and relogin for the settings to take effect.

Now we are done with the preparation, lets proceed in the method to install programs into your home folder

Compiling and Installing

Untar the source packages into somewhere you like ( I usually untar it in ~/local/src/build/ ). Change directory into the folder and run

./configure --prefix=$HOME/local/
make install

This will work with programs that uses the usual procedure of this method. Some might requires some extra stuff to be done first before make. Basically , the most important part here is the --prefix=$HOME/local/

After installation, try executing the command and check whether it works or not. For example, if you compile a new nmap, run

which nmap

if the output is ~/local/bin/nmap , congratulations, you succeeded XD .

If it works, you're done. And If not, you might have done something that made it doesn't work and good luck finding it ;-P

NOTE: Some programs might need you to export LD_LIBRARY_PATH=$HOME/local/lib before executing the program

How about packages that comes in a standalone tarballs? Eg. Azureus

Simple, just extract the tarball into ~/local/opt/ and create a symlink in ~/local/bin to the program's executables. And you're done.

You can also create a folder ~/local/opt/bin for symlinks related to ~/local/opt programs. Just make sure you add $HOME/local/opt/bin into the PATH declaration in ~/.bash_profile


Linux is a very flexible environment and a very fun one if you know how to use and manipulate it. Enjoy~~ (^-^)
Post a Comment

Popular posts from this blog

Adding simple popup to Plone frontpage

Here is a little guide for those who want to add a simple popup to the Plone frontpage for some purpose (eg: announcements, advertisements, etc).

Create a basic html file containing the content you want to appear in the popup. Upload it into $PLONE_SITE/portal_skins/custom (as Page Template) and for the sake of this example, name it popup.html

Afterward, create a Javascript file with your Pop-Up loader script. For example , this script:

function popup(mylink, windowname)
if (! window.focus)return true;
var href;
if (typeof(mylink) == 'string')
href=mylink.href;, windowname, 'width=220,height=400,scrollbars=no');
return false;

popup('popup.html', 'My Popup');

Also upload this file into $PLONE_SITE/portal_skins/custom (as Page Template too). For this example, name it as popup.js

Afterward, in $PLONE_SITE/portal_javascripts , add popup.js as a new script into portal_javascripts…

Consolidated community site infrastructure on Plone

In Inigo, we believe in helping out local FOSS communities and help them grow. We help out in community events where we can, present FOSS talks, and provide some platforms for local communities to grow. One of such platform is our consolidated community site infrastructure on Plone.

The system/infra and its components was originally developed for the Fedora Malaysia website, while keeping in mind to keep it generic enough so that other communities could use the same components for their own community sites. The infra is already at a usable state, and we can add new sites easily with just a few clicks.

Features in this consolidated infra are:
Document/Content management (Plone built-in)Calendar system (powered by solgema.fullcalendar addon)Conference/BarCamp system (powered by collective.conference addon, which was developed for FUDCon Kuala Lumpur 2012)Blog (powered by Products.Scrawl)Simple yet powerful theming engine (powered by Diazo) - Check out Diazo, you'l…

HOWTO: Mirroring Yum repositories using Yum-Utils

As promised before in one of my previous post, a Howto on how to mirror and manage yum repositories using some of the utilities in yum-utils.

The first step is, well, of course, is to get yum-utils from fedora repository
yum install yum-utils

Reposync is a utility for mirroring and synchronizing local copy of a yum/rpmmetadata repository.

This utility is very useful if you wanted to make a yum repository mirror. Before this, I used "wget -R -np -N" but this method is a little bit tedious and it doesnt work with repos that didn't use directory listing. Plus, it also download together additional site stuff that I don't need/want and it doesn't verify checksum of the downloaded packages.

Mirroring a repo using this utility is easy, just execute this command
reposync -r <repoid> -a <arch> -n
and the repo will be mirrored in a folder with the same name of the repoid in the directory you executed the command. Eg: you executed the command in /mnt/storage/mi…