15
10

ubuntu22.04にZabbix server6.4を構築する

Posted at

こんにちは。
株式会社クラスアクト インフラストラクチャ事業部の大塚です。

仕事関連でZabbixを触る機会が増え、適当にいじり倒せる環境が欲しいなと思う今日この頃。
なので作ってみることにしました。
まずはZabbix serverを構築し、次にAgentを導入したサーバを用意して監視環境を作っていきます。

用語

Zabbix

公式サイトからの引用です。

Zabbixはネットワークの多くのパラメータ、サーバ、仮想マシン、アプリケーション、サービス、データベース、Webサイト、クラウドなどの健全性と完全性を監視するソフトウェアです。Zabbixは柔軟な通知メカニズムを使用しており、ユーザは事実上あらゆるイベントに対してメールベースのアラートを設定することができます。これにより、サーバトラブルへの迅速な対応が可能です。Zabbixは保存されたデータに基づいた優れたレポート機能とデータ可視化機能を提供します。そのため、Zabbixはキャパシティプランニングに最適です。
Zabbixはポーリングとトラッピングの両方をサポートしています。全てのZabbixレポートと統計情報、設定パラメータはWebベースのフロントエンドからアクセスすることができます。Webベースのフロントエンドはネットワークの状態とサーバの健全性をどこからでも確実に評価することができます。適切に設定することで、ZabbixはITインフラの監視において重要な役割を果たすことができます。これは数台のサーバを持つ小規模な組織でも、多数のサーバを持つ大企業でも同様です。

HW構成

ubuntu22.04のHW構成を以下に示します。
こんなにスペック高くなくて良いと思いますが、後から足りなくなると面倒なので。

HW Spec
CPU 2sockets 4cores
Memory 20GiB
Disk 50GB

参考サイト

以下の公式サイトに各々の環境に合わせた環境構築の手順が記載されております。

ちなみに今回の環境構築にあたり、以下の様に設定を入れております。
image.png

構築

手順に記載の通り、Zabbixのリポジトリを追加します。

root@zabbix:~# wget https://repo.zabbix.com/zabbix/6.4/ubuntu/pool/main/z/zabbix-release/zabbix-release_6.4-1+ubuntu22.04_all.deb
root@zabbix:~# dpkg -i zabbix-release_6.4-1+ubuntu22.04_all.deb
root@zabbix:~# apt update

次にZabbix serverをインストールしていきます。
※あとでこの記事には記載しますが、MySQLやApacheは別途インストールする必要があります。公式手順には記載がありません。

root@zabbix:~# apt install zabbix-server-mysql zabbix-frontend-php zabbix-apache-conf zabbix-sql-scripts zabbix-agent -y

MySQLやApacheをインストールし、MySQLのrootユーザのパスワードを設定します。
このパスワードは任意のもので問題ありません。

root@zabbix:~# apt install mysql-server mysql-client apache2 -y
root@zabbix:~# systemctl start mysql apache2
root@zabbix:~# systemctl enable mysql apache2
root@zabbix:~# mysqladmin -u root password
New password:
Confirm new password:
Warning: Since password will be sent to server in plain text, use ssl connection to ensure password safety.

MySQLにログインして公式サイトの通り、設定を入れていきます。

root@zabbix:~# mysql -u root -p
Enter password:
mysql> create database zabbix character set utf8mb4 collate utf8mb4_bin;
Query OK, 1 row affected (0.03 sec)
mysql> create user zabbix@localhost identified by 'password';
Query OK, 0 rows affected (0.05 sec)
mysql> grant all privileges on zabbix.* to zabbix@localhost;
Query OK, 0 rows affected (0.03 sec)
mysql> set global log_bin_trust_function_creators = 1;
Query OK, 0 rows affected, 1 warning (0.00 sec)
mysql> quit;
Bye

Zabbix Serverに必要なスキーマやデータを準備します。
このコマンド実行後、2,3分ほど処理に時間がかかるため待機します。

root@zabbix:~# zcat /usr/share/zabbix-sql-scripts/mysql/server.sql.gz | mysql --default-character-set=utf8mb4 -u zabbix -p zabbix

以下のコマンドを実行し、MySQLとZabbixのconfigの設定を変更していきます。

root@zabbix:~# mysql -uroot -p
Enter password:
mysql> set global log_bin_trust_function_creators = 0;
Query OK, 0 rows affected, 1 warning (0.01 sec)
mysql> quit;
Bye

root@zabbix:~# cp -p /etc/zabbix/zabbix_server.conf /etc/zabbix/zabbix_server.conf.org
root@zabbix:~# vi /etc/zabbix/zabbix_server.conf
root@zabbix:~# diff /etc/zabbix/zabbix_server.conf /etc/zabbix/zabbix_server.con
f.org
129c129
< DBPassword=password
---
> # DBPassword=

root@zabbix:~# systemctl restart zabbix-server zabbix-agent apache2 
root@zabbix:~# systemctl enable zabbix-server zabbix-agent

ここまで完了しましたら、Webブラウザでアクセスが出来るようになっていると思います。
http://"Zabbix serverのIPアドレス"/zabbixでいけます。
アクセス後、以下の様な画面が表示されます。Next stepを押下します。
image (56).png
全てOKとなっていることを確認してください。(OKになっていないものがあると次に進めないはずです。)
image (57).png
DBにZabbixが接続する為の情報を記載します。
以下の様に入力すればOKです。Passwordの部分はpasswordです。Zabbix公式サイトに準拠していれば。
image (58).png
Time zoneをAsia/Tokyoに変更し後はデフォルトのままで先に進めました。
image (59).png
以下の様な画面が表示されれば成功です。Finishを押下します。
image (60).png
ユーザ:Admin
パスワード:zabbix
でログインができます。
image (61).png
image (62).png

15
10
2

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
15
10