IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Bases de données Delphi Discussion :

Firebird 1.0 + Delphi trafic reseau immence


Sujet :

Bases de données Delphi

  1. #1
    Dry
    Dry est déconnecté
    Membre du Club

    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    48
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 48
    Points : 50
    Points
    50
    Par défaut Firebird 1.0 + Delphi trafic reseau immence
    Bonjour,

    je développe actuellement une application dephi7 lié a une base de données Firebird 1.0. Il se trouve que les client et le serveur FireBird utiliseront l'ADSL comme vecteur de communication.

    Je me suis livré a quelque tests :
    une table des 4 champs : 1 entier, 3 varchar (de 10, 20 et 200).
    Cette table possede 7 enregistrements.
    Je réalise en boucle 10 fois cette requete : "SELECT * FROM MA_TABLE"

    En utilisant le composant DBExpress, cela prend 16 sec et 133 ko de trafic réseau.
    En utilisant IBX avec un IBquery cela prend 16 sec et génére un trafic de 61 ko.
    En utilisant IBX avec un IBSQL cela prend 12 sec et génere un trafic de 33 ko.
    (il faut rajouter entre 3 et 5 sec si l'on prend en compte les temps d'ouverture et de fermeture de connection)
    Je précise bien que que le Serveur Firebird et le client delphi sont dispant et utilise l'ADSL 512k.
    Je trouve vraiment les preformences CATASTROPHIQUES aussi bien au niveau des temps d'execution qu'au niveau du trafique réseau générer.


    Faut-il que je change de Serveur de base de données ? (si oui pour lequel ?) ou il a t il quelque chose a faire pour pouvoir effectuer mes 10 requetes (on ne peut plus simple) en moins de 2 sec ?


    Merci par avance.

  2. #2
    Membre averti Avatar de chtiot
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    385
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 385
    Points : 403
    Points
    403
    Par défaut
    et t'as essayé avec un serveur local pour comparer et voir si ça vient du serveur ou de ta liaison adsl?

  3. #3
    Dry
    Dry est déconnecté
    Membre du Club

    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    48
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 48
    Points : 50
    Points
    50
    Par défaut
    oui, en local, le temps pour réaliser 10 fois ma requete est négligable, tres inférieur à une seconde en tout cas.

  4. #4
    Membre chevronné

    Profil pro
    Chef de Projet / Développeur
    Inscrit en
    Juin 2002
    Messages
    599
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de Projet / Développeur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2002
    Messages : 599
    Points : 2 024
    Points
    2 024
    Par défaut
    Il me semble avoir lu qu'une des optimisation de Firebird 1.5 est que désormais le trim des varchar se fait au niveau du serveur et non plus au niveau du client.

    Cela semblerais impliquer qu'avant (et donc dans la version 1 et autre Interbase) si j'avais un varchar(200), même s'il ne contenait que 10 caractère, c'est bien 200 caractère qui passe par la ligne. Mais bon...
    cela n'explierais que la moitié des 33 ko.

    Autre truc, danscertain composant on peut activer/désactiver le transfert des méta données. On a de bien meiulleur performmances en les désactivant.
    --
    vanquish

  5. #5
    Dry
    Dry est déconnecté
    Membre du Club

    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    48
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 48
    Points : 50
    Points
    50
    Par défaut
    Cela semblerais impliquer qu'avant (et donc dans la version 1 et autre Interbase) si j'avais un varchar(200), même s'il ne contenait que 10 caractère, c'est bien 200 caractère qui passe par la ligne. Mais bon...
    cela n'explierais que la moitié des 33 ko.
    hé oui, cela n'explique pas tout ....

    tu n'aurais pas des infos plus précise quant à l'acitvation / désactivation de transfert de méta données ?

    Merci pour la réponse en tout cas

  6. #6
    Membre chevronné

    Profil pro
    Chef de Projet / Développeur
    Inscrit en
    Juin 2002
    Messages
    599
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de Projet / Développeur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2002
    Messages : 599
    Points : 2 024
    Points
    2 024
    Par défaut
    Citation Envoyé par Dry
    tu n'aurais pas des infos plus précise quant à l'acitvation / désactivation de transfert de méta données ?
    Non pas vraiment.
    J'utilise Zeoslib.
    Là dans les ZxxQuery, il y a l'option doQuickOpen.

    le TSQLDataset de dbExpress contient une property NoMetadata
    (mais qui est déprécié dans D7)

    En fait, je me suis aperçu de ce pb de méta-donnée, non pas avec Firebird, mais avec mySQL lorsque je me suis mis à utilise InnoDB. Les perfs ont chuté d'une façon énorme. J'ai récupéré les perfs initiales en désactivant le transfert des méta-données.

    Sur Firebird je me suis aperçu d'une légère amélioration sur les gros volumes. Mais cette amélioration est plus 'statistique', que réellement sensible pour l'utilisateur. Mais je suis sur un lien rapide. Sur un lien lent, l'impact est peut-être plus sensible.
    --
    vanquish

  7. #7
    Membre expérimenté

    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    897
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2004
    Messages : 897
    Points : 1 561
    Points
    1 561
    Par défaut
    Le serveur hébergeant ta base tourne sous Windows, Linux ou Unix ?
    Pensez à utiliser les tags dans le titre.
    Avant de poser une question reportez-vous à la FAQ Delphi
    Respectez les règles du forum.

  8. #8
    Dry
    Dry est déconnecté
    Membre du Club

    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    48
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 48
    Points : 50
    Points
    50
    Par défaut
    Merci vanquish, je vais creuser dans cette voix.


    Le serveur et le client tournent sous Windows, Pascal Jankowski.

  9. #9
    Membre chevronné

    Profil pro
    Chef de Projet / Développeur
    Inscrit en
    Juin 2002
    Messages
    599
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de Projet / Développeur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2002
    Messages : 599
    Points : 2 024
    Points
    2 024
    Par défaut
    Juste comme ça en passant, ta base et ton client sont bien en dialect 3 ?
    (le dernier et donc probablement le meilleur)
    --
    vanquish

  10. #10
    Membre à l'essai
    Inscrit en
    Avril 2004
    Messages
    12
    Détails du profil
    Informations forums :
    Inscription : Avril 2004
    Messages : 12
    Points : 13
    Points
    13
    Par défaut Salut
    Pour avoir un meilleur temps de réponse utilise un IBSQL, car il est unidirectionnel donc il renvoi les donnée sont métadonnée, sinon pour une meilleur performance utilise don l'architecture multi-tiers(distribuer) avec DataSnap une application cliente/ application serveur. sinon dans le cas ou le client ne cherche qu'a visualiser les résultat de la requete je vous conseil d'utiliser intraweb, le client communiquera avec le serveur via une connexion web HTTP, c ce que j'ai fait pour des client qui veulent avoir des rapport de ma base de donnée (Interbase 6.0) depuis internet.
    Datasnap, Intraweb est parfaitement adéquat pour ce genre de situation.
    il faut transmettre aux autres ce que on a appris par les autres, nul n'est né savant.

  11. #11
    Membre expérimenté

    Homme Profil pro
    Inscrit en
    Mars 2004
    Messages
    897
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2004
    Messages : 897
    Points : 1 561
    Points
    1 561
    Par défaut
    Je rejoins brikh Tsoufik pour la solution trois-tiers, avec Midas (datasnap) puisque ton serveur fonctionne sous Windows. La répartition des charges est bonne, mais attention cependant avec IntraWeb ou TCP aux Goulets d'étranglement (puisque utilisation d'un seul port).
    D'autre part avec HTTP, tu peux sécuriser avec SSL si tu utilises un serveur IIS.

    Mais attention cela reste lent quand même
    Pensez à utiliser les tags dans le titre.
    Avant de poser une question reportez-vous à la FAQ Delphi
    Respectez les règles du forum.

  12. #12
    Dry
    Dry est déconnecté
    Membre du Club

    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    48
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 48
    Points : 50
    Points
    50
    Par défaut
    Merci brikh Tsoufik et Pascal Jankowski

    Je vais me renseigner sur le DataSnap et intraWeb.

Discussions similaires

  1. bloquer trafic reseau
    Par student2008 dans le forum Général Java
    Réponses: 1
    Dernier message: 21/05/2008, 14h45
  2. Réponses: 0
    Dernier message: 30/12/2007, 12h47
  3. Trafic reseau avec BDE
    Par tryonyco dans le forum C++Builder
    Réponses: 5
    Dernier message: 24/04/2007, 14h34
  4. Event sur base de donnée Firebird et programmation delphi
    Par seb8810 dans le forum Connexion aux bases de données
    Réponses: 5
    Dernier message: 16/03/2006, 17h06
  5. Connexion Firebird en PHP+DELPHI
    Par nicotin dans le forum Connexion aux bases de données
    Réponses: 2
    Dernier message: 18/01/2005, 19h34

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo