微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

我正在尝试使用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文件夹,如何知道该文件夹?

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

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

然后一切正常!!!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