In this blog post, we’re going to explore How to Setup MariaDB Galera Cluster on Ubuntu 18.04 with HAProxy as Load Balancer. If you have been working with MariaDB – In place replacement of MySQL, you should definitely be aware of MariaDB Galera Cluster. If you are new to these terms, MariaDB Galera Cluster is a synchronous multi-master cluster for MariaDB with support for XtraDB/InnoDB storage engines.
Top features of MariaDB Galera Cluster are:

  • It provides active-active multi-master topology
  • You can read and write to any cluster node
  • It has automatic node joining
  • Automatic membership control, failed nodes drop from the cluster
  • Has true parallel replication, on row level
  • Direct client connections

From these features, you get the benefits like no loss in transactions or weird slave lag normally seen in database replication since all servers have up-to-date data. By using MariaDB Galera Cluster on Ubuntu 18.04 server, you also get scalability for both reads and writes with small latencies from connecting clients.
To get fair load balancing based on Roundrobin or least number of connections on the servers, we will make use of HAProxy which is a production-grade open source Load Balancer.

Setup MariaDB Galera Cluster on Ubuntu 18.04

When setting up MariaDB Galera Cluster, It is advisable to have an odd number of servers. Minimum being three servers. My Lab environment will be based on the diagram below:
Setup MariaDB Galera Cluster on Ubuntu 18.04 with HAProxy - 图1
I prefer using hostnames as opposed to hard-coded IP addresses in all my configurations. In preparation for this, let’s populate /etc/hosts with correct short hostnames and IP addresses for all servers.

  1. $ sudo vim /etc/hosts
  2. 10.131.69.129 galera-haproxy-01
  3. 10.131.74.92 galera-db-01
  4. 10.131.35.167 galera-db-02
  5. 10.131.65.13 galera-db-03

You must have noticed that my servers are not on the same subnet. This is recommended to ensure there is no single point of failure on the networking side. You can test that everything is working using ping.

Step 1: Install MariaDB database server on Galera nodes

We will start by Installing MariaDB on all Galera cluster nodes:

  • galera-db-01
  • galera-db-02
  • galera-db-03

Use our previous guide Install MariaDB 10.x on Ubuntuto install MariaDB on Ubuntu 18.04. Once you are done with the installation of MariaDB database server on all nodes, proceed to next step.

Step 2: Configure First Galera Cluster node

When setting up Galera Cluster, you need to start with one node which will assume the role of master. Edit first node main configuration to configure default character set.

  1. $ sudo vim /etc/mysql/mariadb.cnf

Uncomment these lines:

  1. character-set-server = utf8
  2. character_set_server = utf8

Then add Galera specific configurations:

  1. sudo vim /etc/mysql/mariadb.conf.d/galera.cnf

Add below on galera-db-01 Galera configuration file:

  1. [mysqld]
  2. bind-address=0.0.0.0
  3. default_storage_engine=InnoDB
  4. binlog_format=row
  5. innodb_autoinc_lock_mode=2
  6. # Galera cluster configuration
  7. wsrep_on=ON
  8. wsrep_provider=/usr/lib/galera/libgalera_smm.so
  9. wsrep_cluster_address="gcomm://10.131.74.92,10.131.35.167,10.131.65.13"
  10. wsrep_cluster_name="mariadb-galera-cluster"
  11. wsrep_sst_method=rsync
  12. # Cluster node configuration
  13. wsrep_node_address="10.131.74.92"
  14. wsrep_node_name="galera-db-01"

Rember to replace 10.131.74.92,10.131.35.167,10.131.65.13 with Galera cluster nodes IP Addresses.

Step 3: Configure other Galera Cluster Nodes

