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

我找到了一种解决方法:

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

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

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

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

然后一切正常!!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值