installing_from_source_on_debian
Differences
This shows you the differences between two versions of the page.
| Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
| installing_from_source_on_debian [2007/09/18 08:46] – 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 | ||
| + | ^ NAV | ||
| ===== Installing dependencies ===== | ===== Installing dependencies ===== | ||
| + | |||
| + | Make sure you have the // | ||
| + | '' | ||
| + | |||
| + | < | ||
| + | deb http:// | ||
| + | deb-src http:// | ||
| + | |||
| + | deb http:// | ||
| + | deb-src http:// | ||
| + | </ | ||
| + | |||
| Install NAV's runtime dependencies: | Install NAV's runtime dependencies: | ||
| + | |||
| < | < | ||
| - | sudo aptitude install perl python | + | sudo aptitude install perl python |
| - | cricket | + | cricket postgresql-8.3 libapache2-mod-python \ |
| - | libapache2-mod-php4 | + | libpg-java libsnmp1.4-java python-pysnmp2 |
| - | libpg-perl libnetaddr-ip-perl libdbd-pg-perl \ | + | |
| - | | + | |
| - | | + | python-ldap python-psycopg2 |
| - | python-forgethtml | + | |
| - | python-ipy python-ldap python-psycopg | + | python-rrd rrdtool |
| - | | + | |
| </ | </ | ||
| - | And, of course, | + | Be aware that NAV doesn' |
| < | < | ||
| - | sudo aptitude install | + | sudo update-alternatives --config java |
| + | sudo update-alternatives --config javac | ||
| + | </ | ||
| + | |||
| + | Next, NAV's build time dependencies: | ||
| + | |||
| + | < | ||
| + | sudo aptitude install | ||
| </ | </ | ||
| ===== Unpacking and building NAV ===== | ===== Unpacking and building NAV ===== | ||
| < | < | ||
| - | tar xvzf nav-3.3.0_rc1.tar.gz | + | tar xvzf nav-3.7.0.tar.gz |
| - | cd nav-3.3.0_rc1 | + | cd nav-3.7.0 |
| - | autoconf | + | ./ |
| - | ./ | + | export CLASSPATH=/ |
| - | export CLASSPATH=/ | + | |
| make | make | ||
| sudo make install | sudo make install | ||
| + | </ | ||
| + | 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,deny | ||
| + | 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:nav | ||
| + | < | ||
| + | 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.1190105209.txt.gz · Last modified: by morten
