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 8 années 8 mois

Bon je pensais que j'étais bon pour l'install de la lib. En fait pour faire le dev. il me manque la librairie XSLT-devel (présente dans le package libxslt-devel-1.1.24-1.aix5.1.ppc.rpm).

Du coup install :

<br />
XMASTER:/var/oa3/rpm>rpm -Uvh libxslt-devel-1.1.24-1.aix5.1.ppc.rpm<br />
error: failed dependencies:<br />
        libxml2-devel >= 2.6.27 is needed by libxslt-devel-1.1.24-1<br />
        libgcrypt-devel is needed by libxslt-devel-1.1.24-1<br />
        pkg-config is needed by libxslt-devel-1.1.24-1<br />
XMASTER:/var/oa3/rpm><br />

...ok donc du coup :

<br />
XMASTER:/var/oa3/rpm>rpm -Uvh libgcrypt-devel-1.4.3-1.aix5.1.ppc.rpm<br />
error: failed dependencies:<br />
        info is needed by libgcrypt-devel-1.4.3-1<br />
        libgpg-error-devel is needed by libgcrypt-devel-1.4.3-1<br />
XMASTER:/var/oa3/rpm><br />

...bon...

<br />
XMASTER:/var/oa3/rpm>rpm -Uvh libgcrypt-devel-1.4.3-1.aix5.1.ppc.rpm<br />
error: failed dependencies:<br />
        info is needed by libgcrypt-devel-1.4.3-1<br />
        libgpg-error-devel is needed by libgcrypt-devel-1.4.3-1<br />
XMASTER:/var/oa3/rpm><br />

... bref n'arrivant pas a installer la librairie de dev. (en gros ça bloque sur une dépendance /usr/bin/python même si j'installe le-dit package) j'ai téléchargé les sources et mis le répertoire contenant les .h dans mes directives de compilation (-I) :)

Il y a 8 années 8 mois

Pour connaître la liste des packages installés sous AIX, il faut taper lslpp -aL | pg ou avec un grep si vous recherchez un package particulier...

Il y a 8 années 8 mois

Donc, suite au plantage et à l'impossibilité de faire fonctionner le 4GL à partir de Java, j'ai changé mon fusil d'épaule...

Soyons fous ! et si on faisait tout dans le 4GL ?

  1. Lecture du message entrant
  2. Parsing XML des données
  3. Insertion en base
  4. Traitement métier
  5. Création du message XML de réponse
  6. Ecriture de ce dernier dans la bonne file

Bon là se profile à l'horizon une autre difficulté : ma méconnaissance du langage C... méconnaissance parce que c'est super loin tout ça, et en plus j'ai jamais bien compris le concept des pointeurs...... ;)=

Bref, je me suis donc lancé, j'ai donc développé un programme 4GL qui fait appel à des fonctions C d'envoi/réception de messages au travers d'MQ, ainsi que des fonctions de parsing/transformation XML (d'où les quelques billets sur l'installation notamment des librairies libxml2 et libxslt sous AIX...).

Donc, petite explication sur l'utilisation de fonction C en 4GL :

  1. Comment ça marche (le principe) :
    L'idée est de créer une fonction ayant une signature de la forme

    int <nom méthode>(int nargs);

    La fonction doit donc retourner un int qui correspond au nombre de paramètres retournés (ne me demandez pas pourquoi, c'est le fonctionnement du 4GL :P ). C'est là où il faut être attentif, a savoir qu'on va utiliser des fonctions du type

    ibm_lib4gl_returnInt4(mqStatus);

    ou

    ibm_lib4gl_returnString(mqErrmsg);

    Pour retourner les valeurs souhaitées, (la fonction à utiliser depend bien sûr du type de valeur retournée, cf. la doc du langage 4GL pour la liste exhaustive)

  2. Le passage de parmètres et la gestion de l'instruction return

A TERMINER

Il y a 8 années 8 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 8 années 8 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...

Pages