如何進行Tokudb安裝測試,相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
創(chuàng)新互聯(lián)公司是一家專注于成都網(wǎng)站制作、網(wǎng)站設計與策劃設計,麥積網(wǎng)站建設哪家好?創(chuàng)新互聯(lián)公司做網(wǎng)站,專注于網(wǎng)站建設10年,網(wǎng)設計領域的專業(yè)建站公司;建站業(yè)務涵蓋:麥積等地區(qū)。麥積做網(wǎng)站價格咨詢:18980820575
一 前言
TokuDB 是一個高性能、支持MVCC的MySQL 和 MariaDB 的存儲引擎。TokuDB 的主要特點是數(shù)據(jù)壓縮功能出色,對高寫壓力的支持,由美國TokuTek公司(http://www.tokutek.com/) 研發(fā),該公司于2015年4月份被Percona收購,理所當然地提供了TokuDB版本的Percona Server。本文使用Peronca server 5.6.30 版本進行測試安裝。
二 安裝前的準備
請參考官方文檔 Percona Server YUM源 ,Percona Server tokudb安裝文檔
三 安裝步驟
3.1 關閉系統(tǒng)的大頁
echo never > /sys/kernel/mm/transparent_hugepage/enabled
echo never > /sys/kernel/mm/transparent_hugepage/defrag
echo never > /sys/kernel/mm/redhat_transparent_hugepage/enabled
echo never > /sys/kernel/mm/redhat_transparent_hugepage/defrag
3.2 禁用SELINUX
root@rac2:~# >vim /etc/selinux/config 設置SELINUX=disabled
root@rac2:~# >setenforce 0
root@rac2:~# >getenforce
undefined3.3 利用percona 的yum 源進行安裝
yum install http://www.percona.com/downloads/percona-release/redhat/0.1-3/percona-release-0.1-3.noarch.rpm
yum list | grep percona #檢查yum源里面是否有 tokudb相關的rpm包
yum install Percona-Server-tokudb-56.x86_64 -y
3.4 初始化數(shù)據(jù)庫實例并啟動數(shù)據(jù)庫
/usr/bin/mysql_install_db --user=mysql --datadir=/srv/my3306/data --basedir=/usr/ --defaults-file=/srv/my3306/my.cnf &
/usr/bin/mysqld_safe --defaults-file=/srv/my3306/my.cnf --user=mysql &
3.5 使用ps_tokudb_admin安裝tokudb 存儲引擎 ,記得實例必須是啟動狀態(tài)的。
root@rac2:/srv/my3306/data# >ps_tokudb_admin --enable -uroot -h227.0.0.1 -P 3306
Checking SELinux status...
INFO: SELinux is in permissive mode.
Checking if Percona Server is running with jemalloc enabled...
INFO: Percona Server is running with jemalloc enabled.
Checking transparent huge pages status on the system...
INFO: Transparent huge pages are currently disabled on the system.
Checking if thp-setting=never option is already set in config file...
INFO: Option thp-setting=never is not set in the config file.
(needed only if THP is not disabled permanently on the system)
Checking TokuDB engine plugin status...
INFO: TokuDB engine plugin is not installed.
Adding thp-setting=never option into /etc/my.cnf
INFO: Successfully added thp-setting=never option into /etc/my.cnf
Installing TokuDB engine...
INFO: Successfully installed TokuDB engine plugin.--> 說明Tokudb 存儲引擎插件安裝成功
3.6 登陸實例進行檢查
root@rac2:/srv/my3306/data# >my 3306
Server version: 5.6.31-77.0-log Percona Server (GPL), Release 77.0, Revision 5c1061c
mysql> show engines;
+---------+---------+--------------------------------------------------------------+--------------+------+------------+
| Engine | Support | Comment | Transactions | XA | Savepoints
+---------+---------+--------------------------------------------------------------+--------------+------+------------+
| TokuDB | YES | Percona TokuDB Storage Engine with Fractal Tree(tm) Technology| YES | YES | YES |
+---------+---------+---------------------------------------------------------------+-------------+------+------------+
10 rows in set (0.02 sec)
mysql> SELECT @@tokudb_version;
+------------------+
| @@tokudb_version |
+------------------+
| 5.6.31-77.0 |
+------------------+
1 row in set (0.00 sec)
四 測試
4.1 壓縮比例
創(chuàng)建innodb 和tokudb存儲引擎的表,測試插入 和文件大小。
mysql> create table t_tokudb (id int,val varchar(256)) engine=tokudb default charset utf8;
Query OK, 0 rows affected (0.05 sec)
mysql> insert into t_tokudb(val) select val from t_tokudb;
Query OK, 262144 rows affected (2.32 sec)
Records: 262144 Duplicates: 0 Warnings: 0
mysql> CREATE TABLE `t_innodb` (
-> `id` int(11) DEFAULT NULL,
-> `val` varchar(256) DEFAULT NULL
-> ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
Query OK, 0 rows affected (0.13 sec)
mysql> insert into t_innodb select * from t_tokudb;
Query OK, 1048576 rows affected (10.40 sec)
Records: 1048576 Duplicates: 0 Warnings: 0
查看innodb 表和tokudb 表的大小
root@rac2:/srv/my3306/data# >du -sm _yang_t_tokudb_main_5_2_1d.tokudb
8_yang_t_tokudb_main_5_2_1d.tokudb
root@rac2:/srv/my3306/data/yang# >du -sm t_innodb.ibd
149t_innodb.ibd
root@rac2:/srv/my3306/data/yang# >
innodb 149M
tokudb 8M
壓縮比達到驚人的 149/8 = 18:1. 因為測試例子中val 的值都是相同的,生產(chǎn)環(huán)境中val值不相同的會比較多,壓縮比會有所減小。
4.2 存儲引擎轉(zhuǎn)換
mysql> show create table t1 \G
*************************** 1. row ***************************
Table: t1
Create Table: CREATE TABLE `t1` (
`id` int(10) NOT NULL AUTO_INCREMENT,
`val` varchar(10) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8
1 row in set (0.01 sec)
mysql> alter table t1 engine=tokudb;
Query OK, 4 rows affected (0.25 sec)
Records: 4 Duplicates: 0 Warnings: 0
4.3 online ddl 測試
mysql> alter table t_tokudb add name varchar(30) default 'a';
Query OK, 0 rows affected (0.06 sec)
Records: 0 Duplicates: 0 Warnings: 0
mysql> alter table t_tokudb add key idx_a(name);
Query OK, 0 rows affected (4.79 sec)
Records: 0 Duplicates: 0 Warnings: 0
mysql> alter table t_tokudb drop key idx_a;
Query OK, 0 rows affected (0.57 sec)
Records: 0 Duplicates: 0 Warnings: 0
五 TokuDB 總結(jié)
TokuDB特點
1 高壓縮比,默認使用zlib進行壓縮,尤其是對字符串(varchar,text等)類型有非常高的壓縮比,比較適合存儲日志、原始數(shù)據(jù)等。一般有5-10倍壓縮比。
2 支持在線字段增加、刪除、擴展、重命名操作。
3 支持完整的ACID特性和事務機制
4 支持快速的寫入場景,F(xiàn)ractal-tree在事務實現(xiàn)上有優(yōu)勢,無undo log
TokuDB缺點
1,響應時間相對較長
2,online ddl 對text,blob等類型的字段不適用
3,沒有完善的熱備工具,目前有阿里云數(shù)據(jù)庫團隊推薦的備份方案和邏輯備份
建議適用場景:
1 訪問頻率不高的數(shù)據(jù)或歷史數(shù)據(jù)歸檔
2 表非常大并且時不時還需要進行ddl操作
TokuDB的壓縮算法如何選擇
tokudb_zlib:表啟用zlib壓縮,壓縮效果偏中,CPU消耗偏中,建議使用(默認);
tokudb_quicklz:表啟用quicklz壓縮,壓縮效果差,CPU消耗低;
tokudb_lzma:表啟用lzma壓縮,壓縮效果好,CPU消耗高。
TokuDB默認壓縮算法為zlib,建議您不要做修改,因為zlib壓縮的性價比非常高。
看完上述內(nèi)容,你們掌握如何進行Tokudb安裝測試的方法了嗎?如果還想學到更多技能或想了解更多相關內(nèi)容,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!