阿里云
双11技术峰会
发表主题 回复主题
  • 1269阅读
  • 1回复

[教程]Ubuntu 下 MariaDB 安装 TokuDB 并设为默认引擎

级别: 论坛版主
发帖
9237
云币
13486
— 本帖被 不靠谱贝贝 设置为精华(2017-07-28) —
)>,b>7  
ZNPzQ:I@  
介绍 vCwDE~  
uPe4Rr  
TokuDB 是非常有效的数据库引擎,在阿里、腾讯均有广泛的运用,MySQL 的变种 Percona Server 和 AliSQL 均推荐启用 TokuDB 并作为默认引擎。其以优异的压缩性能和储存表现,被广泛的应用,颇有代替 InnoDB 之势。 6wzF6] @O  
WordPress 是没有外键的,因此可以完美的使用 TokuDB,使用其优秀特性。这里将介绍的是 MariaDB 如何开启 TokuDB 功能。 Yfy6o6*:  
U'LO;s04m  
~c!zTe  
安装 MariaDB 教程请看:Ubuntu 安装 MariaDB Server @M4~,O6-  
vII&v+C  
教程 *Kt7"J  
h~elF1dG  
.Gl&K|/{j  
关闭 THP :^kP?  
,$3  
u0$7k9mE  
THP(Transparent Huge Pages) 在有数据库服务(Mysql、Redis、MongoDB)的机器上都是建议关闭的 不然总会发生莫名其妙的事情,TokuDB 也是一定要关闭的。 8{Y ?;~G  
在 /etc/rc.local 加入如下语句,这样就算重启系统也会动关闭 THP "}K/ b  
6f=/vRAh$  
;JFE7\-mC  
  1. echo never > /sys/kernel/mm/transparent_hugepage/enabled
  2. echo never > /sys/kernel/mm/transparent_hugepage/defrag
:=~%&  
"<6pp4*I  
安装 TokuDB d^ !3bv*h  
!N,Z3p>Q  
  1. apt install mariadb-plugin-tokudb
!U>"H8}dv  
}p t5.'l  
对,就这么简单,自动安装好 tokudb 引擎,如果没有安装 jemalloc 还会自动安装,还会自动生成 /etc/mysql/mariadb.conf.d/tokudb.cnf 文件,真的很贴心~ -7ct+3"J  
重启 MariaDB
  1. systemctl restart mysql
zx-+u7qKH  
Dr`\  
设为默认引擎 T<54qe4`p  
n{BC m %  
o9wg<LP  
使用下面命令,登入数据库,查看可用引擎: jT: :o  
Ef,@}S  
  1. mysql -u root -p  #下面要输入你的密码
  2. MariaDB [(none)]> show engines;
v/+dx/  
*`}_e)(k  
在中间可以看到这条,不过还不是默认引擎,默认引擎是 InnoDB (dMFYL>YP  
)SA$hwR  
  1. | TokuDB             | YES     | Percona TokuDB Storage Engine with Fractal Tree(tm) Technology                   | YES          | YES  | YES        |
T]^F%D%  
k|A!5A2  
输入设为默认引擎: sxThz7#i)  
)lw7 W9  
  1. SET storage_engine=TokuDB;
WKah$l  
{+xUAmd  
然后输入 quit; 退出。 HAO/r`7*  
_D,8`na>K  
e982IP  
注: 这是临时设置为默认引擎的,重启数据库之后就继续变成默认 InnoDB,因为有些程序还是不支持 TokuDB的,通过这时候创建的数据表并不会退回到 InnoDB 而是继续是 TokuDB。 9Biw!%a  
[ 此帖被妙正灰在2017-07-28 11:49重新编辑 ]
本帖最近评分记录: 1 条评分 云币 +1
魔咒626 云币 +1 优秀文章-欢迎进行技术分享,感谢你的支持! 07-29
级别: 论坛版主
发帖
1839
云币
3577
只看该作者 沙发  发表于: 07-29
优秀文章-欢迎进行技术分享,感谢你的支持!
发表主题 回复主题
« 返回列表上一主题下一主题

限100 字节
批量上传需要先选择文件,再选择上传
 
验证问题: 阿里云官网域名是什么? 正确答案:www.aliyun.com
上一个 下一个