Portál AbcLinuxu, 9. května 2025 06:05

Dotaz: meziprocesní komunikace

31.1.2009 22:42 Jan Honza
meziprocesní komunikace
Přečteno: 310×
Odpovědět | Admin

Ahoj,
na Ubuntu mám spuštěné dva nezávislé procesy: "Master" (skript v Perlu) a "Slave" (Céčko). V případě že "Slave" zachytí přerušení měl by o tom odeslat zprávu procesu "Master". Bohužel, protože
procesy jsou nezávislé nelze pro komunikaci použít běžné roury. Prý lze použít roury přes
FIFO soubory. Nebo je rozumnější použít sokety (server - klient) ?? Nebo existuje ještě
další, elegantnější řešení?
 

Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

31.1.2009 23:52 l4m4
Rozbalit Rozbalit vše Re: meziprocesní komunikace
Odpovědět | | Sbalit | Link | Blokovat | Admin
Nezávislé znamená, že mezi nimi není vztah rodič-potomek?

Pak jsou v zásadě možnosti (v náhodném pořadí):
- pojmenované roury (viz mkfifo)
- SysV IPC (viz např. msgget nebo i shmget)
- POSIX IPC (viz např. mq_open nebo i shm_open)
- již zmíněné sockety, pro lokální viz ,Unix domain sockets` v info libc

Doporučovat nebudu nic, protože to záleží na situaci.  FIFO je asi
nejjednodušší (v perlu viz POSIX::mkfifo), sokety nejjednodušší nejsou,
ale umožní snáz přejít na připojování klientů z jiných počítačů.
1.2.2009 12:39 Jan Honza
Rozbalit Rozbalit vše Re: meziprocesní komunikace

ješte jsem nyní uvažoval (po položení otázky: zda jsou procesy opravdu nezávislé)....

V případě že bych z perlovského skriptu spustil pomocí "system" proces "Slave"...jednalo by se tím pádem o vztah rodič potomek? Dalo by se požít klasických rour?

 

 

1.2.2009 17:28 alkoholik25
Rozbalit Rozbalit vše Re: meziprocesní komunikace
Ano. Pak se jednoduse budes moct pripojit na stdin/stdout/stderr techto procesu.
Josef Kufner avatar 1.2.2009 18:11 Josef Kufner | skóre: 70
Rozbalit Rozbalit vše Re: meziprocesní komunikace
Odpovědět | | Sbalit | Link | Blokovat | Admin
Pokud Slave je spuštěn Masterem, tak znáš jeho pid a můžeš Slave poslat třeba SIGHUP když Master končí. Pokud končí Slave, posílá se Masterovi SIGCHLD.

Pokud máš mezi nimi nějaký komunikační kanál, třeba pár rour, tak s ukončením jednoho z nich dostaneš při čtení/zápisu EOF.

Na jejich spojení nemusíš vytvářet pojmenované roury, stačí nepojmenované, které vytváří pipe. Nebo můžeš přesměrovat stdin+stdout a komunikovat po nich -- to je v mnoha případech nejlepší varianta, protože v kombinaci s textovým komunikačním protokolem se to velmi pohodlně ladí.

No a pokud ty dva procesy nemají společného vůbec nic, použij prostě unix sockety. Je to výrazně pohodlnější než roura, je to obousměrné a hlavně je to stavěné na více klientů. S rourama je to na první pohled jednodušší, ale to co sockety už mají vyřešené si musíš řešit sám. Navíc změna na tcp socket je pak velmi jednoduchá.

Další celkem hezkou možností je použití D-Bus. To se ti pak třeba Master může spouštět na požádání automaticky.
Hello world ! Segmentation fault (core dumped)

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.