Programmation » Lighttpd met mon process FastCGI en suspend... :kiki:
Catégorie:  
   
Lighttpd met mon process FastCGI en suspend... :kiki:
Publié le 28/07/2007 @ 01:45:54,
Par zion

Non la c'est pas gentil Lighttpd, vraiment :petrus:

Je m'explique...

J'ai mon process à moi, indépendant, qui gère le protocole FastCGI.
J'ai ma config:


fastcgi.server = (".ks" =>
(
(
"host" => "127.0.0.1",
"port" => 2000
)
)
)


Il a à priori pas besoin de plus et en effet, il se connecte, récupère et affiche la page sans soucis, sauf que juste après avoir envoyé la page, ce con suspend mon processus et je dois manuellement faire un fg %1 pour le relancer.

Bref, pas du tout pratique pour un serveur web si je dois manuellement lancer le truc page par page :ddr555:

Any idea?
phil? :oh:
Je suis le Roy :ocube:
   
Lighttpd met mon process FastCGI en suspend... :kiki:
Publié le 28/07/2007 @ 02:16:15,
Par philfr
C'est quel process qui est suspendu ? Ton fastcgi ? Tu l'as démarré en background ? Et il utilise stdin/stdout/stderr ?

Si tu le laisses en foreground que fait-il ?
   
Lighttpd met mon process FastCGI en suspend... :kiki:
Publié le 28/07/2007 @ 02:19:19,
Par zion
C'est mon process fastcgi que j'ai démarré manuellement, en foreground!, que Lighttpd suspend.

Je recois un

[1]+ Stopped ./kelare

Et si je refais un fg %1 ca repart pour un tour et il me refait la même chose... J'ai tenté de bloquer une dizaine de SIG déjà sans trouver le bon :ddr555:
Je suis le Roy :ocube:
   
Lighttpd met mon process FastCGI en suspend... :kiki:
Publié le 28/07/2007 @ 10:32:41,
Par rfr
faut pas bloquer les signaux, faut les intercepter ...
To die is a time consuming activity, it often takes a lifetime (but some are faster than others ... though)
   
Lighttpd met mon process FastCGI en suspend... :kiki:
Publié le 28/07/2007 @ 10:47:12,
Par philfr
SIGSTOP ne peut être ni bloqué, ni traité.
Faudrait trouver pourquoi lighttpd envoie ce signal au process fastcgi, ce qui semble être le cas...

Je cherche sur google...
   
