gpt4 book ai didi

Mysql sys_exec 无法打开共享库 'lib_mysqludf_sys.so' (errno : 11, wrong ELF class: ELFCLASS32)

转载 作者:可可西里 更新时间:2023-11-01 08:23:32 27 4
gpt4 key购买 nike

我正在尝试使用 sys_exec 在 unix 上运行 native 命令,但我已尝试将插件从 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. -shared 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/

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

然后一切正常!!!

关于Mysql sys_exec 无法打开共享库 'lib_mysqludf_sys.so' (errno : 11, wrong ELF class: ELFCLASS32),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55241615/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com