abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 23:55 | Nová verze

    Byla vydána nová stabilní verze 24.05 linuxové distribuce NixOS (Wikipedie). Její kódové označení je Uakari. Podrobný přehled novinek v poznámkách k vydání. O balíčky se v NixOS stará správce balíčků Nix.

    Ladislav Hagara | Komentářů: 0
    včera 17:33 | Nová verze

    Byla vydána nová verze 1.48.0 sady nástrojů pro správu síťových připojení NetworkManager. Novinkám se v příspěvku na blogu NetworkManageru věnuje Fernando F. Mancera. Mimo jiné se v nastavení místo mac-address-blacklist nově používá mac-address-denylist.

    Ladislav Hagara | Komentářů: 7
    včera 17:11 | Komunita

    Před 25 lety, 31. května 1999, započal vývoj grafického editoru Krita (Wikipedie). Tenkrát ještě pod názvem KImageShop a později pod názvem Krayon.

    Ladislav Hagara | Komentářů: 3
    včera 12:55 | Nová verze

    Farid Abdelnour se v příspěvku na blogu rozepsal o novinkám v nejnovější verzi 24.05.0 editoru videa Kdenlive (Wikipedie). Ke stažení brzy také na Flathubu.

    Ladislav Hagara | Komentářů: 0
    včera 11:22 | Zajímavý článek

    David Revoy, autor mj. komiksu Pepper&Carrot, se rozepsal o své aktuální grafické pracovní stanici: Debian 12 Bookworm, okenní systém X11, KDE Plasma 5.27, …

    Ladislav Hagara | Komentářů: 6
    30.5. 22:44 | Nová verze

    Wayland (Wikipedie) byl vydán ve verzi 1.23.0. Z novinek lze vypíchnout podporu OpenBSD.

    Ladislav Hagara | Komentářů: 0
    30.5. 21:22 | Zajímavý článek

    Craig Loewen na blogu Microsoftu představil novinky ve Windows Subsystému pro Linux (WSL). Vypíchnout lze GUI aplikaci pro nastavování WSL nebo správu WSL z Dev Home.

    Ladislav Hagara | Komentářů: 0
    30.5. 12:44 | Pozvánky

    V sobotu 1. června lze navštívit Maker Faire Ostrava, festival plný workshopů, interaktivních činností a především nadšených a zvídavých lidí.

    Ladislav Hagara | Komentářů: 0
    30.5. 12:22 | Nová verze

    Webový server Caddy (Wikipedie) s celou řadou zajímavých vlastností byl vydán ve verzi 2.8 (𝕏). Přehled novinek na GitHubu.

    Ladislav Hagara | Komentářů: 13
    29.5. 22:11 | Nová verze

    Byla vydána verze 3.0 (@, 𝕏) svobodného softwaru HAProxy (The Reliable, High Performance TCP/HTTP Load Balancer; Wikipedie) řešícího vysokou dostupnost, vyvažování zátěže a reverzní proxy. Detailní přehled novinek v příspěvku na blogu společnosti HAProxy Technologies.

    Ladislav Hagara | Komentářů: 7
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (90%)
     (3%)
     (4%)
     (4%)
    Celkem 1068 hlasů
     Komentářů: 17, poslední včera 15:31
    Rozcestník

    Dotaz: Linux komunikace mezi procesy, příklady v C?

    6.8.2023 20:06 Marek
    Linux komunikace mezi procesy, příklady v C?
    Přečteno: 555×
    Hraji si s myšlenkou použít něco jako Raspberry Pi k řízení stroje, čistě protože většina práce kolem toho je komunikace s uživateli, logování atd. Představa, pro obsluhu hw tj, čidel, spinačů , kontrolek a hlavně celou řídící logiku, napíši program (C) , který bude přes to něco umět na žádost jiného procesu poskytnou základní info o stavu stroje nebo i přijmout nějaké data. Například na venek by stroj mohl informace poskytovat přes webový server (ligthtpd) kam by se data dosta třeba přes cgi, fastcgi nebo co je dnes in. Co je dnes pro tento účel v Linuxu nejvhodnější a kde najdu příklad použití, at si to osahám? Děkuji Marek

    Odpovědi

    Jendа avatar 6.8.2023 21:03 Jendа | skóre: 78 | blog: Jenda | JO70FB
    Rozbalit Rozbalit vše Re: Linux komunikace mezi procesy, příklady v C?
    Takhle to provozujeme na našem radaru:

    Chceš věc, která se jmenuje message broker / message bus.

    Pro stavová a menší data (typický příklad jsou teploty, ale i třeba nastavování provozních parametrů) používáme MQTT (mosquitto), přes které posíláme JSONy. Každá komponenta má nějaké topicy, třeba rxpow-h/power (obsahuje aktuální průnik výkonu do přijímače) nebo transmit-api/performance (obsahuje kolik je v které producer/consumer frontě a jak se to stíhá odbavovat) a do těchto topiců publikujeme JSONy, především protože se to celé jednoduše serializuje a deserializuje (v Pyhonu to mám ve slovníku a stačí json.dumps / json.loads). V tom JSONu jsou normální key-value, třeba pro změnu ukázka ze solární elektrárny:
    victron/status:
    {
      "id": "victron",
      "type": "status",
      "timestamp": 1691347644,
      "device_state_id": 9,
      "device_state_name": "charge",
      "mains_u": 236.33,
      "mains_i": 2.11,
      "inv_u": 236.33,
      "inv_i": 1.83,
      "inv_p": 111,
      "out_p": 75,
      "bat_u": 50,
      "bat_i": 0.1,
      "bat_p": 5,
      "soc": 194,
      "led_light": 9,
      "led_blink": 0,
      "led_info": [
        "mains",
        "float"
      ],
      "state": "on"
    }
    
    (commandlinový jq je tvůj kamarád)

    Na tom MQTT mají různé komponenty subscribnuté topicy kterým se jim dávají příkazy (typicky komponenta/set, třeba když do tilt/set/absolute_deg publikuju 10 tak se anténa naklopí na 10°). A dále je věc co je subscribnutá na skoro všechno a tlačí to do Influxu (tomu nerozumím, dělá to kolega) a z toho se to pak grafuje v Grafaně. A dále si můžeš pustit CLI / webový tool, který ukazuje všechny ty topicy a co v nich je aktuálně za data. A dále se můžeš subscribnout přes mosquitto_sub a prostě to padá na stdout. A dále monitoring, že ty parametry nevybočují. Atd.

    Bulk a streamová data (v našem případě vyloženě kvadraturní signály každého odběhu) přenášíme přes ZeroMQ, což je tenká abstrakce nad běžnými sockety, ale nemusíš řešit že se ti klient připojí/odpojí nebo že by se chtělo připojit víc klientů a nemusíš řešit rozdělování streamu do zpráv, a dokonce to umí multipart messages (což se v Pythonu pak objeví jako seznam bytestringů). ZeroMQ má velmi schůdný tutoriál přímo na webu a má překvapivě malý výkonový overhead.

    Dále bych doporučoval nepsat to v C, je to moc lowlevel a strašný pain tam tyhle datové věci dělat (protože to nemá slovníky, seznamy, i blbé stringy se musí alokovat a řešit), ale v něčem víc high-level a pokud tam máš pár funkcí co nutně vyžadují C (výkon, přístup k HW) tak jen ty napsat v C a volat přes CFFI, o tom jsem tu psal.
    8.8.2023 11:32 z_sk | skóre: 34 | blog: analyzy
    Rozbalit Rozbalit vše Re: Linux komunikace mezi procesy, příklady v C?
    nemá slovníky, seznamy
    Použiješ glib.
    blbé stringy se musí alokovat
    Máš napríklad strdup() alebo strndup().
    debian.plus@protonmail.com
    7.8.2023 13:36 z_sk | skóre: 34 | blog: analyzy
    Rozbalit Rozbalit vše Re: Linux komunikace mezi procesy, příklady v C?

    Založit nové vláknoNahoru

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

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.