Lighttpd met mon process FastCGI en suspend... :kiki:
Publié le 28/07/2007 @ 10:55:55,
Par philfr
... je trouve des bug reports php (http://www.google.be/search?hl=en&q=sigstop++fastcgi&btnG=Search&meta=), mais le site bugs.php.net ne répond pas chez moi pour l'instant...

Il est écrit en PHP to process fastcgi ?
   
Lighttpd met mon process FastCGI en suspend... :kiki:
Publié le 28/07/2007 @ 12:02:42,
Par zion
Non, il est écrit en Pascal (Kylix) et je sais intercepter une bonne partie des signaux, mais en effet si c'est un SIGSTOP que ce connard envoie j'ai aucune chance de le bloquer :sweat:

Fait chier, maintenant que j'ai plus de SegFault ce serait bien qu'on me tue pas unilatéralement mon process :mmmfff:
Je suis le Roy :ocube:
   
Lighttpd met mon process FastCGI en suspend... :kiki:
Publié le 28/07/2007 @ 12:04:04,
Par zion
http://groups.google.be/group/mailing.www.php-dev/browse_thread/thread/aab7bdaef0d3fac0/4d220c53540963ef?lnk=st&q=sigstop++li- ghttpd&rnum=1&hl=en#4d220c53540963ef

C'est strace qui me permet de savoir quel message j'ai reçu? J'aimerais être sûr déjà que je reçois un SIGSTOP et de qui :smile:
Je suis le Roy :ocube:
   
Lighttpd met mon process FastCGI en suspend... :kiki:
Publié le 28/07/2007 @ 12:07:35,
Par zion
Ah... J'ai lancé strace et je vois un:

ERESTART_RESTARTBLOCK (To be restarted) :oh:

Bon vais chez brico, je note ça pour plus tard, ça doit bien avoir une raison ce truc :oh:
Je suis le Roy :ocube:
   
Lighttpd met mon process FastCGI en suspend... :kiki:
Publié le 28/07/2007 @ 12:11:09,
Par zion
Ce serait lié à une boucle avec un... Sleep(1) et un nanosleep qui fail :figti:

Ptain c'est quoi ce bordel :dawa:

Bon tant pis, Brico, j'espère que ca tournera pas trop tard ce truc, c'était pas un bug prévu au planning :ddr555:
Je suis le Roy :ocube:
   
Lighttpd met mon process FastCGI en suspend... :kiki:
Publié le 28/07/2007 @ 14:04:25,
Par zion
Bon non c'est pas le nanosleep, dommage... En virant le sleep et en relancant avec un strace il ne me dit rien du tout mais le process est quand même down :sweat:

Non di djou :kiki:
Je suis le Roy :ocube:
   
Lighttpd met mon process FastCGI en suspend... :kiki:
Publié le 28/07/2007 @ 14:16:48,
Par ovh
Courage tu vas trouver :calin: :zoubi:

Tu vas le mater ce fastcgi :taio:
Je n'ai rien à voir avec www.ovh.com
   
Lighttpd met mon process FastCGI en suspend... :kiki:
Publié le 28/07/2007 @ 15:36:13,
Par philfr
Quels libs utilises-tu dans ton prog fastcgi ? Une lib fastcgi ? Un accès DB ?
C'est peut-être une autre cause que lighttpd lui-même...
   
Lighttpd met mon process FastCGI en suspend... :kiki:
Publié le 28/07/2007 @ 16:04:18,
Par zion
Quels libs utilises-tu dans ton prog fastcgi ? Une lib fastcgi ? Un accès DB ?
C'est peut-être une autre cause que lighttpd lui-même...


Tout est codé à la main, pas question d'utiliser une lib fastcgi non :petrus:

Mais pourquoi ce serait à la fin de la requête fastcgi exactement que le process est foutu en suspend et que si je le relance manuellement il recommence parfaitement pour la prochaine requête, etc, etc? :oh:

Y a vraiment aucune raison :sisicaivrai:
Je suis le Roy :ocube:
   
Lighttpd met mon process FastCGI en suspend... :kiki:
Publié le 28/07/2007 @ 17:36:51,
Par rfr
ben file ton code :ddr555:
To die is a time consuming activity, it often takes a lifetime (but some are faster than others ... though)
   
Lighttpd met mon process FastCGI en suspend... :kiki:
Publié le 28/07/2007 @ 17:39:43,
Par Altar
Farpaitement :oh:
   
Lighttpd met mon process FastCGI en suspend... :kiki:
Publié le 28/07/2007 @ 18:05:10,
Par zion
T'as un environnement kylix qui tourne sur ta machine? :petrus:
Je suis le Roy :ocube:
   
Lighttpd met mon process FastCGI en suspend... :kiki:
Publié le 28/07/2007 @ 18:09:36,
Par zion
On va recommencer avec des questions simples, la solution en sortira j'en suis sûr :joce:

Déjà, pourquoi un process passe en "Stopped"?
Je suis le Roy :ocube:
   
Lighttpd met mon process FastCGI en suspend... :kiki:
Publié le 28/07/2007 @ 18:23:26,
Par philfr
Parce qu'il reçoit le signal SIGSTOP :oh:

Edith: ou le signal SIGTSTP, avec un CTRL-Z dans une console...

Dernière édition: 28/07/2007 @ 18:24:14
   
Lighttpd met mon process FastCGI en suspend... :kiki:
Publié le 28/07/2007 @ 18:28:38,
Par philfr


Tout est codé à la main, pas question d'utiliser une lib fastcgi non :petrus:

:kiki:

Mais pourquoi ce serait à la fin de la requête fastcgi exactement que le process est foutu


Que fait ton process à la fin de la requête ?
Le lien lighttpd-fastcgi est via un socket TCP ? Un socket Unix ? Un pipe ?
Si tu le fais via un socket TCP, tu peux mettre ethereal wireshark pour sniffer ce qui passe ?

Dernière édition: 28/07/2007 @ 18:29:49
Répondre - Catégorie:  
Informaticien.be - © 2002-2024 AkretioSPRL  - Generated via Kelare
The Akretio Network: Akretio - Freedelity - KelCommerce - Votre publicité sur informaticien.be ?