本文介紹了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)的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,