Mysql sys_exec Не удается открыть общую библиотеку 'lib_mysqludf_sys.so' (номер ошибки: 11, неправильный класс ELF: ELFCLASS32) - PullRequest
3 голосов
/ 19 марта 2019

Я пытаюсь использовать 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.

1 Ответ

2 голосов
/ 19 марта 2019

Я нашел способ исправить это:

Прежде всего нам нужно установить default-libmysqlclient-dev на Unix

Запустить команду: 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 натесты

chown -R mysql.mysql /tmp

тогда все работает !!!

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...