Thursday, July 23, 2009

Configuring gitweb in Linux

Gitweb is a web interface to git. I use frequently gitweb to view repository inside browser and hence configured the same on my laptop running Linux OS.

Apache is used as a web server to run gitweb.
Below is a step by step guide to setup git inside Linux using Apache.
1. Download gitweb from web. Run "yum install gitweb" for distributions supporting yum.
2. Add the following code to httpd.conf file (generally in /etc/httpd/conf/httpd.conf)

<VirtualHost *:80>
DocumentRoot /opt/git
ServerName git.pawan.com

Allow from all
AllowOverride all
Order allow,deny
Options ExecCGI

SetHandler cgi-script


DirectoryIndex gitweb.cgi
SetEnv GITWEB_CONFIG /etc/gitweb.conf
</VirtualHost>

NameVirtualHost *:80
3. Set the repository root path inside /etc/gitweb.conf as shown below.
$projectroot = '/opt/git/';
4. Restart Apache HTTPD server to take effect by "/etc/init.d/httpd restart" or the corresponding command as per your distribution.
5. Visit http://localhost/git to view git repositories on web.

Setting up of local Git repository.

Git is a great distributed source code management (SCM) software developed by Linus Torvalds. Merging in git is simply awesome. I have used in the past subversion, cvs and VSS but now using Git extensively for small and large projects. It helps you to focus really on development rather than nuiances of typical SCMs.

Below is a step by step guide to setup Git on a Linux machine (My machine configuration is: Fedora Core 10, Kernel 2.6.30)-
1. Choose a folder where you want to keep all git repositories. I have placed all source code in /opt/git (say GIT_HOME)
2. Go to GIT_HOME. Create a new repository directory say Test.git. It is just a convention to put .git in the end of repository name.
3. Initialize newly created repository using "cd Test.git/; git --bare init"
4. Go to project folder which you want to put in git repository. Say, for ex Test inside /pawan/workspace/Test.
5. Initialize desired project folder using command "git init"
6. Add the newly created git repository inside Test/ using "git remote add origin ssh://localhost/opt/git/Test.git" (This assume you have already configured SSH)
7. Now, add desired folders and files in working project folder using "git add .". If you want to add only specific type of files, use "find . -iname "*.java" | xargs git add"
8. Commit all of your changes using "git commit -a -m "Initial version for Test.". Please change the message you want to change after -m.
9. Now, push the local code to repository using "git push origin master".
10.View the repository in gitweb and you will see your code inside git repository.

Visit http://git-scm.com/ for visual and written tutorials.

Thursday, February 12, 2009

Run Windows inside Linux

Generally I doesn't like all MS products very much but Project Plan and Visio (dia - open source is an alternative but not so user friendly) seems to be very impressive to me. These are some of the great tools developed by MS team. Though I use Linux at work and at home full time but when it comes to creating a project plan and nice design and architecture diagrams, I prefer MS Project Plan and Visio resp. My laptop came preinstalled with Windows XP and a recovery disk for the same. Now, I am using VirtualBox (http://www.virtualbox.org/) to run windows XP inside Linux. It is very easy to configure and gives you lot of features you would need to run and use windows easily inside Fedora Core 10 (distribution I am using) with 1.5GB RAM and 1.73GHz Intel 32bit processor.

Easy search and replace in a directory

