10bet网址
MySQL 8.0参考手册
相关的文档10bet官方网站 本手册下载 本手册节选

15.20.9 InnoDB memcached插件故障处理

本节介绍在使用时可能遇到的问题InnoDBmemcached插件。

  • 如果MySQL错误日志中出现如下错误,可能导致服务器启动失败:

    为打开的文件设置rlimit失败。尝试以root用户身份运行或请求较小的maxconns值。

    错误消息来自memcached守护进程。一种解决方案是提高操作系统对打开文件数量的限制。检查和增加打开文件限制的命令因操作系统不同而不同。这个例子展示了Linux和macOS的命令:

    # macOS shell> ulimit -n 256 shell> ulimit -n 4096 shell> ulimit -n 4096

    另一种解决方案是减少允许的并发连接数量memcached守护进程。为此,对- cmemcached选项daemon_memcached_optionMySQL配置文件中的配置参数。的- c选项的默认值为1024。

    (mysqld)……loose-daemon_memcached_option = ' 64 - c '
  • 的位置进行故障排除memcachedDaemon无法存储或检索InnoDB表数据,编码-vvvmemcached选项daemon_memcached_optionMySQL配置文件中的配置参数。检查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连接无法访问服务器代码。