本节介绍在使用时可能遇到的问题InnoDB
memcached插件。
如果MySQL错误日志中出现如下错误,可能导致服务器启动失败:
为打开的文件设置rlimit失败。尝试以root用户身份运行或请求较小的maxconns值。
错误消息来自memcached守护进程。一种解决方案是提高操作系统对打开文件数量的限制。检查和增加打开文件限制的命令因操作系统不同而不同。这个例子展示了Linux和macOS的命令:
# macOS shell> ulimit -n 256 shell> ulimit -n 4096 shell> ulimit -n 4096
另一种解决方案是减少允许的并发连接数量memcached守护进程。为此,对
- c
memcached选项daemon_memcached_option
MySQL配置文件中的配置参数。的- c
选项的默认值为1024。(mysqld)……loose-daemon_memcached_option = ' 64 - c '
的位置进行故障排除memcachedDaemon无法存储或检索
InnoDB
表数据,编码-vvv
memcached选项daemon_memcached_option
MySQL配置文件中的配置参数。检查MySQL错误日志,查看与memcached操作。(mysqld)……loose-daemon_memcached_option = ' -vvv '
如果列指定保存memcached值是错误的数据类型,例如数值类型而不是字符串类型,存储键值对的尝试失败,没有特定的错误代码或消息。
如果
daemon_memcached
插件导致MySQL服务器启动问题,你可以暂时禁用daemon_memcached
在故障排除时添加此行(mysqld)
MySQL配置文件中的group:daemon_memcached =了
例如,如果您运行
安装插件
语句之前运行innodb_memcached_config.sql
配置脚本来设置必要的数据库和表,服务器可能意外退出并无法启动。控件中的项配置错误,也可能导致服务器无法启动innodb_memcache.containers
表格卸载了memcachedMySQL实例插件,发出如下语句:
mysql>卸载插件
如果在同一台机器上运行多个MySQL实例
daemon_memcached
在每个实例中启用的插件,使用daemon_memcached_option
配置参数来指定唯一的memcached端口为每个daemon_memcached
插件。如果SQL语句不能找到
InnoDB
表或发现表中没有数据,但是memcached的API调用检索预期的数据时,您可能会丢失一个条目InnoDB
表中innodb_memcache.containers
表,否则您可能没有切换到正确的InnoDB
通过发出得到
或集
请求使用@@
符号。控件中的现有条目也可能发生此问题table_id
innodb_memcache.containers
表,之后无需重新启动MySQL服务器。自由格式存储机制足够灵活,您的请求可以存储或检索多列值,例如col1 | col2 | col3
可能仍然工作,即使守护进程正在使用test.demo_test
在单个列中存储值的表。当你定义自己的时候
InnoDB
表,用于daemon_memcached
插件,表中的列定义为非空
,确保为非空
项中插入表记录时的innodb_memcache.containers
表格如果插入
声明的innodb_memcache.containers
记录包含的带分隔符的值比映射列要少,未填充的列被设置为零
.试图插入零
值到一个非空
列原因插入
失败,只有在重新初始化daemon_memcached
应用更改到innodb_memcache.containers
表格如果
cas_column
而且expire_time_column
的字段innodb_memcached.containers
表设置为零
,当试图加载memcached插件:InnoDB_Memcached:数据库innodb_memcache中配置表'containers'的第6列有一个无效的NULL值。
的memcached插件拒绝使用
零
在cas_column
而且expire_time_column
列。将这些列的值设置为0
当列未使用时。的长度memcached键和值增加时,可能会遇到大小和长度限制。
当密钥超过250字节时,memcached操作返回错误。这是目前一个固定的限制内memcached.
InnoDB
如果值的大小超过768字节、3072字节或一半,则可能会遇到表限制innodb_page_size
价值。如果您打算在值列上创建索引,以便使用SQL在该列上运行生成报告的查询,则主要适用于这些限制。看到第15.22节,“InnoDB限制”获取详细信息。键-值组合的最大大小为1mb。
如果您在不同版本的MySQL服务器之间共享配置文件,请使用最新的配置选项
daemon_memcached
在旧的MySQL版本上可能会导致启动错误。要避免兼容性问题,请使用宽松的
以选项名称作为前缀。例如,使用loose-daemon_memcached_option = ' 64 - c '
而不是daemon_memcached_option = ' 64 - c '
.不存在验证字符集设置的限制或检查。memcached以字节存储和检索键和值,因此对字符集不敏感。但是,您必须确保memcached客户端和MySQL表使用相同的字符集。
memcached连接无法访问包含索引虚拟列的表。访问索引的虚拟列需要回调到服务器,但是memcached连接无法访问服务器代码。