[MySQL TroubleShooting] 服务启动报错

时间:2022-05-02 17:30:39

有个朋友发了一段启动错误的stack,当启动Skip_Grant_Table就不报错:

群里的大神找出来了因为udf_initv这个自定义函数报错。

[MySQL TroubleShooting] 服务启动报错

 

但是一直想不通为啥服务启动要去运行自定义函数呢?

mysqld_main里面有一段代码:

  if (!opt_noacl)
{
#ifdef HAVE_DLOPEN
udf_init();
#endif
}

 其中opt_noacl就是参数skip_grant_table,如果没有设置opt_noacl=1 否则为0 ,所以没有设置skip_grant_table,那么就会进入udf_init然后去初始化自定义函数,如果自定义函数有问题,导致服务无法启动。