We now need to add configurations to Galera cluster node 2 and node 3.
For galera-db-02:

  1. root@galera-db-02:~# vim /etc/mysql/mariadb.conf.d/galera.cnf
  2. [mysqld]
  3. bind-address=0.0.0.0
  4. default_storage_engine=InnoDB
  5. binlog_format=row
  6. innodb_autoinc_lock_mode=2
  7. # Galera cluster configuration
  8. wsrep_on=ON
  9. wsrep_provider=/usr/lib/galera/libgalera_smm.so
  10. wsrep_cluster_address="gcomm://10.131.74.92,10.131.35.167,10.131.65.13"
  11. wsrep_cluster_name="mariadb-galera-cluster"
  12. wsrep_sst_method=rsync
  13. # Cluster node configuration
  14. wsrep_node_address="10.131.35.167"
  15. wsrep_node_name="galera-db-02"

For galera-db-03:

  1. root@galera-db-03:~# vim /etc/mysql/mariadb.conf.d/galera.cnf
  2. [mysqld]
  3. bind-address=0.0.0.0
  4. default_storage_engine=InnoDB
  5. binlog_format=row
  6. innodb_autoinc_lock_mode=2
  7. # Galera cluster configuration
  8. wsrep_on=ON
  9. wsrep_provider=/usr/lib/galera/libgalera_smm.so
  10. wsrep_cluster_address="gcomm://10.131.74.92,10.131.35.167,10.131.65.13"
  11. wsrep_cluster_name="mariadb-galera-cluster"
  12. wsrep_sst_method=rsync
  13. # Cluster node configuration
  14. wsrep_node_address="10.131.65.13"
  15. wsrep_node_name="galera-db-03"

You must have noted that what changes on each node is Cluster node configuration

Step 4: Start Galera Cluster on Ubuntu 18.04

Stop mariadb on all three nodes:

  1. sudo systemctl stop mariadb

Now start new Galera cluster on node 1 – galera-node-01:

  1. sudo galera_new_cluster

Check Galera status if it’s running:

  1. $ mysql -u root -p -e "show status like 'wsrep_%'"
  2. Enter password:
  3. +------------------------------+--------------------------------------+
  4. | Variable_name | Value |
  5. +------------------------------+--------------------------------------+
  6. | wsrep_apply_oooe | 0.000000 |
  7. | wsrep_apply_oool | 0.000000 |
  8. | wsrep_apply_window | 0.000000 |
  9. | wsrep_causal_reads | 0 |
  10. | wsrep_cert_deps_distance | 0.000000 |
  11. | wsrep_cert_index_size | 0 |
  12. | wsrep_cert_interval | 0.000000 |
  13. | wsrep_cluster_conf_id | 1 |
  14. | wsrep_cluster_size | 1 |
  15. | wsrep_cluster_state_uuid | 9f957c6d-76b4-11e8-a71a-17cc0eca13f1 |
  16. | wsrep_cluster_status | Primary |
  17. | wsrep_commit_oooe | 0.000000 |
  18. | wsrep_commit_oool | 0.000000 |
  19. | wsrep_commit_window | 0.000000 |
  20. | wsrep_connected | ON |
  21. | wsrep_desync_count | 0 |
  22. | wsrep_evs_delayed | |
  23. | wsrep_evs_evict_list | |
  24. | wsrep_evs_repl_latency | 0/0/0/0/0 |
  25. | wsrep_evs_state | OPERATIONAL |
  26. | wsrep_flow_control_paused | 0.000000 |
  27. | wsrep_flow_control_paused_ns | 0 |
  28. | wsrep_flow_control_recv | 0 |
  29. | wsrep_flow_control_sent | 0 |
  30. | wsrep_gcomm_uuid | 9f945140-76b4-11e8-84c6-a66f9e2978f6 |
  31. | wsrep_incoming_addresses | 10.131.74.92:3306 |
  32. | wsrep_last_committed | 0 |
  33. | wsrep_local_bf_aborts | 0 |
  34. | wsrep_local_cached_downto | 18446744073709551615 |
  35. | wsrep_local_cert_failures | 0 |
  36. | wsrep_local_commits | 0 |
  37. | wsrep_local_index | 0 |
  38. | wsrep_local_recv_queue | 0 |
  39. | wsrep_local_recv_queue_avg | 0.000000 |
  40. | wsrep_local_recv_queue_max | 1 |
  41. | wsrep_local_recv_queue_min | 0 |
  42. | wsrep_local_replays | 0 |
  43. | wsrep_local_send_queue | 0 |
  44. | wsrep_local_send_queue_avg | 0.000000 |
  45. | wsrep_local_send_queue_max | 1 |
  46. | wsrep_local_send_queue_min | 0 |
  47. | wsrep_local_state | 4 |
  48. | wsrep_local_state_comment | Synced |
  49. | wsrep_local_state_uuid | 9f957c6d-76b4-11e8-a71a-17cc0eca13f1 |
  50. | wsrep_protocol_version | 8 |
  51. | wsrep_provider_name | Galera |
  52. | wsrep_provider_vendor | Codership Oy <info@codership.com> |
  53. | wsrep_provider_version | 25.3.23(r3789) |
  54. | wsrep_ready | ON |
  55. | wsrep_received | 2 |
  56. | wsrep_received_bytes | 148 |
  57. | wsrep_repl_data_bytes | 0 |
  58. | wsrep_repl_keys | 0 |
  59. | wsrep_repl_keys_bytes | 0 |
  60. | wsrep_repl_other_bytes | 0 |
  61. | wsrep_replicated | 0 |
  62. | wsrep_replicated_bytes | 0 |
  63. | wsrep_thread_count | 2 |
  64. +------------------------------+--------------------------------------+

