Custom haproxy script for monitoring galera

Depends-On: https://review.opendev.org/710217/

Change-Id: I85652f23e487c40192106d23f2cdd45a3077deca
This commit is contained in:
Michal Nasiadka 2020-02-27 11:29:22 +01:00
parent 7f42813159
commit 026f5cc48a
9 changed files with 139 additions and 21 deletions

View File

@ -328,6 +328,7 @@ mariadb_port: "{{ database_port }}"
mariadb_wsrep_port: "4567" mariadb_wsrep_port: "4567"
mariadb_ist_port: "4568" mariadb_ist_port: "4568"
mariadb_sst_port: "4444" mariadb_sst_port: "4444"
mariadb_clustercheck_port: "4569"
masakari_api_port: "15868" masakari_api_port: "15868"

View File

@ -10,3 +10,17 @@
format1 /^(?<Payload>.*)/ format1 /^(?<Payload>.*)/
enable_watch_timer false enable_watch_timer false
</source> </source>
<source>
@type tail
path /var/log/kolla/mariadb/xinetd.log
pos_file /var/run/{{ fluentd_binary }}/mariadb-xinetd.pos
tag infra.mariadb.xinetd
format multiline
format_firstline /^\d{2}/\d{1,2}/\d{1,2}@\d{1,2}:\d{1,2}:\d{1,2}\: (START|EXIT)\: /
format1 /^(?<Timestamp>\S+) (?<Payload>.*)?$/
time_key Timestamp
keep_time_key true
time_format %y/%-m/%-d@%T
ignore_repeated_permission_error true
enable_watch_timer false
</source>

View File

