Я нашел способ исправить это:
Прежде всего нам нужно установить 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
тогда все работает !!!