栏目导航:首页 > 网络编程 > Mysql > 内容 在线投稿

下一站:HandlerSocket!

目前使用MySQL的网站,多半同时使用Memcache作为键值缓存。虽然这样的架构极其流行,有众多成功的案例,但过于依赖Memcache,无形中让Memcache成为故障的根源: 本文转载自墨者资讯网 墨者资讯网

Memcache数据一致性的问题:当MySQL数据变化后,如果不能及时有效的清理掉过期的数据,就会造成数据不一致。这在强调即时性的Web2.0时代,不可取。

墨者资讯www.cnmoker.org

Memcache崩溃后的雪崩效应:作为缓存的Memcache一旦崩溃,MySQL很可能在短时间内承受高负载而宕机。据说前段时间新浪微博就遭遇了这样的问题。 cnmoker.org

注:关于清理过期数据的问题,可以在程序架构上想办法,如果数据操作有统一DAO封装的话,可以利用Observer模式来清理过期数据,非主题内容,资料自查。

本文来自墨者资讯

面对这些问题,HandlerSocket项目是个不错的解决方案,它通过插件的方式赋予MySQL完整的NoSQL功能,从原理上讲,它跳过MySQL中最耗时的语法解析,查询计划等步骤,直接读取数据,如果内存够大,能装下索引,MySQL的查询效率能提高若干倍! 墨者资讯www.cnmoker.org

性能测试实例:Using MySQL as a NoSQL – A story for exceeding 750,000 qps (GFW)

内容来自墨者资讯

因为HandlerSocket的性能足够好,所以就没有必要使用Memcache了,能节省大量的硬件资源,相当低碳!而且HandlerSocket操作的是MySQL放在内存中的索引,没有额外的缓存,所以自然就不存在数据一致性的问题。 本文来自墨者资讯

安装

cnmoker.org

如果使用Percona Server版本的MySQL就简单了,因为它已经内置了HandlerSocket支持,不过考虑到其内置的版本不够新,存在一些早已修复的BUG,所以最好采用源代码编译。

cnmoker.org

官方已经有了一份简单的安装文档,但在我实际安装时,遇到了一些其他未说明的问题,所以这里就把相应的安装过程再写一遍。

本文转载自墨者资讯网 墨者资讯网

首先要确保已经安装了MySQL5.1以上的版本,我用的是Ubuntu操作系统,事先已经用apt安装了MySQL5.1.37,同时还需要相应的mysql_config,如果是Ubuntu的话,可以: cnmoker.org

shell> aptitude install libmysqld-dev

本文转载自墨者资讯网 墨者资讯网

墨者资讯,最新资讯

注:如果你用的MySQL是从源代码编译的或官方提供的二进制版本,可以略过此步。 copyright cnmoker.orrg

接着下载一份和系统MySQL版本一致的MySQL源代码和HandlerSocket源代码: copyright cnmoker.orrg

mysql-5.1.37.tar.gz 墨者资讯www.cnmoker.org

ahiguti-HandlerSocket-Plugin-for-MySQL-1.0.6-76-gf5f7443.tar.gz

cnmoker.org

shell> tar zxf mysql-5.1.37.tar.gz
shell> tar zxf ahiguti-HandlerSocket-Plugin-for-MySQL-1.0.6-76-gf5f7443.tar.gz
shell> cd ahiguti-HandlerSocket-Plugin-for-MySQL-f5f7443
shell> ./autogen.sh
shell> ./configure --with-mysql-source=../mysql-5.1.37 \
                   --with-mysql-bindir=/usr/bin \
                   --with-mysql-plugindir=/usr/lib/mysql/plugin

内容来自墨者资讯

内容来自墨者资讯

其中的参数含义如下:with-mysql-source表示MySQL源代码目录,with-mysql-bindir表示MySQL二进制可执行文件目录(也就是mysql_config所在目录),with-mysql-plugindir表示MySQL插件目录,如果不清楚这个目录在哪,可以按如下方法查询: 内容来自墨者资讯

mysql> SHOW VARIABLES LIKE 'plugin%';
+---------------+-----------------------+
| Variable_name | Value                 |

来源:墨者资讯网-我们致力于做最全面的it资讯信息资料库
TAG: shell ID MySQL
评论 | 推荐 | 挑错 | 责编:admin | 时间: 2011-04-13
上一篇:MySQL复制的概述、安装、故障、技巧、工具 下一篇:MySQL数据库中CHAR与VARCHAR之争