3 votes

Mysql sys_exec Impossible d'ouvrir la bibliothèque partagée 'lib_mysqludf_sys.so' (errno : 11, mauvaise classe ELF : ELFCLASS32)

J'essaie d'utiliser sys_exec pour exécuter une commande native sur unix, mais j'ai essayé de mettre le plugin de https://github.com/mysqludf/lib_mysqludf_sys

Dans le /usr/lib/x86_64-linux-gnu/mariadb18/plugin# mais quand j'essaie d'exécuter cette commande ci-dessous :

create function sys_exec returns int soname 'lib_mysqludf_sys.so';

Je reçois cette réponse :

ERROR 1126 (HY000): Can't open shared library 'lib_mysqludf_sys.so' (errno: 11, wrong ELF class: ELFCLASS32)

Il s'agit de MariaDB 15.1.

6voto

Oracy Martos Points 400

J'ai trouvé un moyen d'arranger ça :

Tout d'abord, nous devons installer default-libmysqlclient-dev sur unix

Exécutez la commande : apt-get install default-libmysqlclient-dev

Ensuite, téléchargez le référentiel à partir de : https://github.com/mysqludf/lib_mysqludf_sys

Après le téléchargement terminé, nous pouvons exécuter cette commande :

gcc -DMYSQL_DYNAMIC_PLUGIN -fPIC -Wall -m64 -I/usr/include/mysql -I. -shared lib_mysqludf_sys.c -o lib_mysqludf_sys.so

Puis copier lib_mysqludf_sys.so vers le dossier des plugins MariaDB/MySQL, comment savoir quel est ce dossier ?

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)

Dans mon cas, ma commande devrait être :

cp lib_mysqludf_sys.so /usr/lib/x86_64-linux-gnu/mariadb18/plugin/

Après cela, nous pouvons créer notre déclencheur et exécuter tout ce dont nous avons besoin sur notre propre 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!!!');

Si vous ne pouvez pas exécuter les commandes, vous devez vérifier les permissions, j'ai changé mon propriétaire et mon groupe de /tmp à tests.

chown -R mysql.mysql /tmp

Ensuite, tout fonctionne ! !!

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X