2009-10-02 10:09:10 -04:00
|
|
|
$OpenBSD: README.OpenBSD,v 1.4 2009/10/02 14:09:10 ajacoutot Exp $
|
2009-06-03 13:54:12 -04:00
|
|
|
|
|
|
|
This document gives information relevant to using ZABBIX on OpenBSD.
|
2009-07-12 15:51:51 -04:00
|
|
|
The original documentation is available as a PDF file at
|
|
|
|
${HOMEPAGE}
|
2009-06-03 13:54:12 -04:00
|
|
|
(or via the -doc subpackage of the zabbix port) but may not be
|
|
|
|
redistributed.
|
|
|
|
|
|
|
|
On OpenBSD, ZABBIX is packaged in four parts:
|
|
|
|
|
|
|
|
- the agent (in the zabbix-agent package) for installing onto a
|
|
|
|
monitored machine. To simplify installation from ports on client
|
|
|
|
machines, only this part is built by default.
|
|
|
|
|
|
|
|
- the server and proxy (in the database-dependent zabbix-server
|
|
|
|
package); this has heavier dependencies and is built by selecting
|
|
|
|
the FLAVOR for the database you use (currently mysql or pgsql).
|
|
|
|
|
|
|
|
- the web interface to run with the server (in the zabbix-web package).
|
|
|
|
This is also in a database-dependent package to ensure the correct
|
|
|
|
PHP modules are installed.
|
|
|
|
|
|
|
|
- the PDF document, a package which must be 'built' locally because it
|
|
|
|
can not be redistributed.
|
|
|
|
|
2009-07-13 13:13:01 -04:00
|
|
|
Next, you have to adapt the configuration files under
|
2009-07-12 15:51:51 -04:00
|
|
|
${SYSCONFDIR}/zabbix/
|
2009-10-02 10:09:10 -04:00
|
|
|
(make sure your webserver can resolve hostnames; otherwise use IP
|
|
|
|
addresses in the configuration files).
|
2009-06-03 13:54:12 -04:00
|
|
|
|
2009-07-12 15:51:51 -04:00
|
|
|
To have the ZABBIX server start at boot time, insert the following into
|
|
|
|
/etc/rc.local:
|
|
|
|
|
|
|
|
if [ -x ${TRUEPREFIX}/sbin/zabbix_server ]; then
|
|
|
|
install -d -o _zabbix /var/run/zabbix
|
|
|
|
echo -n ' zabbix_server'; ${TRUEPREFIX}/sbin/zabbix_server
|
2009-06-03 13:54:12 -04:00
|
|
|
fi
|
|
|
|
|
2009-07-12 15:51:51 -04:00
|
|
|
For the proxy and the client, follow the same procedure, replacing
|
|
|
|
zabbix_server with zabbix_proxy or zabbix_clientd.
|
2009-06-03 13:54:12 -04:00
|
|
|
|
|
|
|
The web frontend works reasonably well with OpenBSD's chroot'ed
|
|
|
|
httpd (the "Status of ZABBIX" page uses /bin/ps and /dev/kmem to
|
|
|
|
check the process, so it erroneously reports it as not running).
|
|
|
|
Some changes from the default configuration are required -
|
|
|
|
you can do this by creating symbolic links as follows:
|
|
|
|
|
|
|
|
# ln -s ${PREFIX-web}/conf/modules.sample/zabbix.conf \
|
|
|
|
${PREFIX-web}/conf/modules
|
|
|
|
|
|
|
|
# ln -fs ${PREFIX-web}/conf/php5.sample/zabbix.ini \
|
|
|
|
${PREFIX-web}/conf/php5/zabbix.ini
|
|
|
|
|
|
|
|
ZABBIX requires a timezone to be configured in PHP; zabbix.ini
|
|
|
|
sets this to UTC, you may like to adjust this. After making these
|
|
|
|
changes, stop and start httpd.
|
|
|
|
|
|
|
|
Next you must create the database following the relevant set of
|
|
|
|
instructions below. When this is done you can proceed to configure
|
2009-07-12 15:51:51 -04:00
|
|
|
through the web interface at http://<hostname>/zabbix/setup.php.
|
|
|
|
(default user is 'admin' with password 'zabbix')
|
2009-06-03 13:54:12 -04:00
|
|
|
|
|
|
|
== MySQL ==
|
|
|
|
|
|
|
|
MySQL users running with chroot'ed httpd might like to take the
|
|
|
|
following steps to place the mysql socket inside the chroot:
|
|
|
|
|
|
|
|
Create a directory for the mysql socket.
|
|
|
|
|
|
|
|
mkdir -p /var/www/var/run/mysql
|
|
|
|
|
|
|
|
Adjust ${SYSCONFDIR}/my.cnf to put the mysql socket into the chroot,
|
|
|
|
|
|
|
|
[client]
|
|
|
|
socket = /var/www/var/run/mysql/mysql.sock
|
|
|
|
|
|
|
|
[mysqld]
|
|
|
|
socket = /var/www/var/run/mysql/mysql.sock
|
|
|
|
|
|
|
|
and set DBSocket in the ZABBIX configuration appropriately.
|
|
|
|
|
|
|
|
Connect to MySQL, and create a user and database for ZABBIX;
|
|
|
|
|
|
|
|
$ mysql -u root -p
|
2009-07-12 15:51:51 -04:00
|
|
|
mysql> create user zabbix@localhost identified by 'password';
|
|
|
|
mysql> create database zabbix;
|
|
|
|
mysql> grant all on zabbix.* to zabbix@localhost;
|
|
|
|
mysql> quit
|
2009-06-03 13:54:12 -04:00
|
|
|
|
|
|
|
Then initialize the database from the files installed in
|
2009-07-13 13:13:01 -04:00
|
|
|
${TRUEPREFIX}/share/examples/zabbix:
|
2009-06-03 13:54:12 -04:00
|
|
|
|
2009-07-12 15:51:51 -04:00
|
|
|
$ cd ${TRUEPREFIX}/share/zabbix/schema
|
2009-06-03 13:54:12 -04:00
|
|
|
$ mysql -uzabbix -p[password] zabbix < mysql.sql
|
|
|
|
$ cd ../data
|
|
|
|
$ mysql -uzabbix -p[password] zabbix < data.sql ## N.B. slow!!
|
|
|
|
$ mysql -uzabbix -p[password] zabbix < images_mysql.sql
|
|
|
|
|
|
|
|
== PostgreSQL ==
|
|
|
|
|
|
|
|
Assuming you have an administrative account named `postgres',
|
|
|
|
you can create the 'zabbix' user and database like this:
|
|
|
|
|
|
|
|
createuser -U postgres --pwprompt --no-superuser \
|
|
|
|
--createdb --no-createrole zabbix
|
|
|
|
createdb -U zabbix zabbix
|
|
|
|
|
|
|
|
And initialize the database:
|
|
|
|
|
|
|
|
$ psql -U zabbix
|
|
|
|
psql> create database zabbix;
|
|
|
|
psql> \q
|
2009-07-12 15:51:51 -04:00
|
|
|
$ cd ${TRUEPREFIX}/share/zabbix/schema
|
2009-06-03 13:54:12 -04:00
|
|
|
$ cat postgresql.sql | psql -U zabbix zabbix
|
|
|
|
$ cd ../data
|
|
|
|
$ cat data.sql | psql -U zabbix zabbix
|
|
|
|
$ cat images_pgsql.sql | psql -U zabbix zabbix
|