MYSQL教程老生常谈mysql event事件调度器(必看篇)

MYSQL教程老生常谈mysql event事件调度器(必看篇),第1张

概述介绍《MYSQL教程老生常谈mysql event事件调度器(必看篇)》开发教程,希望对您有用。

《MysqL教程老生常谈MysqL event事件调度器(必看篇)》要点:
本文介绍了MysqL教程老生常谈MysqL event事件调度器(必看篇),希望对您有用。如果有疑问,可以联系我们。

MysqL必读概述

MysqL必读MysqL也有自己的事件调度器,简单地可以理解为linux的crontab job,不过对于sql应用来说,它的功能更齐全,也更易于维护.个人感觉如果数量创建太多的话,也可能影响DB性能,且不易调试.

MysqL必读MysqL事件调度器的主要内容

MysqL必读总开关

MysqL必读参数event_scheduler为事件调度器的总开关,一般来说设置为ON或者OFF就好,不建议设置成Disabled,如果设置为ON,show processList可看到该线程

MysqL必读


MysqL必读创建,修改,查看等语法

MysqL必读关于如何创建,修改event这里不做叙述,创建语法如下,具体的含义可参考下面关于event信息表介绍.也可以参考官网文档链接,http://dev.MysqL.com/doc/refman/5.6/en/create-event.HTML

MysqL必读


MysqL必读查看创建好的event,在进入当前db后,show create event xxx\G

MysqL必读


MysqL必读
event的信息查询和含义

MysqL必读查看某个event的状态信息,可查看MysqL.event或者information_schema.events,或者简单地切到当前DB后执行show events; 三者的内容基本一致,information_schema无法做了下数据复制,更改了下列名称和starts时间以便更好的阅读.这里已information_schema.events里的信息为例解释

MysqL必读


MysqL必读EVENT_CATALOG:一般都是def,不管

MysqL必读EVENT_SCHEMA:event所在的schema

MysqL必读EVENT_name:event的名称

MysqL必读defineR:event的定义者,和定义这个event时,默认selectcurrent_user()的结果一致,如果该user有super权限,可以指定为其他用户

MysqL必读TIME_ZONE:event使用的时区,默认是system,建议别做修改

MysqL必读EVENT_BODY:一般都是sql,不用管

MysqL必读EVENT_DEFinitioN:该event的内容,可以是具体的insert等sql,也可以是一个调用存储过程的 *** 作

MysqL必读EVENT_TYPE:这个参数比较重要,定义的时候指定,有两个值:RECURRING和ONE TIME,RECURRING表示只要符合条件就会重复执行,而ONE TIME只会调用一次

MysqL必读EXECUTE_AT: 针对one-time类型的event有效,如果是RECURRING类型的event一般为NulL,表示该event的预计执行时间

MysqL必读INTERVAL_VALUE:针对RECURRING类型的event有效,表示执行间隔长度

MysqL必读INTERVAL_FIELD:针对RECURRING类型的event有效,表示执行间隔的单位,一般是SECOND,DAY等值,可参考创建语法

MysqL必读sql_mode:当前event采用的sql_mode

MysqL必读STARTS:针对RECURRING类型的event有效,表示一个event从哪个时间点点开始执行,和one-time的EXECUTE_AT功能类似.为NulL表示一符合条件就开始执行

MysqL必读ENDS:针对RECURRING类型的event有效,表示一个event到了哪个时间点后不再执行,如果为NulL就是永不停止

MysqL必读STATUS:一般有三个值,ENABLED,Disabled和 SLAVESIDE_Disabled,其中ENABLED表示激活这个event,该event只要符合其他条件就会执行;Disabled状态改event将不会执行,SLAVESIDE_Disabled表示在从库上不执行该event.需要特别注意在从库上不要执行任何形式的event,因为如果主库执行一次,复制到从库后,从库再执行一次的话,那就数据不一致了,一般来说直接禁用掉从库上的总开关event_scheduler就行.

MysqL必读ON_COMPLETION:只有两种值,PRESERVE和NOT PRESERVE,PRESERVE

MysqL必读CREATED:event的创建时间

MysqL必读LAST_ALTERED:event最新一次被修改的时间

MysqL必读LAST_EXECUTED:event最近一次执行的时间,如果为NulL表示从未执行过

MysqL必读EVENT_COMMENT:event的注释信息

MysqL必读ORIGINATOR:当前event创建时的server-ID,用于主从上的处理,比如SLAVESIDE_Disabled

MysqL必读CHaraCTER_SET_CLIENT:event创建时的客户端字符集,即character_set_clIEnt

MysqL必读ColLATION_CONNECTION:event创建时的连接字符校验规则,即collation_connection

MysqL必读DATABASE_ColLATION:event创建时的数据库字符集校验规则

MysqL必读EVENT的权限管理

MysqL必读1 设置event_scheduler系统变量,需要super_priv权限

MysqL必读2 创建,修改和删除event需要该user用户EVENT权限,该权限是schema级别的

MysqL必读3 对应于event的具体内容,需要对应的权限.比如event里有对某张表的insert *** 作,那么该user需要对该表的insert *** 作,不然LAST_EXECUTED一直会是NulL

MysqL必读EVENT的状态查询

MysqL必读通过以下命令查看DB启动以来的event的相关信息统计

MysqL必读MysqL> showglobal status like '%event%';

MysqL必读+--------------------------+-------+

MysqL必读|Variable_name | Value |

MysqL必读+--------------------------+-------+

MysqL必读|Com_alter_event | 0 |

MysqL必读|Com_create_event | 2 |

MysqL必读|Com_drop_event | 2 |

MysqL必读|Com_show_binlog_events | 0 |

MysqL必读|Com_show_create_event | 191 |

MysqL必读|Com_show_events | 40 |

MysqL必读|Com_show_relaylog_events | 0 |

MysqL必读+--------------------------+-------+

MysqL必读7 rows in set(0.00 sec)

MysqL必读使用建议

MysqL必读1 如果主库已经执行过,从库上务必要保证event不会执行(除非故意在slave上创建的event)

MysqL必读2 创建,删除等 *** 作严禁直接 *** 作MysqL.event表,而是通过create等正规语法实现,不然会导致元数据混乱,各种莫名其妙的问题随之产生,比如event不执行或者重复执行.这时一般只有重启DB才能解决 了.

MysqL必读3 创建的event涉及到海量数据变更的话,要做好充分测试,确保不影响现网服务

MysqL必读4 如果需要备份带有event的DB,MysqLdump时需要加上--event参数

MysqL必读以上这篇老生常谈MysqL event事件调度器(必看篇)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持内存溢出PHP.

总结

以上是内存溢出为你收集整理的MYSQL教程老生常谈mysql event事件调度器(必看篇)全部内容,希望文章能够帮你解决MYSQL教程老生常谈mysql event事件调度器(必看篇)所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1162630.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存