memcached 与 mysql_Memcached and MySQL

秦滨海
2023-12-01

相信很多开发人员接触过memcached,而且我认识的朋友当中有的是经常使用。那么在结合数据库,在对数据库内容做缓存的时候什么情况下使用memcached却不甚了解。有些朋友问到MySQL有自己的Query cache,为什么还要用memcached? –by ivan@mysqlab.net

MySQL为了效率考虑,不太可能将数据粒度分那么细,所以在对表更新的时候将清空所有涉及到这张表的qcache,这样的话,在更新频繁或者表记录数很大的情况,qcache的效率将大打折扣。而使用memcached一般都是针对单挑记录,从而在更新的时候对表中其他记录的cache没有影响,相比qcache来说,cache效率极大提高。这也是为什么在MySQL有Query cache的情况下还要使用memcache来缓存数据。

不过结合MySQL和memcached使用需要app层配合。不过当前也有MySQL memcached UDFs,结合MySQL触发器trigger,可是实现MySQL数据库的内容跟memcached同步,这样可以避免不同的应用程序需要实现对memcached的管理。

shell> tar zxf memcached_functions_mysql-x.xx.tar.gz

shell> cd memcached_functions_mysql-x.xx

shell> ./configure –with-mysql=/usr/local/mysql/bin/mysql_config

shell> make

shell> make install

shell> cp /usr/local/lib/libmemcached_functions_mysql* /usr/local/mysql/lib/mysql/plugins/

mysql> CREATE FUNCTION memc_get RETURNS STRING SONAME "libmemcached_functions_mysql.so";

mysql> source /path/TO/install_functions.sql

Related posts:

 类似资料: