MySQL sys_exec无法打开共享库'lib_mysqludf_sys.so(错误号:11,错误ELF类:ELFCLASS32) [英] Mysql sys_exec Can't open shared library 'lib_mysqludf_sys.so' (errno: 11, wrong ELF class: ELFCLASS32)

查看:0
本文介绍了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#,但当我尝试运行下面的命令时:

create function sys_exec returns int soname 'lib_mysqludf_sys.so';

我收到此回复:

ERROR 1126 (HY000): Can't open shared library 'lib_mysqludf_sys.so' (errno: 11, wrong ELF class: 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. -shared lib_mysqludf_sys.c -o lib_mysqludf_sys.so

然后复制lib_mysqludf_sys.so到MariaDB/MySQL插件文件夹,怎么知道是哪个文件夹?

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/

之后,我们可以创建触发器并运行在我们自己的操作系统上运行所需的一切: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更改为TESTS

chown -R mysql.mysql /tmp

然后一切正常!

这篇关于MySQL sys_exec无法打开共享库'lib_mysqludf_sys.so(错误号:11,错误ELF类:ELFCLASS32)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