mirror of
https://github.com/ansible-collections/community.mysql.git
synced 2025-04-05 10:10:32 -07:00
mysql_db: added zstd
support (#696)
This commit is contained in:
parent
022ed60906
commit
a45a0d006d
2 changed files with 9 additions and 2 deletions
3
changelogs/fragments/696-mysql-db-add-zstd-support.yml
Normal file
3
changelogs/fragments/696-mysql-db-add-zstd-support.yml
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
minor_changes:
|
||||||
|
- mysql_db - added ``zstd`` (de)compression support for ``import``/``dump`` states
|
||||||
|
(https://github.com/ansible-collections/community.mysql/issues/696).
|
|
@ -46,8 +46,8 @@ options:
|
||||||
target:
|
target:
|
||||||
description:
|
description:
|
||||||
- Location, on the remote host, of the dump file to read from or write to.
|
- Location, on the remote host, of the dump file to read from or write to.
|
||||||
- Uncompressed SQL files (C(.sql)) as well as bzip2 (C(.bz2)), gzip (C(.gz)) and
|
- Uncompressed SQL files (C(.sql)) as well as bzip2 (C(.bz2)), gzip (C(.gz)),
|
||||||
xz (Added in 2.0) compressed files are supported.
|
xz (Added in 2.0) and zstd (C(.zst)) (Added in 3.12.0) compressed files are supported.
|
||||||
type: path
|
type: path
|
||||||
single_transaction:
|
single_transaction:
|
||||||
description:
|
description:
|
||||||
|
@ -455,6 +455,8 @@ def db_dump(module, host, user, password, db_name, target, all_databases, port,
|
||||||
path = module.get_bin_path('bzip2', True)
|
path = module.get_bin_path('bzip2', True)
|
||||||
elif os.path.splitext(target)[-1] == '.xz':
|
elif os.path.splitext(target)[-1] == '.xz':
|
||||||
path = module.get_bin_path('xz', True)
|
path = module.get_bin_path('xz', True)
|
||||||
|
elif os.path.splitext(target)[-1] == '.zst':
|
||||||
|
path = module.get_bin_path('zstd', True)
|
||||||
|
|
||||||
if path:
|
if path:
|
||||||
cmd = '%s | %s > %s' % (cmd, path, shlex_quote(target))
|
cmd = '%s | %s > %s' % (cmd, path, shlex_quote(target))
|
||||||
|
@ -526,6 +528,8 @@ def db_import(module, host, user, password, db_name, target, all_databases, port
|
||||||
comp_prog_path = module.get_bin_path('bzip2', required=True)
|
comp_prog_path = module.get_bin_path('bzip2', required=True)
|
||||||
elif os.path.splitext(target)[-1] == '.xz':
|
elif os.path.splitext(target)[-1] == '.xz':
|
||||||
comp_prog_path = module.get_bin_path('xz', required=True)
|
comp_prog_path = module.get_bin_path('xz', required=True)
|
||||||
|
elif os.path.splitext(target)[-1] == '.zst':
|
||||||
|
comp_prog_path = module.get_bin_path('zstd', required=True)
|
||||||
if comp_prog_path:
|
if comp_prog_path:
|
||||||
# The line below is for returned data only:
|
# The line below is for returned data only:
|
||||||
executed_commands.append('%s -dc %s | %s' % (comp_prog_path, target, cmd))
|
executed_commands.append('%s -dc %s | %s' % (comp_prog_path, target, cmd))
|
||||||
|
|
Loading…
Add table
Reference in a new issue