Mysql sys_exec无法打开共享库’lib_mysqludf_sys.so'(错误号:11,错误的ELF类:ELFCLASS32)

Mysql sys_exec无法打开共享库’lib_mysqludf_sys.so'(错误号:11,错误的ELF类:ELFCLASS32),第1张

概述我正在尝试使用sys_exec在Unix上运行本机命令,但是我尝试将插件从https://github.com/mysqludf/lib_mysqludf_sys开始进入/usr/lib / x86_64-linux-gnu / mariadb18 / plugin#,但是当我尝试在下面运行此命令时:创建函数sys_exec返回int soname'lib_

我正在尝试使用sys_exec在Unix上运行本机命令,但是我尝试将插件从https://github.com/mysqludf/lib_mysqludf_sys开始

进入/usr/lib / x86_64-linux-gnu / mariadb18 / plugin#,但是当我尝试在下面运行此命令时:

创建函数sys_exec返回int soname’lib_MysqLudf_sys.so’;

我收到此回复:

错误1126(HY000):无法打开共享库’lib_MysqLudf_sys.so'(错误号:11,错误的ELF类:ELFCLASS32)

是MariaDB 15.1.

最佳答案我找到了一种解决方法:

首先,我们需要在unix上安装default-libMysqLclIEnt-dev

运行命令:apt-get install default-libMysqLclIEnt-dev

然后从以下位置下载资源库:https://github.com/mysqludf/lib_mysqludf_sys

下载完成后,我们可以运行以下命令:

gcc -DMysqL_DYNAMIC_PLUGIN -fPIC -Wall -m64 -I /usr/include / MysqL -I. -共享的lib_MysqLudf_sys.c -o lib_MysqLudf_sys.so

然后将lib_MysqLudf_sys.so复制到MariaDB / MysqL plugins文件夹,如何知道该文件夹?

@H_502_32@MariaDB [(none)]> SHOW VARIABLES liKE 'plugin_dir';+---------------+---------------------------------------------+| Variable_name | Value |+---------------+---------------------------------------------+| plugin_dir | /usr/lib/x86_64-linux-gnu/mariadb18/plugin/ |+---------------+---------------------------------------------+1 row in set (0.00 sec)

就我而言,我的命令应该是:

cp lib_MysqLudf_sys.so /usr/lib / x86_64-linux-gnu / mariadb18 / plugin /

之后,我们可以创建触发器并运行我们需要在自己的OS上运行的所有东西:D

@H_502_32@CREATE table `trig_test` ( `ID` int(11) NOT NulL auto_INCREMENT,`random_data` varchar(255) NOT NulL,PRIMARY KEY (`ID`));DEliMITER @@CREATE TRIGGER trig_test AFTER INSERT ON `trig_test`FOR EACH ROW BEGIN DECLARE cmd CHAR(255); DECLARE result int; SET cmd=CONCAT('node /tmp/script/script.Js >> /tmp/script/result.txt'); SET result = sys_exec(cmd);END;@@DEliMITER ;INSERT INTO trig_test(random_data)VALUES('GOOOO!!!');

如果您无法运行检查权限所需的命令,我将所有者和组从/ tmp更改为测试

chown -R MysqL.MysqL / tmp

然后一切正常!!!

总结

以上是内存溢出为你收集整理的Mysql sys_exec无法打开共享库’lib_mysqludf_sys.so'(错误号:11,错误的ELF类:ELFCLASS32) 全部内容,希望文章能够帮你解决Mysql sys_exec无法打开共享库’lib_mysqludf_sys.so'(错误号:11,错误的ELF类:ELFCLASS32) 所遇到的程序开发问题。

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

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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存