您好,欢迎访问一九零五行业门户网

MySQL NoSQL – Memcached 插件

大多数人都已经听说 nosql 数据库,其中使用最广泛的工具是 memcached,你们通过 memcached 再应用层和数据库之间添加一个缓存层
大多数人都已经听说 nosql 数据库,其中使用最广泛的工具是 memcached,你们通过 memcached 再应用层和数据库之间添加一个缓存层。从 mysql 5.6 开始,你可以获得一个全新的插件,这个插件把 mysql 和 memcached 集成起来。在此文中,我们将学习怎样在 linux 中 安装这个插件,怎样做一些基础的配置。
先决条件安装 libevent。
译者注:以下命令由译者提供。
命令如下:
译者注:我的操作系统版本是 rhel 6.5,而作者的 os 版本为 centos。以下是我的 mysql 版本。
安装安装 memcached 支持,我们需要创建一些为 mysql 和 memcached 集成服务的表。mysql 已经包含了创建这些表的文件(innodb_memcached_config.sql),你可以在你的 basedir 子目录中找到这个文件。为了找到你的 basedir 在什么地方,运行如下命令:
如果你通过发行版仓库安装 mysql,这个文件的路径如下:$basedir/share/mysql/innodb_memcached_config.sql
如果你使用 mysql 二进制版本,这个文件的路径如下:$basedir/share/innodb_memcached_config.sql
现在,我们将运行这个 sql 文件。默认情况下,这个脚本在 test 数据库中创建一个 test 表,但是在我们的测试中,我们将使用 memcached 数据库。
译者注:操作日志中的时间可能跟原文不同,以下日志来自自己的实验。
现在,让我们创建我们自己的表,用于存放 memcached 数据:
下一步是在 mysql 中安装 memcached 插件。为了实现这个功能,我们将会使用install plugin 命令:
验证此插件是否成功安装,我们可以运行如下命令:
配置和使用现在,,我们将会通过一种编程语言——php,比如使用这种方式:
译者注:原文是 new memcached(),此处改为 new memcache(),以下的 php 脚本均为 new memcache()。
现在,让我们看看在 mysql 中存储了些什么?
如果我们在 mysql 中手动更改一个记录,会发生什么?
如果我们想存放条目到不同的 mysql 表,那么又会怎样?
我们仅仅需要创建一个新的表,添加一个新的容器,并且使用在 innodb_memcache 数据库的 config_options 表定义的分隔符。
我们已经创建一个名为 dados2 的新表,并且添加了一个新的名为 bbb 的容器指向那个表,现在我们仅仅需要在 memcached 中使用它作为前缀即可。
我们也可以映射这个表,将存储的值分为单独的域。
我们将会使用这个字符来把值存储到不同的列中。让我们创建一个表,添加到一个新的容器中(我们将会指定新的分隔符——逗号’,’,来存放我们的数据):
现在,让我们创建一个产品数组,然后添加这些数据到 memcached 中。
服务器/服务 重启让我们看看如果我们重启 mysql 服务(重启服务器通用适用)会发生什么?
这些存储在 memcached 中的数据在 mysql 服务重启之后仍然会存在吗?
换句话说!即使服务重启或者服务器重启,这些数据仍然会存在。
selinux在 selinux 启用的环境中,会阻止 memcached 和 mysql 集成,因为不允许监听 memcached 端口,下面是一个怎样允许监听 memcached 端口的例子(我使用 centos linux 分发版):
在 /var/log/audit/audit.log 中查找包含 mysqld 和 denied 关键字的条目,如果你能找到,输入如下的命令来创建一个新的 selinux 模块来允许:
译者注:以下为译者添加,用于测试在 selinux 环境下,mysql 和 memcached 的集成。
memcached 选项如果你想更改任何 memcached 特殊的选项,你可以在 mysql 的配置文件中添加daemon_memcached_option 参数,比如更改 memcached 端口:
# in the configuration file, my.cnf generally就是这样,我希望你已经学会了如何安装和配置 mysql 和 memcached 插件的集成工作。
本文永久更新链接地址:
其它类似信息

推荐信息