一、工具介绍
- 前几日用
mysql-sandbox
来搭建MySQL8.0
新版本时发现用不了,提示需要使用dbdeployer
才行,瞬间觉得mysql-sandbox
不香了,只好咬咬牙来熟悉dbdeployer
了。 dbdeployer
是使用go
语言重构的sandbox
,和sandbox
同一个作者。- 当然,
dbdeployer
延续了sandbox
所有功能。可实现一键部署不同架构、不同版本的数据库环境。如,MySQL 主从复制、GTID 模式复制、MySQL 组复制(单主模式、多主模式等) - 完整的数据库类型支持及版本,可在安装完 dbdeployer 后使用
dbdeployer admin capabilities
命令进行查看,以下是当前已支持数据库及组件类型
- – pxc (Percona XtraDB Cluster)
- – mysql-shell
- – mysql (MySQL server)
- – percona (Percona Server)
- – mariadb
- – tidb (TiDB isolated server)
- – ndb (MySQL NDB Cluster)
二、工具安装
- OS:
centos8
- dbdeployer:
1.54.0
- mysql:
8.0.20
2.1 dbdeployer
工具下载
直接到github下载release包即可:
https://github.com/datacharmer/dbdeployer/releases
2.2 解压
软件解压后实际只有一个单独的编译好的可执行文件
tar -zxvf dbdeployer-1.54.0.linux.tar.gz
2.3 赋予可执行权限
chmod +x dbdeployer-1.54.0.linux
2.4 移动到系统可执行目录下方便使用
mv dbdeployer-1.54.0.linux /usr/local/bin/dbdeployer
2.5 验证是否可以使用
[root@db01 tmp]# dbdeployer --version
dbdeployer version 1.54.0
[root@db01 tmp]# dbdeployer --help
dbdeployer makes MySQL server installation an easy task.
Runs single, multiple, and replicated sandboxes.
Usage:
dbdeployer [command]
Available Commands:
admin sandbox management tasks
cookbook Shows dbdeployer samples
defaults tasks related to dbdeployer defaults
delete delete an installed sandbox
delete-binaries delete an expanded tarball
deploy deploy sandboxes
downloads Manages remote tarballs
export Exports the command structure in JSON format
global Runs a given command in every sandbox
help Help about any command
import imports one or more MySQL servers into a sandbox
info Shows information about dbdeployer environment samples
init initializes dbdeployer environment
sandboxes List installed sandboxes
unpack unpack a tarball into the binary directory
update Gets dbdeployer newest version
usage Shows usage of installed sandboxes
use uses a sandbox
versions List available versions
Flags:
--config string configuration file (default "/root/.dbdeployer/config.json")
-h, --help help for dbdeployer
--sandbox-binary string Binary repository (default "/root/opt/mysql")
--sandbox-home string Sandbox deployment directory (default "/root/sandboxes")
--shell-path string Which shell to use for generated scripts (default "/usr/bin/bash")
--skip-library-check Skip check for needed libraries (may cause nasty errors)
-v, --version version for dbdeployer
Use "dbd