11 votes

Impossible de pousser vers le dépôt git distant via ssh, bloqué à "Writing objects : 11%"

J'ai un problème lorsque j'essaie de faire un push git qui se bloque pendant "l'écriture des objets". Ce n'est pas le scénario commun de Windows et de git-daemon que j'ai vu répondu ailleurs. Il s'agit d'une connexion Linux à Linux, en utilisant ssh. Sur le client et le serveur, la version de git est 1.7.8.6.

J'ai essayé de faire ce qui suit :

  • Créez un dépôt local vide et poussez-le vers ce dépôt -- cela fonctionne bien.
  • Pull du dépôt local vers le dépôt local -- fonctionne bien
  • Clonez le dépôt distant sur la machine locale - cela fonctionne bien.
  • git fsck et git gc sur les dépôts du serveur et du client
  • Pousser vers un dépôt distant préexistant -- bloque l'écriture des objets à 11%.
  • Créez un dépôt distant vide et poussez-le vers ce dépôt -- suspendez l'écriture d'objets à 2%.

Il y a une variable env que je peux définir pour que git produise des messages de débogage. Rien d'utile ici.

J'ai longuement discuté de ce sujet avec des personnes sur IRC, et j'ai essayé de le googler. Nous n'arrivons à rien. Quelqu'un ici peut-il m'aider à comprendre ce qui ne va pas ?

Gracias.

UPDATE : Basé sur la suggestion de quelqu'un, j'ai fait un strace -F et il reste bloqué sur un select() dans un processus enfant. Je fournirais bien la trace complète, mais stackexchange ne permet pas de la télécharger. Quoi qu'il en soit, voici la section concernée :

[pid 14414] getsockopt(3, SOL_SOCKET, SO_RCVBUF, [87872], [4]) = 0^M
[pid 14414] select(7, [3 4], [3], NULL, NULL) = 2 (in [4], out [3])^M
[pid 14414] read(4,  <unfinished ...>^M
[pid 14433] <... write resumed> )       = 8192^M
[pid 14433] write(1, "\262\36\237\265\234\n\332W\26\271.\250\271W\34\250N\34*\341\247R\21\177\\Dq\23\27\211\270\25"..., 8192) = 8192^M
[pid 14433] write(1, "Y\343}z\367\31y\321)\254\236na\274\347*\253\247\264d\25\213\364\243\331\242\236\3222U3\246"..., 8192 <unfinished ...>^M
[pid 14414] <... read resumed> "t\277\177\276\361\377\327U\361Re\f\347\300\27\3\255}E\363\2277\312p\356F\335U\345\336\250\273"..., 16384) = 16384^M
[pid 14414] write(3, "\210y\r\202\303`\222m\216\177x \354\216Y\322n\232l\273\237\214\352\32\r\261r\311\347\356\236\26"..., 16432) = 16432^M
[pid 14414] getsockopt(3, SOL_SOCKET, SO_RCVBUF, [87872], [4]) = 0^M
[pid 14414] select(7, [3], [3], NULL, NULL) = 1 (out [3])^M
[pid 14414] write(3, "\v\267\355\33\257\332\330\326\233\260;\223\212z\333\213\21'1\20\7\366\"f\253\373\0059\24\206C4"..., 5504) = 5504^M
[pid 14414] getsockopt(3, SOL_SOCKET, SO_RCVBUF, [87872], [4]) = 0^M
[pid 14414] select(7, [3], [], NULL, NULL <unfinished ...>^M
[pid 14433] <... write resumed> )       = ? ERESTARTSYS (To be restarted if SA_RESTART is set)^M
[pid 14433] --- SIGALRM {si_signo=SIGALRM, si_code=SI_KERNEL, si_value={int=1, ptr=0x1}} ---^M
[pid 14433] rt_sigreturn()              = 1^M
[pid 14433] write(1, "Y\343}z\367\31y\321)\254\236na\274\347*\253\247\264d\25\213\364\243\331\242\236\3222U3\246"..., 8192) = ? ERESTARTSYS (To be restarted if SA_RESTART is set)^M
[pid 14433] --- SIGALRM {si_signo=SIGALRM, si_code=SI_KERNEL, si_value={int=1, ptr=0x1}} ---^M
[pid 14433] rt_sigreturn()              = 1^M
[pid 14433] write(1, "Y\343}z\367\31y\321)\254\236na\274\347*\253\247\264d\25\213\364\243\331\242\236\3222U3\246"..., 8192) = ? ERESTARTSYS (To be restarted if SA_RESTART is set)^M
[pid 14433] --- SIGALRM {si_signo=SIGALRM, si_code=SI_KERNEL, si_value={int=1, ptr=0x1}} ---^M
[pid 14433] rt_sigreturn()              = 1^M
[pid 14433] write(1, "Y\343}z\367\31y\321)\254\236na\274\347*\253\247\264d\25\213\364\243\331\242\236\3222U3\246"..., 8192) = ? ERESTARTSYS (To be restarted if SA_RESTART is set)^M
[pid 14433] --- SIGALRM {si_signo=SIGALRM, si_code=SI_KERNEL, si_value={int=1, ptr=0x1}} ---^M
[pid 14433] rt_sigreturn()              = 1^M

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X