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:56] – 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 ===== | ===== Installing and initializing the database schema ===== | ||
| - | While still in the NAV source code directory. | + | Edit ''/ |
| + | < | ||
| + | local | ||
| + | local | ||
| - | * FIXME follow doc/sql/README | + | host all |
| - | * Edit ''/ | + | host all |
| - | | + | </code> |
| + | |||
| + | Then reload PostgreSQL to make the changes effective: | ||
| + | < | ||
| + | sudo invoke-rc.d | ||
| + | </code> | ||
| + | |||
| + | While still in the NAV source code directory, '' | ||
| + | |||
| + | To create the PostgreSQL user and database: | ||
| + | < | ||
| + | # The following command will prompt for a password | ||
| + | # Pick one of your own choosing. | ||
| + | sudo -u postgres | ||
| + | </ | ||
| + | |||
| + | :!: Then, take the password you chose for the database | ||
| + | |||
| + | ===== 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 ===== | ===== Configuring Apache ===== | ||
| Line 67: | Line 133: | ||
| < | < | ||
| - | # Let NAV authorize all access to this location | + | # Enable debugging on errors, if you like |
| - | PythonHeaderParserHandler nav.web | + | |
| PythonDebug on | PythonDebug on | ||
| </ | </ | ||
| Line 77: | Line 142: | ||
| sudo a2dissite default | sudo a2dissite default | ||
| sudo a2ensite default-nav | sudo a2ensite default-nav | ||
| - | sudo a2enmod php4 | ||
| sudo a2enmod mod_python | sudo a2enmod mod_python | ||
| sudo invoke-rc.d apache2 force-reload | 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.1190105789.txt.gz · Last modified: by morten
