[MySQL TroubleShooting] 服务启动报错

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

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

[MySQL TroubleShooting] 服务启动报错_第1张图片

 

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

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然后去初始化自定义函数,如果自定义函数有问题,导致服务无法启动。

你可能感兴趣的:([MySQL TroubleShooting] 服务启动报错)