installing_from_source_on_debian
Differences
This shows you the differences between two versions of the page.
| Next revision | Previous revision | ||
| installing_from_source_on_debian [2007/09/18 08:38] – created morten | installing_from_source_on_debian [2011/06/24 08:05] (current) – [Installing dependencies] vegardv | ||
|---|---|---|---|
| Line 1: | Line 1: | ||
| ====== Installing NAV from source on Debian GNU/Linux ====== | ====== Installing NAV from source on Debian GNU/Linux ====== | ||
| - | This is an attempt at a guide and a few helpful pointers for those who don't care to use the prepackaged NAV for Debian. | + | This is an attempt at a guide and a few helpful pointers for those who don't care to use the prepackaged NAV for Debian. |
| + | |||
| + | Versions | ||
| + | ^ Debian | 5.0 (//Lenny//) | | ||
| + | ^ NAV | 3.7 | | ||
| + | |||
| + | |||
| + | ===== Installing dependencies ===== | ||
| + | |||
| + | Make sure you have the // | ||
| + | '' | ||
| + | |||
| + | < | ||
| + | deb http:// | ||
| + | deb-src http:// | ||
| + | |||
| + | deb http:// | ||
| + | deb-src http:// | ||
| + | </ | ||
| + | |||
| + | Install NAV's runtime dependencies: | ||
| + | |||
| + | < | ||
| + | sudo aptitude install perl python sun-java6-jdk apache2-mpm-prefork \ | ||
| + | cricket postgresql-8.3 libapache2-mod-python \ | ||
| + | libpg-java libsnmp1.4-java python-pysnmp2 logrotate \ | ||
| + | python-cheetah python-xmpp python-django \ | ||
| + | python-egenix-mxdatetime python-gammu python-ipy \ | ||
| + | python-ldap python-psycopg2 python-pyrad \ | ||
| + | python-pysnmp-se python-twisted python-twisted-snmp \ | ||
| + | python-rrd rrdtool samba-common | ||
| + | </ | ||
| + | |||
| + | Be aware that NAV doesn' | ||
| + | |||
| + | < | ||
| + | sudo update-alternatives --config java | ||
| + | sudo update-alternatives --config javac | ||
| + | </code> | ||
| + | |||
| + | Next, NAV's build time dependencies: | ||
| + | |||
| + | < | ||
| + | sudo aptitude install ant autoconf automake libsnmp1.4-java python python-cheetah sun-java5-jdk make | ||
| + | </code> | ||
| + | |||
| + | ===== Unpacking and building | ||
| + | < | ||
| + | tar xvzf nav-3.7.0.tar.gz | ||
| + | cd nav-3.7.0 | ||
| + | ./configure CRICKETDIR=/ | ||
| + | export CLASSPATH=/ | ||
| + | make | ||
| + | sudo make install | ||
| + | </code> | ||
| + | Note: avoid using -j when calling make. It will break the build, since make tries to run many ant processes with interdependencies at the same time. | ||
| + | |||
| + | |||
| + | ===== Installing and initializing the database schema ===== | ||
| + | Edit '' | ||
| + | < | ||
| + | local | ||
| + | local | ||
| + | |||
| + | host all | ||
| + | host all | ||
| + | </ | ||
| + | |||
| + | Then reload PostgreSQL to make the changes effective: | ||
| + | < | ||
| + | sudo invoke-rc.d postgresql-8.3 reload | ||
| + | </ | ||
| + | |||
| + | While still in the NAV source code directory, '' | ||
| + | |||
| + | To create the PostgreSQL user and database: | ||
| + | < | ||
| + | # The following command will prompt for a password for the new database user. | ||
| + | # Pick one of your own choosing. | ||
| + | sudo -u postgres ./ | ||
| + | </ | ||
| + | |||
| + | :!: Then, take the password you chose for the database user and put this as the value to the '' | ||
| + | |||
| + | ===== Fixing Python library path ===== | ||
| + | We do this because we don't install the libraries to the systemwide Python library directories by default. | ||
| + | < | ||
| + | sudo bash -c 'cat << EOF >> / | ||
| + | |||
| + | import sys | ||
| + | __navpath = "/ | ||
| + | if __navpath not in sys.path: | ||
| + | sys.path.append(__navpath) | ||
| + | EOF | ||
| + | ' | ||
| + | </ | ||
| + | |||
| + | |||
| + | |||
| + | ===== Fixing Java libraries ===== | ||
| + | < | ||
| + | cd / | ||
| + | sudo ln -s / | ||
| + | sudo ln -s / | ||
| + | </ | ||
| + | |||
| + | ===== Configuring Apache ===== | ||
| + | Put this in ''/ | ||
| + | < | ||
| + | ServerName nav.example.com | ||
| + | ServerAdmin webmaster@example.com | ||
| + | |||
| + | DirectoryIndex index.html index.html index.php index.cgi index.py | ||
| + | AccessFileName .htaccess | ||
| + | AddDefaultCharset UTF-8 | ||
| + | AddHandler cgi-script .cgi | ||
| + | |||
| + | DocumentRoot / | ||
| + | < | ||
| + | Options FollowSymLinks | ||
| + | AllowOverride None | ||
| + | </ | ||
| + | |||
| + | < | ||
| + | Options Indexes FollowSymLinks ExecCGI | ||
| + | AllowOverride All | ||
| + | Order allow, | ||
| + | Allow from all | ||
| + | </ | ||
| + | |||
| + | LogLevel warn | ||
| + | |||
| + | < | ||
| + | # Enable debugging on errors, if you like | ||
| + | PythonDebug on | ||
| + | </ | ||
| + | </ | ||
| + | |||
| + | Then run the following commands: | ||
| + | < | ||
| + | sudo a2dissite default | ||
| + | sudo a2ensite default-nav | ||
| + | sudo a2enmod mod_python | ||
| + | sudo invoke-rc.d apache2 force-reload | ||
| + | </ | ||
| + | |||
| + | ===== Cleaning up and configuring ===== | ||
| + | Create groups and users, and set proper permissions: | ||
| + | < | ||
| + | sudo addgroup --system nav | ||
| + | sudo adduser --system --no-create-home --home / | ||
| + | | ||
| + | sudo addgroup navcron dialout | ||
| + | |||
| + | cd / | ||
| + | sudo chown -R navcron:nav . | ||
| + | </ | ||
| + | |||
| + | Edit ''/ | ||
| + | Also set '' | ||
| + | |||
| + | Optionally make the nav process control command more available: '' | ||
| + | |||
| + | |||
| + | ===== Initialize Cricket configuration ===== | ||
| + | |||
| + | Cricket should already be installed as it is a part of the runtime dependencies. | ||
| + | |||
| + | Remove ''/ | ||
| + | |||
| + | Create a directory to place the nav cricket-config: | ||
| + | < | ||
| + | |||
| + | Change owner to navcron: | ||
| + | < | ||
| + | sudo chown navcron:nav / | ||
| + | </ | ||
| + | |||
| + | Edit the / | ||
| + | < | ||
| + | $gConfigRoot = "/ | ||
| + | $gLogDir = your/ | ||
| + | </ | ||
| + | |||
| + | Copy / | ||
| + | < | ||
| + | cd / | ||
| + | sudo cp / | ||
| + | </ | ||
| + | |||
| + | As navcron, copy recursively / | ||
| + | < | ||
| + | sudo -u navcron cp -r / | ||
| + | </ | ||
| + | |||
| + | Create a directory to store Cricket' | ||
| + | < | ||
| + | sudo mkdir / | ||
| + | sudo chown navcron / | ||
| + | </ | ||
| + | |||
| + | Go to the cricket-config directory and edit the " | ||
| + | < | ||
| + | Target | ||
| + | dataDir | ||
| + | </ | ||
| + | |||
| + | Compile the cricket-config as navcron to create the cricket-database. | ||
| + | < | ||
| + | |||
| + | Run '' | ||
| + | < | ||
| + | cd / | ||
| + | sudo -u navcron ./mcc.py | ||
| + | </ | ||
| + | |||
| + | Now, start Cricket: | ||
| + | < | ||
| + | cd / | ||
| + | sudo ./nav start cricket | ||
| + | </ | ||
| + | |||
| + | ==== Cricket Web ==== | ||
| + | |||
| + | Create the cricket directory in apache/ | ||
| + | < | ||
| + | cd / | ||
| + | sudo mkdir cricket | ||
| + | </ | ||
| + | |||
| + | Make a symlink to the cricket cgi-scripts and copy cricket.css from source. | ||
| + | < | ||
| + | cd / | ||
| + | sudo ln -s / | ||
| + | sudo ln -s / | ||
| + | sudo ln -s grapher.cgi index.cgi | ||
| + | sudo ln -s / | ||
| + | sudo cp / | ||
| + | </ | ||
| + | |||
| + | Create .htaccess-file to make sure mod_python doesn' | ||
| + | < | ||
| + | sudo bash -c 'echo " | ||
| + | </ | ||
installing_from_source_on_debian.1190104733.txt.gz · Last modified: by morten