A python script to search (http://groups.google.com/group/pawan-kumar-group/web/SearchReplaceUtil.py?hl=en) for a keyword and replace the same with the proposed keyword inside a directory recursively.

Query RPM packages easily

This is a very basic query script (http://groups.google.com/group/pawan-kumar-group/web/pkrpm?hl=en) to get information about an installed RPM package in OS supporting Redhat Package Manager (RPM).

Change images in WindowMaker

It is always good to see pictures of your loved ones in the background appearing one after another while working. This python script (http://groups.google.com/group/pawan-kumar-group/web/changeimages?hl=en) gives you the ability to set images on dynamic basis inside windowmaker.

Tuesday, January 20, 2009

Making Cisco VPN Client work in Linux

The easiest way would be to install "vpnc" package which provides client for Cisco VPN concentrator (more information http://www.unix-ag.uni-kl.de/~massar/vpnc/).

On various OS, "yum" can be used to download and install the package.

#yum install vpnc

Once installed, you can use great script pcf2vpnc developed by Steven. This is useful only if you already have a .pcf file available with you.

#pcf2vpnc Input.pcf US-VPN.conf

NOTE: You can give any meaningful name to the output configuration file. Copy the output file to "/etc/vpnc" folder.

#cp US-VPN.conf /etc/vpnc

Cisco VPN server can be connected using below command

#vpnc US-VPN

If everything goes well, you are connected to the VPN server.


SquashFS, AUFS, Video4Linux, Cryptoloop and ext4 support in latest kernel 2.6.28

I always believe in "Need is the key to invention".

Though we are not going to do an invention here but will follow simple steps to customize the Linux kernel as per the need.


I had to do this for a variety of reasons -


1. I need to compress data stored on various partitions to save space and make them available in both read-only and read-write mode.
2. Integrated webcam (ALi Corp. camera) which comes with Lenovo Y300 13' laptop is not recognized by default by Fedora Core 10.
3. Accessing my new HTC Touch mobile phone inside Fedora.
4. To encrypt my important and personal data inside encrypted files and partitions.
5. To incre
ase the performance of writes and reads on hard disk.

Hence the journey began....

One of the most important thing to keep in mind while building kernel is to know what you want to achieve out of that unless somebody just want to know how it feel to compile and run customized kernel.

Searching Google for all above points gave me pointers as to how to go ahead and add support for all of
them.

First thing which one has to perform is to download latest kernel from www.kernel.org. I had chosen the latest version 2.6.28 which was available at that time.

Once downloaded, unfold its source inside a directory which having approx. 2.0 GB of space. Actually less also will do but to compile most of the modules and almost every feature provided within the kernel, one would need that much of space.

[Italic font shows commands to be executed on any shell inside Linux]
$su -
Password:

#cd /usr/src
#tar -jxvf /pawan/sources/linux-2.6.28.tar.bz2 -C kernels/

#ln -s /usr/src/kernels/linux-2.6.28 linux

#cd linux
#vim Makefile
(set the EXTRAVERSION to any meaningful value. I have used -xAUFS-SQFS-EXT4)

Please change the path of root d
irectory as per your settings. It is better to use UUID instead of partition identifier such as /dev/sda1. You can get the UUID value for all partitions using "blkid" command.

There are many file systems which does compression but squash file system (SQFS) seems to be the most promising one. So, I have chosen SQFS. Its tarball can be downloaded from squashfs.sourceforge.net website. SQUASHFS comes with a well written guide to add its patch inside kernel.


#patch -p1 < /pawan/sources/squashfs3.4/kernel-patches/linux-2.6.27-rc4-next/squashfs3.4-patch


I had to use patch for 2.6.27-rc4 and its upcoming versions since there was no patch specifically created for 2.6.28. But this worked for me and hopefully it will for you as well.

AUFS or Another Union File System is file system which will give user consolidated view of both read-only and read-write directories/partitions so that one can read/write to a directory without worrying about the internal details. What was the intension behind using this? I have made a compressed SQUASHFS file out of /usr/src directory to save space. It get automatically mounted using "/etc/rc.local" script but in read-only mode. After couple of days when I started installing Cisco VPN client to access our partner servers, I have started getting error while copying files to /usr/src. Then I came across AUFS after gooling a way to resolve this. It is again needs a patch to work with kernel 2.6.28 and many previous versions.


Below is how to download its source code and apply a patch to the kernel to be build.


# mkdir /pawan/sources/aufs.wcvs

# cd /pawan/sources/aufs.wcvs
# cvs -d:pserver:anonymous@aufs.cvs.sourceforge.net:/cvsroot/aufs login (Use EMPTY password)
# cvs -z3 -d:pserver:anonymous@aufs.cvs.sourceforge.net:/cvsroot/aufs co aufs
# make include/linux/version.h include/linux/utsrelease.h
# cd /pawan/sources/aufs.wcvs/aufs
# rm fs/aufs/Kconfig
# make -f local.mk kconfig
# patch -p1 < /pawan/sources/aufs.wcvs/aufs/patch/fsync_super-2.6.19.patch

# patch -p1 < /pawan/sources/aufs.wcvs/aufs/patch/sec_perm-2.6.24.patch
# patch -p0 < /pawan/sources/aufs.wcvs/aufs/patch/splice-2.6.23.patch

# patch -p0 < /pawan/sources/aufs.wcvs/aufs/patch/sysfs_get_dentry.patch

# patch -p0 < /pawan/sources/aufs.wcvs/aufs/patch/put_filp.patch
# patch -p0 < /pawan/sources/aufs.wcvs/aufs/patch/ksize.patch


#make xconfig

This command will open a Qt-GUI so that we can easily see all the functionality provided by our dear kernel in an easy way.
Go to File Systems panel to view all the supported file systems.
Choose compile within the kernel or as a module option for ext4, Another unionfs and FUSE from the right side of the File Systems link.

Click on the sub-menu called Miscellaneous filesystems to enable Squash FS 3.4 file system.


Go to Multimedia Devices to add support for webcam. Enable "Video For Linux" Also, choose V4L USB Devices and enable GSPCA for webcams. Choose ALi USB m5602 Camera Driver as a module.
If you have Sony Digital camera then also choose Sony MemoryStick Card support to access memory stick directly from the slot provided within the laptop for memory chips. Choose "MMC/SD/SDIO Card Supprt".

Save the settings to update ".config" file withing the source code folder.

Run below command to start compiling linux for all the desired features.


#make

Run modules_install to install modules and other kernel files inside /lib/modules/2.6.28-xAUFS-SQFS-EXT4/ directory.


#make modules_install


Now perform these step to load the compiled kernel from GRUB/LILO.

#cp arch/i383/boot/bzImage /boot/bzImage-2.6.28-xAUFS-SQFS-EXT4

#cp System.map /boot/System.map-2.6.28-xAUFS-SQFS-EXT4

#mkinitrd /boot/initrd-2.6.28-xAUFS-SQFS-EXT4.img 2.6.28-xAUFS-SQFS-EXT4


Add a new entry for the newly built kernel as shown below.


#vim /etc/grub.conf

default=1
timeout=5
splashimage=(hd0,7)/grub/splash.xpm.gz
#hiddenmenu
password --md5 $1$Oh/nmqE5$q5V.MJW4f0afWpljI30yI.
title Fedora (2.6.28)
root (hd0,7)
kernel /bzImage-2.6.28 ro root=UUID=ad3afe2e-46bf-4071-ab97-47ee050142be quiet vga=0x318
initrd /initrd-2.6.28.img
title Fedora (2.6.28-xAUFS-SQFS-EXT4)
root (hd0,7)
kernel /bzImage-2.6.28-xAUFS-SQFS-EXT4 ro root=UUID=ad3afe2e-46bf-4071-ab97-47ee050142be quiet vga=0x318
initrd /initrd-2.6.28-xAUFS-SQFS-EXT4.img
title Fedora (2.6.27.9-159.fc10.i686)
root (hd0,7)
kernel /vmlinuz-2.6.27.9-159.fc10.i686 ro root=UUID=ad3afe2e-46bf-4071-ab97-47ee050142be rhgb quiet vga=0x318
initrd /initrd-2.6.27.9-159.fc10.i686.img
title Fedora (2.6.27.5-117.fc10.i686)
root (hd0,7)
kernel /vmlinuz-2.6.27.5-117.fc10.i686 ro root=UUID=ad3afe2e-46bf-4071-ab97-47ee050142be rhgb quiet
initrd /initrd-2.6.27.5-117.fc10.i686.img

#exit

Restart the OS to boot the new kernel and have your fingure crossed. You will see a nice penguin welcoming you inside the new kernel. If everything goes well you will be shown GDM manager or console as per your settings.

We will see creating and mounting various file systems which were added the
above kernel in next article.

Enjoy!!