下载最新的dbdeployer1.6.0,使用非root帐户安装dbdeployer,特别是mv的时候。sql
1,解压缓存
dbdeployer unpack Percona-Server-5.7.22-22-Linux.x86_64.ssl101.tar.gz --sandbox-binary=/usr/localbash
2,安装单实例Percona Serverpost
dbdeployer deploy single 8.0.11 --sandbox-home=/data/bakup --sandbox-binary=/usr/local --port=8011 --concurrent --native-auth-plugin --bind-address=0.0.0.0 --remote-access="%" --db-password="cc.123" --db-user="sa" --post-grants-sql="grant all on *.* to 'sa'@'%' with grant option ";
注明: 1,这里的--port 是指安装后MySQL的端口 2,--native-auth-plugin 客户端如SQLLog能够访问MySQL
性能
安装tokudb的pluginsspa
INSTALL PLUGIN tokudb SONAME 'ha_tokudb.so'; INSTALL PLUGIN tokudb_file_map SONAME 'ha_tokudb.so'; INSTALL PLUGIN tokudb_fractal_tree_info SONAME 'ha_tokudb.so'; INSTALL PLUGIN tokudb_fractal_tree_block_map SONAME 'ha_tokudb.so'; INSTALL PLUGIN tokudb_trx SONAME 'ha_tokudb.so'; INSTALL PLUGIN tokudb_locks SONAME 'ha_tokudb.so'; INSTALL PLUGIN tokudb_lock_waits SONAME 'ha_tokudb.so'; INSTALL PLUGIN tokudb_background_job_status SONAME 'ha_tokudb.so';
查看:SHOW ENGINES; tokudb是否安装完毕!线程
SELECT @@tokudb_version; 查看tokudb的版本!blog
TokuDB里可调优的参数很少,今天把"最重要"的几个拉出来晒晒。事务
与性能相关的参数及说明:内存
tokudb_cache_size(bytes): 缓存大小,读写时候,数据会首先会缓存到这里。 默认大小为机器物理内存的一半。
tokudb_commit_sync(ON/OFF): 当事务提交的时候,是否要fsync log到磁盘。 默认开启(ON),若是设置为OFF,性能会提高,但可能会丢失事务(commit记录到log buffer,可是未fsync到磁盘的事务)。 tokudb_directio(ON/OFF): 是否开启Direct I/O功能,TokuDB在写盘的时候,不管是否开启Direct I/O,都是按照512字节对齐的。 默认为OFF。 tokudb_fsync_log_period(ms): 多久fsync一下log buffer到磁盘,TokuDB的log buffer总大小为32MB且不可更改。 默认为0ms(此时作fsync的后台线程一直处于wait状态),此时受tokudb_commit_sync开关控制是否要fsync log到磁盘(checkpoint也会fsync log buffer的,默认为1分钟)。
针对不一样的使用场景:
1) 对数据要求较高(不容许丢失数据,事务ACID完整性),只需根据内存调整tokudb_cache_size大小便可,建议开启tokudb_directio。
2) 对数据要求不过高(容许部分数据丢失,不要求事务ACID完整性),可配置:
tokudb_commit_sync=OFF
tokudb_fsync_log_period=1000 #1s
在此配置下,每1秒对log buffer作下fsync,可充分利用log的group commit功能,若是TokuDB挂掉,则可能会丢失最多1秒的数据。