abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×

    včera 14:33 | Nová verze

    Vývojáři mobilní Datovky prosí o pomoc s testováním beta verze mobilní Datovky s novým grafickým rozhraním, podporou pro tmavý režim a podporou pro VoDZ. Aplikace je zatím dostupná pouze pro zařízení Android a je umístěna v samostatném instalačním kanále Datovka Beta. Tento kanál slouží pro testovaní nové funkcionality a grafického uživatelského rozhraní. Datovka Beta se instaluje jako samostatná aplikace s vlastními daty, která

    … více »
    Ladislav Hagara | Komentářů: 0
    včera 13:22 | Zajímavý software

    Harlequin byl vydán ve verzi 1.0.0. Jedná se o TUI (Text User Interface) IDE (Integrated Development Environment) k systému pro správu SQL OLAP databází DuckDB.

    Ladislav Hagara | Komentářů: 0
    včera 12:55 | IT novinky

    Po roce a půl od představení DALL·E 2 představila společnost OpenAI novou verzi DALL·E 3 svého AI systému pro generování "realisticky vypadajících obrázků nebo uměleckých děl" na základě popisu v přirozeném jazyce, viz příklad "kosmonaut na koni fotorealisticky". Jednou z novinek je integrace s ChatGPT.

    Ladislav Hagara | Komentářů: 0
    včera 09:00 | Nová verze

    Nová čísla časopisů od nakladatelství Raspberry Pi: MagPi 133 (pdf) a HackSpace 70 (pdf).

    Ladislav Hagara | Komentářů: 0
    20.9. 23:55 | Nová verze

    Po půl roce vývoje od vydání verze 44 bylo vydáno GNOME 45 s kódovým názvem Rīga. Přehled novinek i s náhledy v poznámkách k vydání a v novinkách pro vývojáře. Krátké představení na YouTube. Jednou z nejviditelnějších změn je odstranění tlačítka Činnosti (Activities) v levém horním rohu. Nově je tam indikátor ploch. Výchozím prohlížečem obrázků je nově Loupe, nahradil Eye of GNOME (eog). Novou aplikací pro práci s webovou kamerou je Snapshot, nahradil Cheese. Rozšíření GNOME Shellu fungující v předchozích verzích nejsou s verzí 45 kompatibilní.

    Ladislav Hagara | Komentářů: 25
    20.9. 17:55 | Komunita

    Linux Foundation představila a zaštítila svobodný a otevřený fork Terraformu s názvem OpenTofu. Ten vznikl pod původním názvem OpenTF jako reakce na přelicencování Terraformu na BSL (Business Source License) společností HashiCorp.

    Ladislav Hagara | Komentářů: 2
    20.9. 11:22 | IT novinky

    Google oznámil (en), že konverzační AI Bard (Wikipedie) může nyní komunikovat s aplikacemi a službami Google: "Díky nejnovějšímu rozšíření služby může Bard najít a zobrazit relevantní informace z nástrojů společnosti Google, které používáte každý den, jako je například Gmail, Dokumenty, Disk, Mapy, YouTube a Letenky Google, a to i když jsou potřebné informace v různých aplikacích a službách."

    Ladislav Hagara | Komentářů: 0
    20.9. 08:00 | Zajímavý software

    Apache Pinot (GitHub, Wikipedie) dospěl do verze 1.0. Jedná se o realtimeový distribuovaný OLAP datastore navržený tak, aby na OLAP dotazy odpovídal s nízkou latencí.

    Ladislav Hagara | Komentářů: 0
    19.9. 19:44 | Nová verze

    Byla vydána Java 21 / JDK 21. Nových vlastností (JEP - JDK Enhancement Proposal) je 15. Jedná se o LTS verzi. Nová Java / JDK vychází každých 6 měsíců.

    Ladislav Hagara | Komentářů: 19
    19.9. 16:55 | Nová verze

    Byla vydána betaverze Fedora Linuxu 39, tj. poslední zastávka před vydáním finální verze, která je naplánována na úterý 17. října. Nový Fedora Linux přinese GNOME 45, LibreOffice 7.6, GCC 13.2, …

    Ladislav Hagara | Komentářů: 11
    Knihy s linuxovou tematikou
     (20%)
     (16%)
     (51%)
     (26%)
    Celkem 269 hlasů
     Komentářů: 11, poslední 17.9. 19:19
    Rozcestník

    Dotaz: write na TCP spojení neohlásí chybu

    28.12.2011 14:16 Dave
    write na TCP spojení neohlásí chybu
    Přečteno: 326×
    Zdravím,

    programuju v C TCP komunikaci mezi 2 uzly, vše funguje jak má, ale mám problém s jedním chybovým scénářem. Ustanovím TCP spojení, pošlu data, která v pořádku dorazí k příjemci. Spojení nechám otevřené. Pak na odesílající straně zablokuju příjemce firewallem a opět pošlu data. Data k příjemci samozřejmě nedorazí, ale na odesílající straně write() hlásí, že komunikace proběhla v pořádku. Jak se dá na odesílající straně detekovat, že nastala chyba a data k příjemci nedorazila? Zkoušel jsem si hrát s nastavením socketu SO_KEEPALIVE, což funguje, ale přijde mi to jako obcházení problému a ne jeho řešení...

    Odpovědi

    28.12.2011 15:41 kovariadam | skóre: 12 | blog: biased | Košice/Brno
    Rozbalit Rozbalit vše Re: write na TCP spojení neohlásí chybu
    Neslo by po prijati odoslat naspat nejaku ACK spravu? Co za data to su?
    28.12.2011 22:01 Dave
    Rozbalit Rozbalit vše Re: write na TCP spojení neohlásí chybu
    Jde o SIP protokol, komunikace mezi serverem a klientem, modifikovat protokol a přidat ACK bohužel nemůžu...
    28.12.2011 16:22 Sten
    Rozbalit Rozbalit vše Re: write na TCP spojení neohlásí chybu
    write nečeká na potvrzení, že data dorazila, pokud je v cache dost místa. Můžete zkusit použít TCP_NODELAY, ale ani to nezaručí, že se problém dozvíte hned.
    28.12.2011 22:01 Dave
    Rozbalit Rozbalit vše Re: write na TCP spojení neohlásí chybu
    TCP_NODELAY už jsem zkoušel, bohužel neúspěšně...
    28.12.2011 16:22 Ivan
    Rozbalit Rozbalit vše Re: write na TCP spojení neohlásí chybu
    Jen strilim od boku, zkousel jsi SO_SNDTIMEO? Uspesne zavolani write, znamena jenom to, ze kernel prijal data do sveho odesilaciho bufferu (popr. je jeste odeslal po siti). Kolikrat byla data retransmitovana po siti te nemusi zajimat. Hadam, ze ti vlastne vadi, ze mas v defaultu nastaveny velky connection timeout.

    Zadne obecne reseni neexistuje. Pokud by firewally posilaly reject misto toho aby dropovaly packety tak by to fungovalo jak ma.

    U SO_KEEPALIVE mas problem v tom ten timeout je globalni na urovni celeho OS, a neni mozne nastavit ho pro jedno konkretni spojeni.
    28.12.2011 18:58 Sten
    Rozbalit Rozbalit vše Re: write na TCP spojení neohlásí chybu
    U SO_KEEPALIVE mas problem v tom ten timeout je globalni na urovni celeho OS, a neni mozne nastavit ho pro jedno konkretni spojeni.
    Ale lze: TCP_KEEPCNT, TCP_KEEPIDLE, TCP_KEEPINTVL
    28.12.2011 22:08 Dave
    Rozbalit Rozbalit vše Re: write na TCP spojení neohlásí chybu
    SO_SNDTIMEO jsem zkoušel, ale bohužel to nezabralo. Problém je v tom, jak už tu bylo zmíněno, že write() skončí úspěšně po předání dat kernelu a ne až potom, co druhá strana data opravdu přijme.

    SO_KEEPALIVE jde nastavit pro každý socket zvlášť, ale toto řešení přidává dodatečnou síťovou komunikaci, což v mém případě bohužel nemohu použít.
    Luboš Doležel (Doli) avatar 28.12.2011 22:37 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: write na TCP spojení neohlásí chybu
    write() je u TCP spojení standardně tuším asynchronní, když ho přepnete na synchronní, tak už bych chybové návratové kódy čekal.
    Josef Kufner avatar 29.12.2011 00:36 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: write na TCP spojení neohlásí chybu
    TCP negarantuje doručení dat. Pouze garantuje, že ty data dorazí ve správném pořadí a pokud bylo spojení korektně uzavřeno, tak budou všechna.

    Tedy, pokud spojení uzavřeš, tak close() ti chybu vrátí. Do té doby nevíš nic (a není to špatně).

    Pokud chceš mít jistotu, že nějaká zpráva byla doručena, pošli si ACK na aplikační úrovni a nespoléhej na TCP. Ono toho garantuje daleko méně než si mnoho lidí myslí, například Jabber takle ztrácí zprávy, když ti vypadne spojení (je to chyba v návrhu XMPP).
    Hello world ! Segmentation fault (core dumped)
    pavlix avatar 29.12.2011 09:38 pavlix | skóre: 54 | blog: pavlix
    Rozbalit Rozbalit vše Re: write na TCP spojení neohlásí chybu
    Ono toho garantuje daleko méně než si mnoho lidí myslí, například Jabber takle ztrácí zprávy, když ti vypadne spojení (je to chyba v návrhu XMPP).
    A nejde to ani dobře řešit přes TCP acky... ale naštěstí XMPP má definované jak aplikační acky, tak pingy, dělal to původně před pár lety Justin Karneges a byly kolem toho velké diskuze, kdy různí lidi vymýšlely totální cypoviny jako end-to-end potvrzování. Takže je to jen na lenosti implementátorů.
    Já už tu vlastně ani nejsem. Abclinuxu umřelo.
    29.12.2011 10:14 Ondrej 'SanTiago' Zajicek
    Rozbalit Rozbalit vše Re: write na TCP spojení neohlásí chybu
    Pokud chceš mít jistotu, že nějaká zpráva byla doručena, pošli si ACK na aplikační úrovni a nespoléhej na TCP.
    Souhlas. Na druhou stranu TCP samo zajistuje potvrzovani doruceni dat, takze teoreticky by mohlo jit rozsirit API tak, aby toto potvrzeni bylo propagovano do aplikace.
    29.12.2011 10:55 Ivan
    Rozbalit Rozbalit vše Re: write na TCP spojení neohlásí chybu
    Nojo TCP potvrzuje data, ale samo si muze urcit jak velke baliky dat se potvrzuji. Podle me nemuzes spolehat ani na to ze ti prijde ACK pro kazdy packet s priznakem push (P).
    pavlix avatar 29.12.2011 09:45 pavlix | skóre: 54 | blog: pavlix
    Rozbalit Rozbalit vše Re: write na TCP spojení neohlásí chybu
    Tak on write proběhl v pořádku, data se odeslala. Pokud někoho odřízneš DROP, tak holt vytimeoutuje. Musel bys dát aspoň REJECT a doufat, že chybová zpráva dojde. Ale tvrdý rozpad TCP je prostě pomalý.

    Technicky to jde řešit buď ověřováním TCP acků, což vůbec netuším jestli/jak je exponované... a nebo těch aplikačních acků.

    Níže píšeš, že řešíš SIP, to je změna zadání. V dotazu máš TCP, takže jsi se zřejmě zeptal na něco jiného, než jsi chtěl. Chceš na TCP vrstvě řešit něco, co TCP standardně nenabízí, takže doporučuju poskočit na aplikační vrstvu a řešit to tam.

    A vzhledem k tomu, že jsi zatím nenapsal nic o tom, že by s tím byl nějaký problém... tak není, co řešit :).
    Já už tu vlastně ani nejsem. Abclinuxu umřelo.

    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.