Sunday, December 15, 2013

Setting up OpenGrok Source Browser in Ubuntu


OpenGrok is a JSP Servlet for Source Browsing similar to LXR (linux cross reference) but having more features and simpler to setup. Checkout http://opengrok.github.io/OpenGrok/  for more details.

Requirements:
    * Latest Java (At least 1.7)
      http://www.oracle.com/technetwork/java/
    * A servlet container like Tomcat (7.x or later)
      supporting Servlet 2.4 and JSP 2.0
      http://tomcat.apache.org/
    * Exuberant Ctags
      http://ctags.sourceforge.net/
    * Source Code Management (SCM) installation
      depending on type of repositories indexed (ex. git)

Installation of Requirements:
1. JDK will be available by default with the installation of Ubuntu 12.04 LTS. If not available, you can install using below command.
$ sudo apt-get install openjdk-6-jdk openjdk-6-jre
2. Install JSP Server Container - Tomcat.
$ sudo apt-get install tomcat6 tomcat6-common tomcat-examples tomcat6-admin tomcat6-docs tomcat6-extras
Note: packages tomcat6 and tomcat6-common are  sufficient and other packages are optional.

3. Install Exuberant Ctags
$ sudo apt-get install exuberant-ctags
4. Install SCM Tool - GIT
$ sudo apt-get install git git-core gitk 

Setting up OpenGrok
1. Download OpenGrok from the below link:
http://java.net/projects/opengrok/downloads/download/opengrok-0.11.1.tar.gz

Note: Below Steps require sudo/root permission.
2. Extract the contents of opengrok to /var 


$ sudo tar xvzf opengrok-0.11.1.tar.gz -C /var
3. Rename /var/opengrok-0.11.1 to /var/opengrok 
$ sudo mv /var/opengrok-0.11.1 /var/opengrok
4. Create additional directories under /var/opengrok
cd /var/opengrok
$ sudo mkdir etc src data web web/source
5. Copy opengrok JSP Server source.war to web direcory.
$ sudo cp lib/source.war web/
6. Extract opengrok JSP Server source.war to web/source direcory.
$ cd web/source
$ unzip ../source.war
7. Update opengrok src and data directories config in WEB-INF/web.xml as shown below (bold-italic) after the second occurrence of </context-param>  
 <context-param>
    <param-name>ConfigAddress</param-name>
    <param-value>localhost:2424</param-value>
    <description>An address where OpenGrok can receive new configuration</description>
  </context-param>

  <context-param>
    <param-name>SRC_ROOT</param-name>
    <param-value>/var/opengrok/src</param-value>
    <description>Source Directory containing all repositories</description>
  </context-param>

  <context-param>
    <param-name>DATA_ROOT</param-name>
    <param-value>/var/opengrok/data</param-value>
    <description>Data Directory for OpenGrok</description>
  </context-param>

  <listener>
   <listener-class>org.opensolaris.opengrok.web.WebappListener</listener-class>
  </listener>

8. Update the modified web.xml in source.war (using below command assuming current directory is /var/opengrok/web/source)
$  sudo zip -r ../source.war *
9. Deploy the modified source.war under tomcat webapps. (usally it will be /var/lib/tomcat6/webapps)
 $  sudo cp ../source.war /var/lib/tomcat6/webapps
10. Clone the required git repositories under opengrok/src
$  cd /var/opengrok/src
$ sudo git clone <git repository path>
Note: Multiple git repositories can be cloned under src directories as a sub-folder.

11. Build the opengrok index.
$  cd /var/opengrok/
$ sudo bin/OpenGrok index
Note: This will take a while depending on the no. of repositories and its size. This operation need to done whenever the src directories are updated (eg. using git pull) and it can also be automated using crontab to do at a specified interval.

12. Checkout the OpenGrok Source Browsing using your favourite Browser with the below URL:
Happy Source Browsing.


1 comment:

  1. This is a good reference for installing. Much better than the docs on the new github Opengrok site.

    ReplyDelete