Élenchos: Check MySQL and MariaDB Replication
Project description
Élenchos: Check MySQL and MariaDB Replication
A Élenchos command for checking the replication of a MySQL or MariaDB instance.
Installation and Configuration
Primary Instance
On the primary instance create a heartbeat by executing the following SQL commands.
create schema heartbeat;
use heartbeat;
create table heartbeat
(
heartbeat datetime not null
) engine = InnoDB;
insert into heartbeat(heartbeat)
values (now());
create definer=root@localhost event heartbeat
on schedule every 1 minute starts '2016-02-07 09:22:34'
on completion preserve enable
comment 'Heartbeat for replication monitoring.'
do
update heartbeat
set heartbeat = now();
Using this heartbeat is more reliable than Seconds_Behind_Master as provided by the show replica status SQL command
which is NULL when the SQL thread is not running.
Replica Host
On the host where the replication instance is running, install Élenchos by executing the following commands.
cd /opt
mkdir elenchos
cd elenchos
python -m venv .venv
mkdir bin
ln -s ../.venv/bin/elenchos bin/elenchos
. .venv/bin/activate
pip install elenchos-check-mymaria-replication
/opt/elenchos/bin/elenchos gather-commands
Create the configuration file /etc/nagios/replication.cfg:
[nagios]
name = MariaDB Replication <hostname>
max_lag = 60
warning = 15000
critical = 20000
timestamp_path = timestamp.txt
[database]
host = localhost
database = heartbeat
port = 3306
charset = utf8mb4
collation = utf8mb4_general_ci
supplement = credentials.cfg
The values of host, port, charset, and collation in the database section are the defaults and can be omitted.
Create the file /etc/nagios/credentials.cfg for storing the credentials of the replication monitoring user:
[database]
user = rep_monitor
password = secret
Set the proper mode and ownership of /etc/nagios/credentials.cfg by executing the following commands.
chmod 400 /etc/nagios/credentials.cfg
chown nrpe.nrpe /etc/nagios/credentials.cfg
Create the configuration file /etc/nrpe.d/check_mysql_replication.cfg for nrpe:
command[check_mysql_replication]=/opt/elenchos/bin/elenchos check:mariadb-replication /etc/nagios/replication.cfg
Create the user for monitoring the replication by executing the following SQL statements.
create user `rep_monitor`@`localhost` identified by password('secret') with max_user_connections 1;
grant binlog monitor, slave monitor on *.* to `rep_monitor`@`localhost`;
grant select on heartbeat.heartbeat to rep_monitor@localhost;
Finally, restart the nrpe daemon.
systemctl reload nrpe
License
This project is licensed under the terms of the MIT license.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file elenchos_check_mymaria_replication-1.2.0.tar.gz.
File metadata
- Download URL: elenchos_check_mymaria_replication-1.2.0.tar.gz
- Upload date:
- Size: 5.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.12.6 Linux/6.10.9-200.fc40.x86_64
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bc3e379e638a054a32fa3b795d1a3f27b377edfe27662c1d16dbc63ba2702408
|
|
| MD5 |
09097b031393c4af67dcf3de34dd091d
|
|
| BLAKE2b-256 |
15c95e820976e385f3f22ff486bc8c431f7f4ca5ba43f8305feecffadc93a9cc
|
File details
Details for the file elenchos_check_mymaria_replication-1.2.0-py3-none-any.whl.
File metadata
- Download URL: elenchos_check_mymaria_replication-1.2.0-py3-none-any.whl
- Upload date:
- Size: 7.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.12.6 Linux/6.10.9-200.fc40.x86_64
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a44fb2e8a6a5ee3a5c67969a73b15e49dd38b3aa936d23a4b9bffc97a58fb487
|
|
| MD5 |
4ed50eab1c2e279afc83c73c003f86aa
|
|
| BLAKE2b-256 |
df79a9648be2b57e6cc00da4be1b4451f5951fd68c396bd84fe1e2cc8fa66512
|