Blog

Bienvenue...

...sur mon blog, j'utilise ce site pour noter les petites choses qui me sont utiles, que ça soit informatique ou autre :)

Il y a 15 années 9 mois

Dans le cadre de la mise en place du site d'e-commerce d'une filiale, j'ai pu travailler sur la refonte des interfaces Java <-> Back Office.

En effet, actuellement, le site d'e-commerce de la filiale France communique avec l'ensemble des magasins. Le futur site internet de la Suisse communiquera de la même manière avec l'ensemble des magasins Suisses.

Ayant une bonne connaissance de l'existant pour la France, il était clair qu'une refonte était necessaire pour le futur site, ceci pour reprendre la main sur la maintenance des interfaces ainsi que pour garantir un meilleur niveau de performances. Compte tenu des enjeux du Web, une montée en puissance des flux temps rééls n'est pas à exclure. Il était donc impossible de partir sur les interfaces existantes...

Deux solutions ont été envisagées :

  1. Attaquer les programmes 4GL au travers de Java en utilisant JNI
  2. Trouver une autre solution en cas d'impossibilité... :)

J'ai donc commencé par la solution 1 (;), on trouve plein de tutos sur le net concernant JNI, en gros c'est super simple, il faut créer une méthode native qui sera le déclencheur de l'appel à la fonction C. Ensuite on appelle l'utilitaire javah sur la classe créée afin de générer le fichier prototype (.h) qui sera utilisé dans le programme C :

public class TestJNI {
   static {
     System.loadLibrary("testjni");
   }
   private native void helloWorld();
   private native void processMessage(String aMessageId);
   public static void main(String[] args) {
     new TestJNI().helloWorld();
     new TestJNI().processMessage("bidon");
   }
 }

Le fichier .h généré est de la forme :

/* DO NOT EDIT THIS FILE - it is machine generated */
#include <jni.h>
/* Header for class TestJNI */
 
#ifndef _Included_TestJNI
#define _Included_TestJNI
#ifdef __cplusplus
extern "C" {
#endif
/*
 * Class:     TestJNI
 * Method:    processMessage
 * Signature: (Ljava/lang/String;)V
 */
JNIEXPORT void JNICALL Java_TestJNI_processMessage
  (JNIEnv *, jobject, jstring);
 
/*
 * Class:     TestJNI
 * Method:    helloWorld
 * Signature: ()V
 */
JNIEXPORT void JNICALL Java_TestJNI_helloWorld
  (JNIEnv *, jobject);
 
#ifdef __cplusplus
}
#endif
#endif

Bon, donc voilà pour la partie Java, reste à développer un petit programme C qui implémente les deux fonctions :

/* testjni.c */
 
#include <jni.h>
#include "testjni.h"
#include <fglapi.h>
#include <fglsys.h>
 
JNIEXPORT void JNICALL Java_TestJNI_print
  (JNIEnv *env, jobject obj) {
    printf("COUCOU !!\n");
    return;
}
 
void appel4GL() {
    fgl_start();
 
    int1 res[80];
 
    printf("AVANT PUSH\n");
    ibm_lib4gl_pushQuotedStr(res, strlen(res));
 
    printf("AVANT get_server_today\n");
    fgl_call(get_server_today, 0);
 
    printf("AVANT POP\n");
    ibm_lib4gl_popQuotedStr(res, 80);
 
    printf("get_server_today: %s\n", res);
 
    free(res);
 
    fgl_end();
}
 
JNIEXPORT void JNICALL Java_TestJNI_processMessage
  (JNIEnv *env, jobject obj, jstring str) {
    /* Get the native string from str */
    const char *nativeString = (char *) GetStringUTFChars(env, str, 0);
    printf("ID message : %s\n", nativeString);
    /* DON'T FORGET THIS LINE!!! */
    ReleaseStringUTFChars(env, str, nativeString);
    appel4GL();
}
 
int main()
{
    printf("COUCOU !!\n");
    appel4GL();
    return 0;
}

Je vais tuer tout de suite le suspens inhérent à la mise en œuvre de tout ça, une fois que j'ai eu vaincu les directives de compilation et donc compilé mes petits programmes... ... ...Ça ne marche pas...

Chaque appel aux fonctions 4GL au travers de Java se solde par une erreur :

