多实例的mysql 怎么自动开启event 现在event_scheduler 是DISABLED

多实例的mysql 怎么自动开启event 现在event_scheduler 是DISABLED,第1张

我的mysql装在linux上,今天也出现了这种问题,报的错为:ERROR 1290 (HY000): The MySQL server is running with the --skip-grant-tables option so it cannot execute this statementlinux下需要找到my.cnf文件,看配置中是否有skip-grant-tables 这一行,需要注释掉。然后进入命令行输入:set global event_scheduler =on或者set global event_scheduler =1都可以。Windows下的话应该是需要找到my.ini文件,之后的 *** 作和上面一样。至于skip-grant-tables的意思,百度吧。里面有详细的讲解。skip-grant-tables作用是跳过验证,有了这个其实你可以把之前的忘记的密码修改掉。 步骤1、在命令窗登录mysql。切换库为mysql库。2、update user set password=PASSWORD('newpswd')WHERE user='root'3、flush privileges4、退出命令窗重启mysql服务,在使用修改时候的密码登录一下看看如果成功登录,应该就可以设置event事件任务了

在File ->New Query Tab中通过以下SQL可以创建

create event my_event on schedule every 1 minute do select now()

workbench的schemas窗格中看不到event, 可以在窗口中查询information_schema.event看到已经创建的event

select * from information_schema.events

如果已经知道event的名称的话, 也可以在窗口中适用show create event查看:

show create event my_event

另外, 5.6的版本默认不打开调度器, 通过查询mysql全局变量看是否开启, 同样在workbench中执行

show variables like '%event_scheduler%'

如果看到关闭状态: 

event_scheduler    OFF

可以在workbench中直接执行

set global event_scheduler=1

临时打开调度器(重启mysqld服务失效), 重启生效需要修改my.cnf配置, 在[mysqld]下打开

event_scheduler = 1

如果是event已经创建, scheduler也已经打开却没有效果, 可以在mysql的error log(在my.cnf中配置log-error项, 默认在mysql的data文件夹中)中查查是否有错误, 可能导致event没有按预期执行

首先在sql中查询计划事件的状态:SHOW VARIABLES LIKE 'event_scheduler'

如果返回的是off表示当前是关闭状态,如果是on当前已经开启了计划任务。

在mysql程序的目录下找到my.ini文件,添加一个项:event_scheduler = 1

保存后重启mysql服务即可,重启服务可以在服务管理里面找到

也可以用脚本来实现:

mysql event_scheduler

开启event_scheduler sql指令:

SET GLOBAL event_scheduler = ON

SET @@global.event_scheduler = ON

SET GLOBAL event_scheduler = 1

SET @@global.event_scheduler = 1

相反,关闭event_scheduler指令:

SET GLOBAL event_scheduler = OFF

SET @@global.event_scheduler = OFF

SET GLOBAL event_scheduler = 0

SET @@global.event_scheduler = 0


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

原文地址: http://outofmemory.cn/zaji/8529858.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-17
下一篇 2023-04-17

发表评论

登录后才能评论

评论列表(0条)

保存