Débogage d'une bibliothèque partagée en C Go suspendue sur HTTPS.Post()
Dans le problème décrit, une bibliothèque partagée en C écrite en Go rencontre un blocage lors de la tentative HTTPS.Post(). Bien que le binaire exécutable s'exécute correctement, la bibliothèque partagée rencontre ce problème lors de l'utilisation de http.Post() ou net.Dial().
Enquêtes initiales :
Trace de pile :
La trace de pile SIGQUIT a indiqué que le thread était bloqué sur runtime.futexsleep(), qui est utilisé pour la synchronisation des threads.
Cause possible et Solution :
Comme mentionné dans la réponse résolue, la cause première réside dans la façon dont la bibliothèque partagée Go est chargée. Lorsque la bibliothèque partagée est liée à une application C ou C, le runtime Go est initialisé lors du démarrage de l'application. Cela peut conduire à un comportement imprévisible si l'application fork les processus et tente d'utiliser la bibliothèque Go dans les processus forkés.
Solution :
Pour résoudre ce problème, il est nécessaire de charger la bibliothèque partagée Go après le fork. Ceci peut être réalisé en utilisant des techniques de liaison dynamique telles que dlopen() et dlsym(). Cette approche garantit que le runtime Go n'est initialisé que lorsqu'il est nécessaire dans le processus forké.
Conclusion :
Le problème avec la bibliothèque partagée C suspendue était dû à l'initialisation prématurée du runtime Go. En chargeant la bibliothèque dynamiquement après le fork, le problème a été résolu et la bibliothèque partagée a fonctionné correctement.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!