[oa@XRF4]  : java -Djava.compiler=NONE -Djava.library.path=$LIBPATH
COUCOU !!
ID message : bidon
Unhandled exception
Type=Illegal instruction vmState=0x00040000
J9Generic_Signal_Number=00000010 Signal_Number=00000004 Error_Value=00000000 Signal_Code=0000001e
Handler1=F10FF238 Handler2=F10FB064
R0=00000000 R1=2FF21300 R2=00000000 R3=2FF21340
R4=00000001 R5=F0FD85CC R6=00000000 R7=4D343000
R8=3430004D R9=00008000 R10=7F7F7F7F R11=00000003
R12=00000000 R13=30151900 R14=3017FBF8 R15=304A5A9C
R16=00000007 R17=00000000 R18=F1100F48 R19=30151940
R20=3047E260 R21=3017FC10 R22=00000000 R23=DEADBEEF
R24=1000F868 R25=30000330 R26=30151900 R27=300105A8
R28=EC065B50 R29=0000007E R30=00000001 R31=00000001
IAR=00000000 LR=D31B8BC0 MSR=0000D0B2 CTR=00000000
CR=22424284 FPSCR=82008000 XER=00000000 TID=00000000
MQ=DEADBEEF
FPR0 4a39524f4d434c41 (f: 1296256128.000000, d: 3.700745e+49)
FPR1 5353434f4f4b4945 (f: 1330334080.000000, d: 2.511314e+93)
FPR2 c1e0000000000000 (f: 0.000000, d: -2.147484e+09)
FPR3 408f400000000000 (f: 0.000000, d: 1.000000e+03)
FPR4 4330080000000000 (f: 0.000000, d: 4.512396e+15)
FPR5 3f60624de0000000 (f: 3758096384.000000, d: 2.000000e-03)
FPR6 3ff0000000000000 (f: 0.000000, d: 1.000000e+00)
FPR7 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR8 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR9 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR10 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR11 4030000000000000 (f: 0.000000, d: 1.600000e+01)
FPR12 3fe8000000000000 (f: 0.000000, d: 7.500000e-01)
FPR13 4028000000000000 (f: 0.000000, d: 1.200000e+01)
FPR14 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR15 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR16 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR17 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR18 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR19 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR20 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR21 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR22 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR23 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR24 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR25 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR26 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR27 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR28 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR29 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR30 0000000000000000 (f: 0.000000, d: 0.000000e+00)
FPR31 0000000000000000 (f: 0.000000, d: 0.000000e+00)
Target=2_30_20070420_12448_bHdSMR (AIX 5.3)
CPU=ppc (4 logical CPUs) (0x80000000 RAM)
JVMDUMP006I Processing Dump Event "gpf", detail "" - Please Wait.
JVMDUMP007I JVM Requesting System Dump using '/var/oa/v3/core.20081125.102624.245960.dmp'
JVMDUMP010I System Dump written to /var/oa/v3/core.20081125.102624.245960.dmp
JVMDUMP007I JVM Requesting Snap Dump using '/var/oa/v3/Snap0002.20081125.102624.245960.trc'
JVMDUMP010I Snap Dump written to /var/oa/v3/Snap0002.20081125.102624.245960.trc
JVMDUMP007I JVM Requesting Java Dump using '/var/oa/v3/javacore.20081125.102624.245960.txt'
JVMDUMP010I Java Dump written to /var/oa/v3/javacore.20081125.102624.245960.txt
JVMDUMP013I Processed Dump Event "gpf", detail "".
[oa@XRF4]  : 

...la suite dans un prochain billet ;)

Il y a 15 années 9 mois

Une p'tite note en passant : lorsqu'on créé un utilisateur système sous AIX, pour l'execution d'un process par exemple (dans mon cas OpenAdaptor), une fois l'utilisateur créé (smit user en root) il faut executer la commande :

pwdadm -c &lt;login&gt;

Ceci permet d'éviter des soucis lors de connexion FTP avec le compte par exemple...

Il y a 15 années 9 mois

Pour configurer l'authentification LDAP sur Drupal avec Active Directory : http://drupal.org/node/115146

Il y a 15 années 9 mois

Que faire lorsque l'on souhaite parser du contenu XML dans une application ?

Installer la librairie libxml2 :

> Sous AIX, si on a pas le CD IBM contenant les packages OpenSource, des sites existent sur lesquels on peut télécharger les packages à installer ensuite avec RPM (cela évite de tout avoir à recompiler) :

J'ai donc effectué une installation sur le serveur :

  1. Création d'un repertoire de dump des archives > /var/oa/rpm (ben oui a la base j'installe OpenAdaptor3)
  2. Lancer rpm -Uvh /var/oa/rpm/libxml2-2.6.32-1.aix5.1.ppc.rpm
  3. On obtient le message :
    zlib is needed by libxml2-2.6.32-1
  4. En fait il manque forcément quelques dépendances, du coup il faut les installer (avec la même commande) après les avoir récupéré (cf. premier point en haut de l'article)

Les dépendances rencontrées : zlib -> zlib-1.2.3-5.aix5.1.ppc.rpm ... en fait y'en avait qu'une ;)

Bon du coup chui un fou, j'installe aussi de quoi faire des transfo XML : XSLT. Ca se passe donc dans la librairie libxsl :

rpm -Uvh /var/oa/rpm/libxslt-1.1.24-1.aix5.1.ppc.rpm

libgcrypt is needed by libxslt-1.1.24-1

... bon je passe rapidement mais en fait il faut aussi installer les librairies suivantes : libgpg-error et libgcrypt ...

 

Voilà pour l'installation des librairies GNU XML et XSLT sous AIX !

Il y a 15 années 9 mois

Lors de la compilation d'un programme C qui utilise l'API Informix 4GL, il peut arriver que vous rencontriez ce message d'erreur :

XLO2-mag-dev-F > cc -c \
> -I/home/etud/agoun/include/libxml2 -I/infx9.40/incl/tools -I/infx9.40/incl/esql \
> proto_xml_api.c -o proto_xml_api.o
"/infx9.40/incl/tools/locator.h", line 124.7: 1506-334 (S) Identifier loc_t has already
been defined on line 195 of "/usr/include/sys/localedef31.h".

Il faut alors ajouter la directive -D_H_LOCALEDEF au compilateur.

Pages