@ -21,7 +21,7 @@ mariadb_services:
backend_tcp_extra: backend_tcp_extra:
- "option srvtcpka" - "option srvtcpka"
- "timeout server 3600s" - "timeout server 3600s"
- "option mysql-check user haproxy post-41" - "option {% if enable_mariadb_clustercheck | bool %}httpchk{% else %}mysql-check user haproxy post-41{% endif %}"
custom_member_list: "{{ internal_haproxy_members.split(';') }}" custom_member_list: "{{ internal_haproxy_members.split(';') }}"
mariadb_external_lb: mariadb_external_lb:
enabled: "{{ enable_external_mariadb_load_balancer|bool }}" enabled: "{{ enable_external_mariadb_load_balancer|bool }}"
@ -35,6 +35,18 @@ mariadb_services:
- "option srvtcpka" - "option srvtcpka"
- "timeout server 3600s" - "timeout server 3600s"
custom_member_list: "{{ external_haproxy_members.split(';') }}" custom_member_list: "{{ external_haproxy_members.split(';') }}"
mariadb-clustercheck:
container_name: mariadb_clustercheck
group: mariadb
enabled: "{{ enable_mariadb_clustercheck | bool }}"
image: "{{ mariadb_clustercheck_image_full }}"
volumes: "{{ mariadb_clustercheck_default_volumes + mariadb_clustercheck_extra_volumes }}"
dimensions: "{{ mariadb_clustercheck_dimensions }}"
environment:
MYSQL_USERNAME: "haproxy"
MYSQL_PASSWORD: ""
MYSQL_HOST: "{{ api_interface_address }}"
AVAILABLE_WHEN_DONOR: "1"
#################### ####################
# Database # Database
@ -45,8 +57,8 @@ database_max_timeout: 120
#################### ####################
# HAProxy # HAProxy
#################### ####################
internal_haproxy_members: "{% for host in groups['mariadb'] %}server {{ hostvars[host]['ansible_hostname'] }} {{ 'api' | kolla_address(host) }}:{{ mariadb_port }} check inter 2000 rise 2 fall 5{% if not loop.first %} backup{% endif %};{% endfor %}" internal_haproxy_members: "{% for host in groups['mariadb'] %}server {{ hostvars[host]['ansible_hostname'] }} {{ 'api' | kolla_address(host) }}:{{ mariadb_port }} check {% if enable_mariadb_clustercheck | bool %}port {{ mariadb_clustercheck_port }} {% endif %} inter 2000 rise 2 fall 5{% if not loop.first %} backup{% endif %};{% endfor %}"
external_haproxy_members: "{% for host in groups['mariadb'] %}server {{ host }} {{ host }}:{{ mariadb_port }} check inter 2000 rise 2 fall 5{% if not loop.first %} backup{% endif %};{% endfor %}" external_haproxy_members: "{% for host in groups['mariadb'] %}server {{ host }} {{ host }}:{{ mariadb_port }} check {% if enable_mariadb_clustercheck | bool %}port {{ mariadb_clustercheck_port}} {% endif %} inter 2000 rise 2 fall 5{% if not loop.first %} backup{% endif %};{% endfor %}"
#################### ####################
# Docker # Docker
@ -55,7 +67,14 @@ mariadb_install_type: "{{ kolla_install_type }}"
mariadb_image: "{{ docker_registry ~ '/' if docker_registry else '' }}{{ docker_namespace }}/{{ kolla_base_distro }}-{{ mariadb_install_type }}-mariadb" mariadb_image: "{{ docker_registry ~ '/' if docker_registry else '' }}{{ docker_namespace }}/{{ kolla_base_distro }}-{{ mariadb_install_type }}-mariadb"
mariadb_tag: "{{ openstack_tag }}" mariadb_tag: "{{ openstack_tag }}"
mariadb_image_full: "{{ mariadb_image }}:{{ mariadb_tag }}" mariadb_image_full: "{{ mariadb_image }}:{{ mariadb_tag }}"
mariadb_clustercheck_install_type: "{{ kolla_install_type }}"
mariadb_clustercheck_image: "{{ docker_registry ~ '/' if docker_registry else '' }}{{ docker_namespace }}/{{ kolla_base_distro }}-{{ mariadb_clustercheck_install_type }}-mariadb-clustercheck"
mariadb_clustercheck_tag: "{{ openstack_tag }}"
mariadb_clustercheck_image_full: "{{ mariadb_clustercheck_image }}:{{ mariadb_clustercheck_tag }}"
mariadb_dimensions: "{{ default_container_dimensions }}" mariadb_dimensions: "{{ default_container_dimensions }}"
mariadb_clustercheck_dimensions: "{{ default_container_dimensions }}"
mariadb_default_volumes: mariadb_default_volumes:
- "{{ node_config_directory }}/mariadb/:{{ container_config_directory }}/:ro" - "{{ node_config_directory }}/mariadb/:{{ container_config_directory }}/:ro"
@ -63,7 +82,14 @@ mariadb_default_volumes:
- "{{ '/etc/timezone:/etc/timezone:ro' if kolla_base_distro in ['debian', 'ubuntu'] else '' }}" - "{{ '/etc/timezone:/etc/timezone:ro' if kolla_base_distro in ['debian', 'ubuntu'] else '' }}"
- "mariadb:/var/lib/mysql" - "mariadb:/var/lib/mysql"
- "kolla_logs:/var/log/kolla/" - "kolla_logs:/var/log/kolla/"
mariadb_clustercheck_default_volumes:
- "{{ node_config_directory }}/mariadb-clustercheck/:{{ container_config_directory }}/:ro"
- "/etc/localtime:/etc/localtime:ro"
- "{{ '/etc/timezone:/etc/timezone:ro' if kolla_base_distro in ['debian', 'ubuntu'] else '' }}"
- "kolla_logs:/var/log/kolla/"
mariadb_extra_volumes: "{{ default_extra_volumes }}" mariadb_extra_volumes: "{{ default_extra_volumes }}"
mariadb_clustercheck_extra_volumes: "{{ default_extra_volumes }}"
######################################## ########################################
# Vars used within recover_cluster.yml # Vars used within recover_cluster.yml
@ -87,3 +113,8 @@ mariadb_backup_database_schema: "PERCONA_SCHEMA"
mariadb_backup_database_user: "backup" mariadb_backup_database_user: "backup"
mariadb_backup_database_address: "{{ database_address }}" mariadb_backup_database_address: "{{ database_address }}"
mariadb_backup_type: "full" mariadb_backup_type: "full"
####################
# Clustercheck
####################
enable_mariadb_clustercheck: "yes"

View File

@ -89,3 +89,19 @@
- name: Ensure MariaDB is running normally on bootstrap host - name: Ensure MariaDB is running normally on bootstrap host
include_tasks: 'restart_services.yml' include_tasks: 'restart_services.yml'
listen: Bootstrap MariaDB cluster listen: Bootstrap MariaDB cluster
- name: Restart mariadb-clustercheck container
vars:
service_name: "mariadb-clustercheck"
service: "{{ mariadb_services[service_name] }}"
become: true
kolla_docker:
action: "recreate_or_restart_container"
common_options: "{{ docker_common_options }}"
image: "{{ service.image }}"
name: "{{ service.container_name }}"
volumes: "{{ service.volumes }}"
dimensions: "{{ service.dimensions }}"
environment: "{{ service.environment }}"
listen:
- restart mariadb-clustercheck

View File