Initial cluster size should be 1

  1. root@galera-db-01:~# mysql -u root -p -e "show status like 'wsrep_cluster_size'"
  2. Enter password:
  3. +--------------------+-------+
  4. | Variable_name | Value |
  5. +--------------------+-------+
  6. | wsrep_cluster_size | 1 |
  7. +--------------------+-------+

On galera-node-02, start mariadb service:

  1. sudo systemctl start mariadb

Check cluster size again, it should have changed to 2

  1. # mysql -u root -p -e "show status like 'wsrep_cluster_size'"
  2. Enter password:
  3. +--------------------+-------+
  4. | Variable_name | Value |
  5. +--------------------+-------+
  6. | wsrep_cluster_size | 2 |
  7. +--------------------+-------+

Start mariadb on galera-db-03:

  1. sudo systemctl start mariadb

Check cluster size again, it should be 3

  1. # mysql -u root -p -e "show status like 'wsrep_cluster_size'"
  2. Enter password:
  3. +--------------------+-------+
  4. | Variable_name | Value |
  5. +--------------------+-------+
  6. | wsrep_cluster_size | 3 |
  7. +--------------------+-------+

If everything was set correctly, you can start testing.

Step 5: Test Galera Cluster Operation

To test our Galera cluster, we’re going to create a test database on one server and confirm that it has been replicated on other nodes. Log in to any member of Galera cluster as root user:

  1. root@galera-node-01:~# mysql -u root -p
  2. Enter password:
  3. Welcome to the MariaDB monitor. Commands end with ; or \g.
  4. Your MariaDB connection id is 50
  5. Server version: 10.3.7-MariaDB-1:10.3.7+maria~bionic-log mariadb.org binary distribution
  6. Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.
  7. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
  8. MariaDB [(none)]> create database galera_test;
  9. Query OK, 1 row affected (0.004 sec)

Log in to the other node and check if the database exists.

  1. MariaDB [(none)]> show databases;
  2. +--------------------+
  3. | Database |
  4. +--------------------+
  5. | galera_test |
  6. | information_schema |
  7. | mysql |
  8. | performance_schema |
  9. +--------------------+
  10. 4 rows in set (0.000 sec)

Step 6: Install and Configure HAProxy

For installation and Configuration of HAProxy as Load Balancer for MariaDB Galera Cluster, refer to our guide: Galera Cluster High Availability With HAProxy on Ubuntu / CentOS 7.

Install Desktop Database Management Tool

If working with MySQL command line is not your thing, then consider installing a Database Tool to help you. Check out our guide below:
Install and Configure DBeaver on Ubuntu / Debian
That’s all for today. Please subscribe to get the latest updates directly on your email.
Learning courses: