Portál AbcLinuxu, 11. května 2025 10:05

Dotaz: Monitorování komunikace mezi procesy

2.3.2009 11:20 PetrHL | skóre: 17 | blog: petr_h | Neratovice
Monitorování komunikace mezi procesy
Přečteno: 281×
Odpovědět | Admin

Dobrý den,

pokouším se komunikovat s jedním programem pomocí  msgget a msgrcv. Nějak mi to nechodí a bohužel netuším jestli je chyba u mě nebo v aplikaci, která by měla poslat data. Je nějaká možnost jak tuto komunikaci monitorovat? Nevím jak zjistit jestli daná app data vůbec odeslala. Děkuju za případnou radu.

Petr

"Do, or do not. There is no 'try.'" -- Jedi Master Yoda | CQRLOG | CQRPROP | HamQTH | Domů
Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

2.3.2009 11:45 Semo | skóre: 45 | blog: Semo
Rozbalit Rozbalit vše Re: Monitorování komunikace mezi procesy
Odpovědět | | Sbalit | Link | Blokovat | Admin
Nieco sa da vidiet sledovanim suboru cat /proc/sysvipc/msg (napr. pomocou watch). Nie je to uplne odpocuvanie, ale da sa zistit cas posledneho zapisu a pod.
If you hold a Unix shell up to your ear, you can you hear the C.
2.3.2009 13:56 PetrHL | skóre: 17 | blog: petr_h | Neratovice
Rozbalit Rozbalit vše Re: Monitorování komunikace mezi procesy

Díky moc, to pomohlo. Zjistil jsem, že aplikace odesílá data a jak jsou velká.

Použil jsem to takto:

watch -d cat /proc/sysvipc/msg

Bohužel se mi stále data nedaří přijímat. Nikde jsem nenašel nějaký rozumný příklad. Problém může být v tom, že se něco takového snažím udělat ve freepascalu.

Zdroják je zde:

var
  myid : LongInt;
  rcvdm : TMSGbuf;
  s : String = '';
  i : Integer = 0;
  e : LongInt;
begin
  myid  :=   msgget(1238,0666  or  IPC_CREAT);
  Writeln(myid); //
  e := msgrcv(myid, @rcvdm, 1024, 0, 0 or IPC_NOWAIT);
  if e = MSG_NOERROR then
  begin
    for i:=0 to Length(rcvdm.mtext)-1 do
      s:= s + rcvdm.mtext[i];
    Memo1.Lines.Text := s
  end
  else
    Writeln(e)
end;

Bohužel už získání samotného myid nedopadne dobře. Stále se vrací -1. Ve zdrojáku v C je toto:

msgid = msgget ((key_t) 1238, 0666 | IPC_CREAT);

a chodí jim to.

Nenapadá Vás co dělám blbě?

Petr

"Do, or do not. There is no 'try.'" -- Jedi Master Yoda | CQRLOG | CQRPROP | HamQTH | Domů
2.3.2009 14:44 chochi | skóre: 29 | Praha
Rozbalit Rozbalit vše Re: Monitorování komunikace mezi procesy

Ahoj,

V Pascalu jsem neprogramoval uz dlouho, takze nevim jestli to neni blbost - cislo zapsane v C zacinajici nulou je v osmickove soustave - nejsem si jist zda je to tak i v Pascalu.

Takze bych zkusil misto 0666 napsat 438, nebo 0x186 (nebo jak se to pise).

2.3.2009 14:55 Semo | skóre: 45 | blog: Semo
Rozbalit Rozbalit vše Re: Monitorování komunikace mezi procesy
Ked som sa hraval s msgqueues, tak castym problemom po chvily hrania bolo, ze starymi nezrusenymi frontami som vycerpal maximalny pocet queues v systeme. Takze:

1.) pomocou utility ipcrm premazat vytvorene a opustene fronty (nezanikaju po skonceni programu tak ako deskriptory). Zaroven pri konceni vlastnych programov korektne mazat vytvorene IPC prostriedky.

2.) zvacsit pocet moznych front v systeme: zapisat kernel.msgmni = 512 do /etc/sysctl.conf alebo spustit sysctl -w kernel.msgmni=512

3.) po zfailovani msgget sa pozriet do globalnej premennej errno (ako sa do nej pozera v Pascale neviem) a zistit presnejsi kod chyby.
If you hold a Unix shell up to your ear, you can you hear the C.
2.3.2009 15:51 PetrHL | skóre: 17 | blog: petr_h | Neratovice
Rozbalit Rozbalit vše Re: Monitorování komunikace mezi procesy

Děkuju moc!

Smazání fronty pomohlo, stejně tak i zapsání číšla v dekadickém tvaru. Trošku jsem se posunul. Teď program padne na hubu  na řádku, kde je ten for i:=0 atd. Padá to i když si chci hodnotu vypsat najednou pomocí Writeln. Jdu zkoumat dál.

Moc díky za rady, naučil jsem se něco nového.

Petr

"Do, or do not. There is no 'try.'" -- Jedi Master Yoda | CQRLOG | CQRPROP | HamQTH | Domů
2.3.2009 20:50 pht | skóre: 48 | blog: pht
Rozbalit Rozbalit vše Re: Monitorování komunikace mezi procesy
Odpovědět | | Sbalit | Link | Blokovat | Admin
Můžete použít utility strace a ltrace. A samozřejmě nástroj gdb.
In Ada the typical infinite loop would normally be terminated by detonation.

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.