@ -40,19 +40,17 @@
- inventory_hostname == mariadb_backup_host - inventory_hostname == mariadb_backup_host
- name: Copying over config.json files for services - name: Copying over config.json files for services
vars:
service_name: "mariadb"
service: "{{ mariadb_services[service_name] }}"
template: template:
src: "{{ service_name }}.json.j2" src: "{{ item.key }}.json.j2"
dest: "{{ node_config_directory }}/{{ service_name }}/config.json" dest: "{{ node_config_directory }}/{{ item.key }}/config.json"
mode: "0660" mode: "0660"
become: true become: true
when: when:
- inventory_hostname in groups[service.group] - inventory_hostname in groups[item.value.group]
- service.enabled | bool - item.value.enabled | bool
with_dict: "{{ mariadb_services }}"
notify: notify:
- restart mariadb - "restart {{ item.key }}"
- name: Copying over config.json files for mariabackup - name: Copying over config.json files for mariabackup
vars: vars:
@ -97,5 +95,20 @@
notify: notify:
- restart mariadb - restart mariadb
- name: Copying over xinetd clustercheck.conf
vars:
service_name: "mariadb-clustercheck"
service: "{{ mariadb_services[service_name] }}"
template:
src: "{{ role_path }}/templates/xinetd-clustercheck.j2"
dest: "{{ node_config_directory }}/{{ service_name }}/clustercheck"
mode: "0660"
become: true
when:
- inventory_hostname in groups[service.group]
- service.enabled | bool
notify:
- restart mariadb-clustercheck
- include_tasks: check-containers.yml - include_tasks: check-containers.yml
when: kolla_action != "config" when: kolla_action != "config"

View File

@ -185,15 +185,17 @@
- bootstrap_host is defined - bootstrap_host is defined
- bootstrap_host == inventory_hostname - bootstrap_host == inventory_hostname
- name: Restart slave MariaDB container - name: Restart slave MariaDB container(s)
become: true become: true
kolla_docker: kolla_docker:
action: "start_container" action: "start_container"
common_options: "{{ docker_common_options }}" common_options: "{{ docker_common_options }}"
name: "{{ mariadb_service.container_name }}" name: "{{ item.value.container_name }}"
image: "{{ mariadb_service.image }}" image: "{{ item.value.image }}"
volumes: "{{ mariadb_service.volumes }}" volumes: "{{ item.value.volumes }}"
dimensions: "{{ mariadb_service.dimensions }}" dimensions: "{{ item.value.dimensions }}"
environment: "{{ item.value.environment | default({}) }}"
with_dict: "{{ mariadb_services }}"
when: when:
- bootstrap_host is defined - bootstrap_host is defined
- bootstrap_host != inventory_hostname - bootstrap_host != inventory_hostname
@ -213,15 +215,17 @@
- bootstrap_host is defined - bootstrap_host is defined
- bootstrap_host != inventory_hostname - bootstrap_host != inventory_hostname
- name: Restart master MariaDB container - name: Restart master MariaDB container(s)
become: true become: true
kolla_docker: kolla_docker:
action: "recreate_or_restart_container" action: "recreate_or_restart_container"
common_options: "{{ docker_common_options }}" common_options: "{{ docker_common_options }}"
name: "{{ mariadb_service.container_name }}" name: "{{ item.value.container_name }}"
image: "{{ mariadb_service.image }}" image: "{{ item.value.image }}"
volumes: "{{ mariadb_service.volumes }}" volumes: "{{ item.value.volumes }}"
dimensions: "{{ mariadb_service.dimensions }}" dimensions: "{{ item.value.dimensions }}"
environment: "{{ item.value.environment | default({}) }}"
with_dict: "{{ mariadb_services }}"
when: when:
- bootstrap_host is defined - bootstrap_host is defined
- bootstrap_host == inventory_hostname - bootstrap_host == inventory_hostname

View File

@ -0,0 +1,18 @@
{
"command": "/usr/sbin/xinetd -dontfork -filelog /var/log/kolla/mariadb/xinetd.log",
"config_files": [
{
"source": "{{ container_config_directory }}/clustercheck",
"dest": "/etc/xinetd.d/clustercheck",
"owner": "root",
"perm": "0600"
}
],
"permissions": [
{
"path": "/var/log/kolla/mariadb",
"owner": "mysql:mysql",
"recurse": true
}
]
}

View File

@ -0,0 +1,16 @@
# default: on
# description: mysqlchk
service mysqlchk
{
disable = no
flags = REUSE
socket_type = stream
type = UNLISTED
port = {{ mariadb_clustercheck_port }}
wait = no
user = mysql
server = /usr/bin/clustercheck
log_type = FILE /var/log/kolla/mariadb/xinetd.log
log_on_failure = HOST ATTEMPT
per_source = UNLIMITED
}

View File

@ -0,0 +1,5 @@
---
features:
- |
Enable Galera node state checking by using ``clustercheck`` script that is
used by HAProxy to define node up/down state.