mysql_replication: Add aliases to "master" options, add alternatives to "master" state options, add announcement (#150) (#152)

* mysql_replication: Add aliases, add alternatives for the state option, announce major changes

* Change tests

* Add changelog fragment

* Fix changelog

* Update plugins/modules/mysql_replication.py

Co-authored-by: Jorge Rodriguez (A.K.A. Tiriel) <jorge.rodriguez@tiriel.eu>

* Update plugins/modules/mysql_replication.py

Co-authored-by: Jorge Rodriguez (A.K.A. Tiriel) <jorge.rodriguez@tiriel.eu>

Co-authored-by: Jorge Rodriguez (A.K.A. Tiriel) <jorge.rodriguez@tiriel.eu>
(cherry picked from commit c8f9b1cd3f)
This commit is contained in:
Andrew Klychkov 2021-04-23 08:31:02 +03:00 committed by GitHub
parent da7e73ef6e
commit d9651f37d3
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
9 changed files with 234 additions and 185 deletions

View file

@ -0,0 +1,6 @@
minor_changes:
- mysql_replication - change ``master_`` options to ``primary_`` options, add aliases to keep compatibility (https://github.com/ansible-collections/community.mysql/pull/150).
- mysql_replication - add alternative (``primary``) choices to the ``state`` option choices containing ``master`` (https://github.com/ansible-collections/community.mysql/pull/150).
major_changes:
- mysql_replication - the choices of the ``state`` option containing ``master`` will be finally replaced with the alternative ``primary`` choices in ``community.mysql`` 3.0.0, add deprecation warnings (https://github.com/ansible-collections/community.mysql/pull/150).

View file

@ -15,7 +15,7 @@ DOCUMENTATION = r'''
module: mysql_replication module: mysql_replication
short_description: Manage MySQL replication short_description: Manage MySQL replication
description: description:
- Manages MySQL server replication, replica, master status, get and change master host. - Manages MySQL server replication, replica, primary status, get and change primary host.
author: author:
- Balazs Pocze (@banyek) - Balazs Pocze (@banyek)
- Andrew Klychkov (@Andersson007) - Andrew Klychkov (@Andersson007)
@ -23,17 +23,19 @@ options:
mode: mode:
description: description:
- Module operating mode. Could be - Module operating mode. Could be
C(changemaster) (CHANGE MASTER TO), C(changeprimary | changemaster) (CHANGE PRIMARY | MASTER TO),
C(getmaster) (SHOW MASTER STATUS), C(getprimary | getmaster) (SHOW PRIMARY | MASTER STATUS),
C(getreplica | getslave) (SHOW REPLICA | SLAVE STATUS), C(getreplica | getslave) (SHOW REPLICA | SLAVE STATUS),
C(startreplica | startslave) (START REPLICA | SLAVE), C(startreplica | startslave) (START REPLICA | SLAVE),
C(stopreplica | stopslave) (STOP REPLICA | SLAVE), C(stopreplica | stopslave) (STOP REPLICA | SLAVE),
C(resetmaster) (RESET MASTER) - supported since community.mysql 0.1.0, C(resetprimary | resetmaster) (RESET PRIMARY | MASTER) - supported since community.mysql 0.1.0,
C(resetreplica, resetslave) (RESET REPLICA | SLAVE), C(resetreplica, resetslave) (RESET REPLICA | SLAVE),
C(resetreplicaall, resetslave) (RESET REPLICA | SLAVE ALL). C(resetreplicaall, resetslave) (RESET REPLICA | SLAVE ALL).
type: str type: str
choices: choices:
- changeprimary
- changemaster - changemaster
- getprimary
- getmaster - getmaster
- getreplica - getreplica
- getslave - getslave
@ -41,40 +43,48 @@ options:
- startslave - startslave
- stopreplica - stopreplica
- stopslave - stopslave
- resetprimary
- resetmaster - resetmaster
- resetreplica - resetreplica
- resetslave - resetslave
- resetreplicaall - resetreplicaall
- resetslaveall - resetslaveall
default: getreplica default: getreplica
master_host: primary_host:
description: description:
- Same as mysql variable. - Same as the C(MASTER_HOST) mysql variable.
type: str type: str
master_user: aliases: [master_host]
primary_user:
description: description:
- Same as mysql variable. - Same as the C(MASTER_USER) mysql variable.
type: str type: str
master_password: aliases: [master_user]
primary_password:
description: description:
- Same as mysql variable. - Same as the C(MASTER_PASSWORD) mysql variable.
type: str type: str
master_port: aliases: [master_password]
primary_port:
description: description:
- Same as mysql variable. - Same as the C(MASTER_PORT) mysql variable.
type: int type: int
master_connect_retry: aliases: [master_port]
primary_connect_retry:
description: description:
- Same as mysql variable. - Same as the C(MASTER_CONNECT_RETRY) mysql variable.
type: int type: int
master_log_file: aliases: [master_connect_retry]
primary_log_file:
description: description:
- Same as mysql variable. - Same as the C(MASTER_LOG_FILE) mysql variable.
type: str type: str
master_log_pos: aliases: [master_log_file]
primary_log_pos:
description: description:
- Same as mysql variable. - Same as the C(MASTER_LOG_POS) mysql variable.
type: int type: int
aliases: [master_log_pos]
relay_log_file: relay_log_file:
description: description:
- Same as mysql variable. - Same as mysql variable.
@ -83,7 +93,7 @@ options:
description: description:
- Same as mysql variable. - Same as mysql variable.
type: int type: int
master_ssl: primary_ssl:
description: description:
- Same as the C(MASTER_SSL) mysql variable. - Same as the C(MASTER_SSL) mysql variable.
- When setting it to C(yes), the connection attempt only succeeds - When setting it to C(yes), the connection attempt only succeeds
@ -92,43 +102,51 @@ options:
L(MySQL encrypted replication documentation,https://dev.mysql.com/doc/refman/8.0/en/replication-solutions-encrypted-connections.html). L(MySQL encrypted replication documentation,https://dev.mysql.com/doc/refman/8.0/en/replication-solutions-encrypted-connections.html).
type: bool type: bool
default: false default: false
master_ssl_ca: aliases: [master_ssl]
primary_ssl_ca:
description: description:
- Same as the C(MASTER_SSL_CA) mysql variable. - Same as the C(MASTER_SSL_CA) mysql variable.
- For details, refer to - For details, refer to
L(MySQL encrypted replication documentation,https://dev.mysql.com/doc/refman/8.0/en/replication-solutions-encrypted-connections.html). L(MySQL encrypted replication documentation,https://dev.mysql.com/doc/refman/8.0/en/replication-solutions-encrypted-connections.html).
type: str type: str
master_ssl_capath: aliases: [master_ssl_ca]
primary_ssl_capath:
description: description:
- Same as the C(MASTER_SSL_CAPATH) mysql variable. - Same as the C(MASTER_SSL_CAPATH) mysql variable.
- For details, refer to - For details, refer to
L(MySQL encrypted replication documentation,https://dev.mysql.com/doc/refman/8.0/en/replication-solutions-encrypted-connections.html). L(MySQL encrypted replication documentation,https://dev.mysql.com/doc/refman/8.0/en/replication-solutions-encrypted-connections.html).
type: str type: str
master_ssl_cert: aliases: [master_ssl_capath]
primary_ssl_cert:
description: description:
- Same as the C(MASTER_SSL_CERT) mysql variable. - Same as the C(MASTER_SSL_CERT) mysql variable.
- For details, refer to - For details, refer to
L(MySQL encrypted replication documentation,https://dev.mysql.com/doc/refman/8.0/en/replication-solutions-encrypted-connections.html). L(MySQL encrypted replication documentation,https://dev.mysql.com/doc/refman/8.0/en/replication-solutions-encrypted-connections.html).
type: str type: str
master_ssl_key: aliases: [master_ssl_cert]
primary_ssl_key:
description: description:
- Same as the C(MASTER_SSL_KEY) mysql variable. - Same as the C(MASTER_SSL_KEY) mysql variable.
- For details, refer to - For details, refer to
L(MySQL encrypted replication documentation,https://dev.mysql.com/doc/refman/8.0/en/replication-solutions-encrypted-connections.html). L(MySQL encrypted replication documentation,https://dev.mysql.com/doc/refman/8.0/en/replication-solutions-encrypted-connections.html).
type: str type: str
master_ssl_cipher: aliases: [master_ssl_key]
primary_ssl_cipher:
description: description:
- Same as the C(MASTER_SSL_CIPHER) mysql variable. - Same as the C(MASTER_SSL_CIPHER) mysql variable.
- Specifies a colon-separated list of one or more ciphers permitted by the replica for the replication connection. - Specifies a colon-separated list of one or more ciphers permitted by the replica for the replication connection.
- For details, refer to - For details, refer to
L(MySQL encrypted replication documentation,https://dev.mysql.com/doc/refman/8.0/en/replication-solutions-encrypted-connections.html). L(MySQL encrypted replication documentation,https://dev.mysql.com/doc/refman/8.0/en/replication-solutions-encrypted-connections.html).
type: str type: str
master_auto_position: aliases: [master_ssl_cipher]
primary_auto_position:
description: description:
- Whether the host uses GTID based replication or not. - Whether the host uses GTID based replication or not.
- Same as the C(MASTER_AUTO_POSITION) mysql variable.
type: bool type: bool
default: false default: false
master_use_gtid: aliases: [master_auto_position]
primary_use_gtid:
description: description:
- Configures the replica to use the MariaDB Global Transaction ID. - Configures the replica to use the MariaDB Global Transaction ID.
- C(disabled) equals MASTER_USE_GTID=no command. - C(disabled) equals MASTER_USE_GTID=no command.
@ -140,16 +158,19 @@ options:
choices: [current_pos, replica_pos, slave_pos, disabled] choices: [current_pos, replica_pos, slave_pos, disabled]
type: str type: str
version_added: '0.1.0' version_added: '0.1.0'
master_delay: aliases: [master_use_gtid]
primary_delay:
description: description:
- Time lag behind the master's state (in seconds). - Time lag behind the primary's state (in seconds).
- Same as the C(MASTER_DELAY) mysql variable.
- Available from MySQL 5.6. - Available from MySQL 5.6.
- For more information see U(https://dev.mysql.com/doc/refman/8.0/en/replication-delayed.html). - For more information see U(https://dev.mysql.com/doc/refman/8.0/en/replication-delayed.html).
type: int type: int
version_added: '0.1.0' version_added: '0.1.0'
aliases: [master_delay]
connection_name: connection_name:
description: description:
- Name of the master connection. - Name of the primary connection.
- Supported from MariaDB 10.0.1. - Supported from MariaDB 10.0.1.
- Mutually exclusive with I(channel). - Mutually exclusive with I(channel).
- For more information see U(https://mariadb.com/kb/en/library/multi-source-replication/). - For more information see U(https://mariadb.com/kb/en/library/multi-source-replication/).
@ -195,16 +216,16 @@ EXAMPLES = r'''
community.mysql.mysql_replication: community.mysql.mysql_replication:
mode: stopreplica mode: stopreplica
- name: Get master binlog file name and binlog position - name: Get primary binlog file name and binlog position
community.mysql.mysql_replication: community.mysql.mysql_replication:
mode: getmaster mode: getprimary
- name: Change master to master server 192.0.2.1 and use binary log 'mysql-bin.000009' with position 4578 - name: Change primary to primary server 192.0.2.1 and use binary log 'mysql-bin.000009' with position 4578
community.mysql.mysql_replication: community.mysql.mysql_replication:
mode: changemaster mode: changeprimary
master_host: 192.0.2.1 primary_host: 192.0.2.1
master_log_file: mysql-bin.000009 primary_log_file: mysql-bin.000009
master_log_pos: 4578 primary_log_pos: 4578
- name: Check replica status using port 3308 - name: Check replica status using port 3308
community.mysql.mysql_replication: community.mysql.mysql_replication:
@ -212,42 +233,42 @@ EXAMPLES = r'''
login_host: ansible.example.com login_host: ansible.example.com
login_port: 3308 login_port: 3308
- name: On MariaDB change master to use GTID current_pos - name: On MariaDB change primary to use GTID current_pos
community.mysql.mysql_replication: community.mysql.mysql_replication:
mode: changemaster mode: changeprimary
master_use_gtid: current_pos primary_use_gtid: current_pos
- name: Change master to use replication delay 3600 seconds - name: Change primary to use replication delay 3600 seconds
community.mysql.mysql_replication: community.mysql.mysql_replication:
mode: changemaster mode: changeprimary
master_host: 192.0.2.1 primary_host: 192.0.2.1
master_delay: 3600 primary_delay: 3600
- name: Start MariaDB replica with connection name master-1 - name: Start MariaDB replica with connection name primary-1
community.mysql.mysql_replication: community.mysql.mysql_replication:
mode: startreplica mode: startreplica
connection_name: master-1 connection_name: primary-1
- name: Stop replication in channel master-1 - name: Stop replication in channel primary-1
community.mysql.mysql_replication: community.mysql.mysql_replication:
mode: stopreplica mode: stopreplica
channel: master-1 channel: primary-1
- name: > - name: >
Run RESET MASTER command which will delete all existing binary log files Run RESET MASTER command which will delete all existing binary log files
and reset the binary log index file on the master and reset the binary log index file on the primary
community.mysql.mysql_replication: community.mysql.mysql_replication:
mode: resetmaster mode: resetprimary
- name: Run start replica and fail the task on errors - name: Run start replica and fail the task on errors
community.mysql.mysql_replication: community.mysql.mysql_replication:
mode: startreplica mode: startreplica
connection_name: master-1 connection_name: primary-1
fail_on_error: yes fail_on_error: yes
- name: Change master and fail on error (like when replica thread is running) - name: Change primary and fail on error (like when replica thread is running)
community.mysql.mysql_replication: community.mysql.mysql_replication:
mode: changemaster mode: changeprimary
fail_on_error: yes fail_on_error: yes
''' '''
@ -257,7 +278,7 @@ queries:
description: List of executed queries which modified DB's state. description: List of executed queries which modified DB's state.
returned: always returned: always
type: list type: list
sample: ["CHANGE MASTER TO MASTER_HOST='master2.example.com',MASTER_PORT=3306"] sample: ["CHANGE MASTER TO MASTER_HOST='primary2.example.com',MASTER_PORT=3306"]
version_added: '0.1.0' version_added: '0.1.0'
''' '''
@ -277,10 +298,13 @@ from distutils.version import LooseVersion
executed_queries = [] executed_queries = []
def get_master_status(cursor): def get_primary_status(cursor):
# TODO: when it's available to change on MySQL's side,
# change MASTER to PRIMARY using the approach from
# get_replica_status() function. Same for other functions.
cursor.execute("SHOW MASTER STATUS") cursor.execute("SHOW MASTER STATUS")
masterstatus = cursor.fetchone() primarystatus = cursor.fetchone()
return masterstatus return primarystatus
def get_replica_status(cursor, connection_name='', channel='', term='REPLICA'): def get_replica_status(cursor, connection_name='', channel='', term='REPLICA'):
@ -363,7 +387,7 @@ def reset_replica_all(module, cursor, connection_name='', channel='', fail_on_er
return reset return reset
def reset_master(module, cursor, fail_on_error=False): def reset_primary(module, cursor, fail_on_error=False):
query = 'RESET MASTER' query = 'RESET MASTER'
try: try:
executed_queries.append(query) executed_queries.append(query)
@ -400,7 +424,7 @@ def start_replica(module, cursor, connection_name='', channel='', fail_on_error=
return started return started
def changemaster(cursor, chm, connection_name='', channel=''): def changeprimary(cursor, chm, connection_name='', channel=''):
if connection_name: if connection_name:
query = "CHANGE MASTER '%s' TO %s" % (connection_name, ','.join(chm)) query = "CHANGE MASTER '%s' TO %s" % (connection_name, ','.join(chm))
else: else:
@ -417,29 +441,33 @@ def main():
argument_spec = mysql_common_argument_spec() argument_spec = mysql_common_argument_spec()
argument_spec.update( argument_spec.update(
mode=dict(type='str', default='getreplica', choices=[ mode=dict(type='str', default='getreplica', choices=[
'getmaster', 'getreplica', 'getslave', 'changemaster', 'getprimary', 'getmaster',
'stopreplica', 'stopslave', 'startreplica', 'startslave', 'getreplica', 'getslave',
'resetmaster', 'resetreplica', 'resetslave', 'changeprimary', 'changemaster',
'stopreplica', 'stopslave',
'startreplica', 'startslave',
'resetprimary', 'resetmaster',
'resetreplica', 'resetslave',
'resetreplicaall', 'resetslaveall']), 'resetreplicaall', 'resetslaveall']),
master_auto_position=dict(type='bool', default=False), primary_auto_position=dict(type='bool', default=False, aliases=['master_auto_position']),
master_host=dict(type='str'), primary_host=dict(type='str', aliases=['master_host']),
master_user=dict(type='str'), primary_user=dict(type='str', aliases=['master_user']),
master_password=dict(type='str', no_log=True), primary_password=dict(type='str', no_log=True, aliases=['master_password']),
master_port=dict(type='int'), primary_port=dict(type='int', aliases=['master_port']),
master_connect_retry=dict(type='int'), primary_connect_retry=dict(type='int', aliases=['master_connect_retry']),
master_log_file=dict(type='str'), primary_log_file=dict(type='str', aliases=['master_log_file']),
master_log_pos=dict(type='int'), primary_log_pos=dict(type='int', aliases=['master_log_pos']),
relay_log_file=dict(type='str'), relay_log_file=dict(type='str'),
relay_log_pos=dict(type='int'), relay_log_pos=dict(type='int'),
master_ssl=dict(type='bool', default=False), primary_ssl=dict(type='bool', default=False, aliases=['master_ssl']),
master_ssl_ca=dict(type='str'), primary_ssl_ca=dict(type='str', aliases=['master_ssl_ca']),
master_ssl_capath=dict(type='str'), primary_ssl_capath=dict(type='str', aliases=['master_ssl_capath']),
master_ssl_cert=dict(type='str'), primary_ssl_cert=dict(type='str', aliases=['master_ssl_cert']),
master_ssl_key=dict(type='str', no_log=False), primary_ssl_key=dict(type='str', no_log=False, aliases=['master_ssl_key']),
master_ssl_cipher=dict(type='str'), primary_ssl_cipher=dict(type='str', aliases=['master_ssl_cipher']),
master_use_gtid=dict(type='str', choices=[ primary_use_gtid=dict(type='str', choices=[
'current_pos', 'replica_pos', 'slave_pos', 'disabled']), 'current_pos', 'replica_pos', 'slave_pos', 'disabled'], aliases=['master_use_gtid']),
master_delay=dict(type='int'), primary_delay=dict(type='int', aliases=['master_delay']),
connection_name=dict(type='str'), connection_name=dict(type='str'),
channel=dict(type='str'), channel=dict(type='str'),
fail_on_error=dict(type='bool', default=False), fail_on_error=dict(type='bool', default=False),
@ -451,33 +479,33 @@ def main():
], ],
) )
mode = module.params["mode"] mode = module.params["mode"]
master_host = module.params["master_host"] primary_host = module.params["primary_host"]
master_user = module.params["master_user"] primary_user = module.params["primary_user"]
master_password = module.params["master_password"] primary_password = module.params["primary_password"]
master_port = module.params["master_port"] primary_port = module.params["primary_port"]
master_connect_retry = module.params["master_connect_retry"] primary_connect_retry = module.params["primary_connect_retry"]
master_log_file = module.params["master_log_file"] primary_log_file = module.params["primary_log_file"]
master_log_pos = module.params["master_log_pos"] primary_log_pos = module.params["primary_log_pos"]
relay_log_file = module.params["relay_log_file"] relay_log_file = module.params["relay_log_file"]
relay_log_pos = module.params["relay_log_pos"] relay_log_pos = module.params["relay_log_pos"]
master_ssl = module.params["master_ssl"] primary_ssl = module.params["primary_ssl"]
master_ssl_ca = module.params["master_ssl_ca"] primary_ssl_ca = module.params["primary_ssl_ca"]
master_ssl_capath = module.params["master_ssl_capath"] primary_ssl_capath = module.params["primary_ssl_capath"]
master_ssl_cert = module.params["master_ssl_cert"] primary_ssl_cert = module.params["primary_ssl_cert"]
master_ssl_key = module.params["master_ssl_key"] primary_ssl_key = module.params["primary_ssl_key"]
master_ssl_cipher = module.params["master_ssl_cipher"] primary_ssl_cipher = module.params["primary_ssl_cipher"]
master_auto_position = module.params["master_auto_position"] primary_auto_position = module.params["primary_auto_position"]
ssl_cert = module.params["client_cert"] ssl_cert = module.params["client_cert"]
ssl_key = module.params["client_key"] ssl_key = module.params["client_key"]
ssl_ca = module.params["ca_cert"] ssl_ca = module.params["ca_cert"]
check_hostname = module.params["check_hostname"] check_hostname = module.params["check_hostname"]
connect_timeout = module.params['connect_timeout'] connect_timeout = module.params['connect_timeout']
config_file = module.params['config_file'] config_file = module.params['config_file']
master_delay = module.params['master_delay'] primary_delay = module.params['primary_delay']
if module.params.get("master_use_gtid") == 'disabled': if module.params.get("primary_use_gtid") == 'disabled':
master_use_gtid = 'no' primary_use_gtid = 'no'
else: else:
master_use_gtid = module.params["master_use_gtid"] primary_use_gtid = module.params["primary_use_gtid"]
connection_name = module.params["connection_name"] connection_name = module.params["connection_name"]
channel = module.params['channel'] channel = module.params['channel']
fail_on_error = module.params['fail_on_error'] fail_on_error = module.params['fail_on_error']
@ -512,18 +540,24 @@ def main():
# "REPLICA" must be used instead of "SLAVE" # "REPLICA" must be used instead of "SLAVE"
if impl.uses_replica_terminology(cursor): if impl.uses_replica_terminology(cursor):
replica_term = 'REPLICA' replica_term = 'REPLICA'
if master_use_gtid == 'slave_pos': if primary_use_gtid == 'slave_pos':
module.deprecate('master_use_gtid "slave_pos" value is deprecated, use "replica_pos" instead.', module.deprecate('primary_use_gtid | master_use_gtid "slave_pos" value is '
'deprecated, use "replica_pos" instead.',
version='3.0.0', collection_name='community.mysql') version='3.0.0', collection_name='community.mysql')
master_use_gtid = 'replica_pos' primary_use_gtid = 'replica_pos'
else: else:
replica_term = 'SLAVE' replica_term = 'SLAVE'
if master_use_gtid == 'replica_pos': if primary_use_gtid == 'replica_pos':
master_use_gtid = 'slave_pos' primary_use_gtid = 'slave_pos'
if mode in "getmaster": if mode in ('getprimary', 'getmaster'):
status = get_master_status(cursor) if mode == 'getmaster':
module.deprecate('"getmaster" option is deprecated, use "getprimary" instead.',
version='3.0.0', collection_name='community.mysql')
status = get_primary_status(cursor)
if not isinstance(status, dict): if not isinstance(status, dict):
# TODO: change the word master to primary in 3.0.0
status = dict(Is_Master=False, Is_Primary=False, status = dict(Is_Master=False, Is_Primary=False,
msg="Server is not configured as mysql master") msg="Server is not configured as mysql master")
else: else:
@ -556,47 +590,50 @@ def main():
module.exit_json(queries=executed_queries, **status) module.exit_json(queries=executed_queries, **status)
elif mode in "changemaster": elif mode in ('changeprimary', 'changemaster'):
if mode == 'changemaster':
module.deprecate('"changemaster" option is deprecated, use "changeprimary" instead.',
version='3.0.0', collection_name='community.mysql')
chm = [] chm = []
result = {} result = {}
if master_host is not None: if primary_host is not None:
chm.append("MASTER_HOST='%s'" % master_host) chm.append("MASTER_HOST='%s'" % primary_host)
if master_user is not None: if primary_user is not None:
chm.append("MASTER_USER='%s'" % master_user) chm.append("MASTER_USER='%s'" % primary_user)
if master_password is not None: if primary_password is not None:
chm.append("MASTER_PASSWORD='%s'" % master_password) chm.append("MASTER_PASSWORD='%s'" % primary_password)
if master_port is not None: if primary_port is not None:
chm.append("MASTER_PORT=%s" % master_port) chm.append("MASTER_PORT=%s" % primary_port)
if master_connect_retry is not None: if primary_connect_retry is not None:
chm.append("MASTER_CONNECT_RETRY=%s" % master_connect_retry) chm.append("MASTER_CONNECT_RETRY=%s" % primary_connect_retry)
if master_log_file is not None: if primary_log_file is not None:
chm.append("MASTER_LOG_FILE='%s'" % master_log_file) chm.append("MASTER_LOG_FILE='%s'" % primary_log_file)
if master_log_pos is not None: if primary_log_pos is not None:
chm.append("MASTER_LOG_POS=%s" % master_log_pos) chm.append("MASTER_LOG_POS=%s" % primary_log_pos)
if master_delay is not None: if primary_delay is not None:
chm.append("MASTER_DELAY=%s" % master_delay) chm.append("MASTER_DELAY=%s" % primary_delay)
if relay_log_file is not None: if relay_log_file is not None:
chm.append("RELAY_LOG_FILE='%s'" % relay_log_file) chm.append("RELAY_LOG_FILE='%s'" % relay_log_file)
if relay_log_pos is not None: if relay_log_pos is not None:
chm.append("RELAY_LOG_POS=%s" % relay_log_pos) chm.append("RELAY_LOG_POS=%s" % relay_log_pos)
if master_ssl: if primary_ssl:
chm.append("MASTER_SSL=1") chm.append("MASTER_SSL=1")
if master_ssl_ca is not None: if primary_ssl_ca is not None:
chm.append("MASTER_SSL_CA='%s'" % master_ssl_ca) chm.append("MASTER_SSL_CA='%s'" % primary_ssl_ca)
if master_ssl_capath is not None: if primary_ssl_capath is not None:
chm.append("MASTER_SSL_CAPATH='%s'" % master_ssl_capath) chm.append("MASTER_SSL_CAPATH='%s'" % primary_ssl_capath)
if master_ssl_cert is not None: if primary_ssl_cert is not None:
chm.append("MASTER_SSL_CERT='%s'" % master_ssl_cert) chm.append("MASTER_SSL_CERT='%s'" % primary_ssl_cert)
if master_ssl_key is not None: if primary_ssl_key is not None:
chm.append("MASTER_SSL_KEY='%s'" % master_ssl_key) chm.append("MASTER_SSL_KEY='%s'" % primary_ssl_key)
if master_ssl_cipher is not None: if primary_ssl_cipher is not None:
chm.append("MASTER_SSL_CIPHER='%s'" % master_ssl_cipher) chm.append("MASTER_SSL_CIPHER='%s'" % primary_ssl_cipher)
if master_auto_position: if primary_auto_position:
chm.append("MASTER_AUTO_POSITION=1") chm.append("MASTER_AUTO_POSITION=1")
if master_use_gtid is not None: if primary_use_gtid is not None:
chm.append("MASTER_USE_GTID=%s" % master_use_gtid) chm.append("MASTER_USE_GTID=%s" % primary_use_gtid)
try: try:
changemaster(cursor, chm, connection_name, channel) changeprimary(cursor, chm, connection_name, channel)
except mysql_driver.Warning as e: except mysql_driver.Warning as e:
result['warning'] = to_native(e) result['warning'] = to_native(e)
except Exception as e: except Exception as e:
@ -623,11 +660,17 @@ def main():
module.exit_json(msg="Replica stopped", changed=True, queries=executed_queries) module.exit_json(msg="Replica stopped", changed=True, queries=executed_queries)
else: else:
module.exit_json(msg="Replica already stopped", changed=False, queries=executed_queries) module.exit_json(msg="Replica already stopped", changed=False, queries=executed_queries)
elif mode in "resetmaster": elif mode in ('resetprimary', 'resetmaster'):
reset = reset_master(module, cursor, fail_on_error) if mode == 'resetmaster':
module.deprecate('"resetmaster" option is deprecated, use "resetprimary" instead.',
version='3.0.0', collection_name='community.mysql')
reset = reset_primary(module, cursor, fail_on_error)
if reset is True: if reset is True:
# TODO: Change "Master" to "Primary" in release 3.0.0
module.exit_json(msg="Master reset", changed=True, queries=executed_queries) module.exit_json(msg="Master reset", changed=True, queries=executed_queries)
else: else:
# TODO: Change "Master" to "Primary" in release 3.0.0
module.exit_json(msg="Master already reset", changed=False, queries=executed_queries) module.exit_json(msg="Master already reset", changed=False, queries=executed_queries)
elif mode in ("resetreplica", "resetslave"): elif mode in ("resetreplica", "resetslave"):
if mode == "resetslave": if mode == "resetslave":

View file

@ -7,7 +7,7 @@ mysql_replica2_port: 3309
test_db: test_db test_db: test_db
test_table: test_table test_table: test_table
test_master_delay: 60 test_primary_delay: 60
replication_user: replication_user replication_user: replication_user
replication_pass: replication_pass replication_pass: replication_pass
dump_path: /tmp/dump.sql dump_path: /tmp/dump.sql

View file

@ -36,7 +36,7 @@
- name: attempt connection with newly created user (expect failure) - name: attempt connection with newly created user (expect failure)
mysql_replication: mysql_replication:
mode: getmaster mode: getprimary
login_user: '{{ user_name_1 }}' login_user: '{{ user_name_1 }}'
login_password: '{{ user_password_1 }}' login_password: '{{ user_password_1 }}'
login_host: 127.0.0.1 login_host: 127.0.0.1
@ -57,7 +57,7 @@
- name: attempt connection with newly created user ignoring hostname - name: attempt connection with newly created user ignoring hostname
mysql_replication: mysql_replication:
mode: getmaster mode: getprimary
login_user: '{{ user_name_1 }}' login_user: '{{ user_name_1 }}'
login_password: '{{ user_password_1 }}' login_password: '{{ user_password_1 }}'
login_host: 127.0.0.1 login_host: 127.0.0.1

View file

@ -9,13 +9,13 @@
# Initial CI tests of mysql_replication module: # Initial CI tests of mysql_replication module:
- import_tasks: mysql_replication_initial.yml - import_tasks: mysql_replication_initial.yml
# Tests of master_delay parameter: # Tests of primary_delay parameter:
- import_tasks: mysql_replication_master_delay.yml - import_tasks: mysql_replication_primary_delay.yml
# Tests of channel parameter: # Tests of channel parameter:
- import_tasks: mysql_replication_channel.yml - import_tasks: mysql_replication_channel.yml
# Tests of resetmaster mode: # Tests of resetprimary mode:
- import_tasks: mysql_replication_resetmaster_mode.yml - import_tasks: mysql_replication_resetprimary_mode.yml
- include: issue-28.yml - include: issue-28.yml

View file

@ -8,26 +8,26 @@
login_host: 127.0.0.1 login_host: 127.0.0.1
block: block:
# Get master log file and log pos: # Get primary log file and log pos:
- name: Get master status - name: Get primary status
mysql_replication: mysql_replication:
<<: *mysql_params <<: *mysql_params
login_port: '{{ mysql_primary_port }}' login_port: '{{ mysql_primary_port }}'
mode: getmaster mode: getprimary
register: mysql_primary_status register: mysql_primary_status
# Test changemaster mode: # Test changeprimary mode:
- name: Run replication with channel - name: Run replication with channel
mysql_replication: mysql_replication:
<<: *mysql_params <<: *mysql_params
login_port: '{{ mysql_replica2_port }}' login_port: '{{ mysql_replica2_port }}'
mode: changemaster mode: changeprimary
master_host: '{{ mysql_host }}' primary_host: '{{ mysql_host }}'
master_port: '{{ mysql_primary_port }}' primary_port: '{{ mysql_primary_port }}'
master_user: '{{ replication_user }}' primary_user: '{{ replication_user }}'
master_password: '{{ replication_pass }}' primary_password: '{{ replication_pass }}'
master_log_file: '{{ mysql_primary_status.File }}' primary_log_file: '{{ mysql_primary_status.File }}'
master_log_pos: '{{ mysql_primary_status.Position }}' primary_log_pos: '{{ mysql_primary_status.Position }}'
channel: '{{ test_channel }}' channel: '{{ test_channel }}'
register: result register: result

View file

@ -49,12 +49,12 @@
- name: Restore the dump to replica2 - name: Restore the dump to replica2
shell: '{{ mysql_command }} -P{{ mysql_replica2_port }} < {{ dump_path }}' shell: '{{ mysql_command }} -P{{ mysql_replica2_port }} < {{ dump_path }}'
# Test getmaster mode: # Test getprimary mode:
- name: Get master status - name: Get primary status
mysql_replication: mysql_replication:
<<: *mysql_params <<: *mysql_params
login_port: '{{ mysql_primary_port }}' login_port: '{{ mysql_primary_port }}'
mode: getmaster mode: getprimary
register: mysql_primary_status register: mysql_primary_status
- assert: - assert:
@ -63,8 +63,8 @@
- mysql_primary_status.Position != 0 - mysql_primary_status.Position != 0
- mysql_primary_status is not changed - mysql_primary_status is not changed
# Test startreplica fails without changemaster first. This needs fail_on_error # Test startreplica fails without changeprimary first. This needs fail_on_error
- name: Start replica (using deprecated startslave choice) and fail because master is not specified; failing on error as requested - name: Start replica (using deprecated startslave choice) and fail because primary is not specified; failing on error as requested
mysql_replication: mysql_replication:
<<: *mysql_params <<: *mysql_params
login_port: '{{ mysql_replica1_port }}' login_port: '{{ mysql_replica1_port }}'
@ -103,21 +103,21 @@
that: that:
- result is not failed - result is not failed
# Test changemaster mode: # Test changeprimary mode:
# master_ssl_ca will be set as '' to check the module's behaviour for #23976, # primary_ssl_ca will be set as '' to check the module's behaviour for #23976,
# must be converted to an empty string # must be converted to an empty string
- name: Run replication - name: Run replication
mysql_replication: mysql_replication:
<<: *mysql_params <<: *mysql_params
login_port: '{{ mysql_replica1_port }}' login_port: '{{ mysql_replica1_port }}'
mode: changemaster mode: changeprimary
master_host: '{{ mysql_host }}' primary_host: '{{ mysql_host }}'
master_port: '{{ mysql_primary_port }}' primary_port: '{{ mysql_primary_port }}'
master_user: '{{ replication_user }}' primary_user: '{{ replication_user }}'
master_password: '{{ replication_pass }}' primary_password: '{{ replication_pass }}'
master_log_file: '{{ mysql_primary_status.File }}' primary_log_file: '{{ mysql_primary_status.File }}'
master_log_pos: '{{ mysql_primary_status.Position }}' primary_log_pos: '{{ mysql_primary_status.Position }}'
master_ssl_ca: '' primary_ssl_ca: ''
register: result register: result
- assert: - assert:
@ -179,7 +179,7 @@
pause: pause:
seconds: 2 seconds: 2
# Test master log pos has been changed: # Test primary log pos has been changed:
- name: Get replica status - name: Get replica status
mysql_replication: mysql_replication:
<<: *mysql_params <<: *mysql_params

View file

@ -9,13 +9,13 @@
block: block:
# Test master_delay mode: # Test primary_delay mode:
- name: Run replication - name: Run replication
mysql_replication: mysql_replication:
<<: *mysql_params <<: *mysql_params
login_port: '{{ mysql_replica1_port }}' login_port: '{{ mysql_replica1_port }}'
mode: changemaster mode: changeprimary
master_delay: '{{ test_master_delay }}' primary_delay: '{{ test_primary_delay }}'
register: result register: result
- assert: - assert:
@ -31,7 +31,7 @@
mode: startreplica mode: startreplica
register: result register: result
# Check master_delay: # Check primary_delay:
- name: Get standby status - name: Get standby status
mysql_replication: mysql_replication:
<<: *mysql_params <<: *mysql_params
@ -41,5 +41,5 @@
- assert: - assert:
that: that:
- replica_status.SQL_Delay == {{ test_master_delay }} - replica_status.SQL_Delay == {{ test_primary_delay }}
- replica_status is not changed - replica_status is not changed

View file

@ -22,20 +22,20 @@
login_port: '{{ mysql_replica1_port }}' login_port: '{{ mysql_replica1_port }}'
mode: resetreplicaall mode: resetreplicaall
# Get master initial status: # Get primary initial status:
- name: Get master status - name: Get primary status
mysql_replication: mysql_replication:
<<: *mysql_params <<: *mysql_params
login_port: '{{ mysql_primary_port }}' login_port: '{{ mysql_primary_port }}'
mode: getmaster mode: getprimary
register: mysql_primary_initial_status register: mysql_primary_initial_status
# Test resetmaster mode: # Test resetprimary mode:
- name: Reset master - name: Reset primary
mysql_replication: mysql_replication:
<<: *mysql_params <<: *mysql_params
login_port: '{{ mysql_primary_port }}' login_port: '{{ mysql_primary_port }}'
mode: resetmaster mode: resetprimary
register: result register: result
- assert: - assert:
@ -43,12 +43,12 @@
- result is changed - result is changed
- result.queries == ["RESET MASTER"] - result.queries == ["RESET MASTER"]
# Get master final status: # Get primary final status:
- name: Get master status - name: Get primary status
mysql_replication: mysql_replication:
<<: *mysql_params <<: *mysql_params
login_port: '{{ mysql_primary_port }}' login_port: '{{ mysql_primary_port }}'
mode: getmaster mode: getprimary
register: mysql_primary_final_status register: mysql_primary_final_status
- assert: - assert: