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í
×
    dnes 16:44 | Komunita

    Richard Hughes oznámil, že po společnostech Red Hat a Framework a organizacích OSFF a Linux Foundation, službu Linux Vendor Firmware Service (LVFS) umožňující aktualizovat firmware zařízení na počítačích s Linuxem, nově sponzorují také společnosti Dell a Lenovo. Do dnešního dne bylo díky LVFS provedeno více než 145 milionů aktualizací firmwarů od více než 100 různých výrobců na milionech linuxových zařízení.

    Ladislav Hagara | Komentářů: 0
    dnes 15:22 | IT novinky

    Americké technologické společnosti Microsoft, Google a xAI souhlasily, že vládě Spojených států poskytnou přístup k novým modelům umělé inteligence (AI) před jejich uvedením na trh. Oznámila to americká vláda, která tak bude moci prověřit, zda modely nepředstavují hrozbu pro národní bezpečnost. Oznámení podtrhuje rostoucí obavy Washingtonu z rizik spojených s výkonnými AI systémy. Americké úřady chtějí v rámci předběžného přístupu

    … více »
    Ladislav Hagara | Komentářů: 0
    dnes 14:11 | IT novinky

    Společnost Valve zveřejnila (GitLab) nákresy ovladače Steam Controller a puku. Pro všechny, kdo by jej chtěli hacknout nebo modifikovat, případně pro ně navrhnout nějaké příslušenství. Pod licencí Creative Commons (CC BY-NC-SA 4.0).

    Ladislav Hagara | Komentářů: 0
    dnes 12:44 | Komunita

    PHP bylo dlouho distribuováno pod vlastní licencí – s výjimkou částí spadajících pod licenci Zend Engine. Po několikaleté práci se povedlo PHP přelicencovat na 3bodovou licenci BSD.

    Ladislav Hagara | Komentářů: 0
    dnes 05:00 | Komunita

    Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za duben (YouTube). Na Linuxu je vedle Qt frontendu nově k dispozici také GTK4 / libadwaita frontend.

    Ladislav Hagara | Komentářů: 17
    včera 20:22 | IT novinky

    Neziskové průmyslové konsorcium Khronos Group vydalo verzi 3.1 specifikace OpenCL (Open Computing Language). OpenCL je průmyslový standard pro paralelní programování heterogenních počítačových systémů.

    Ladislav Hagara | Komentářů: 0
    včera 13:11 | Nová verze

    Homebridge pro integraci chytrých domácích zařízení byl vydán ve verzi 2.0.0. Nově vedle protokolu HomeKit Accessory Protocol (HAP) podporuje standard chytré domácnosti Matter.

    Ladislav Hagara | Komentářů: 0
    včera 04:11 | Nová verze

    Omarchy je linuxová distribuce s dlaždicovým správcem oken Hyprland. Založena je na Arch Linuxu. Vydána byla v nové verzi 3.7.0 - The Gaming Edition. Z novinek lze vypíchnout příkaz omarchy a celou řadu herních možností.

    Ladislav Hagara | Komentářů: 2
    včera 03:11 | Nová verze

    CyberChef byl vydán v nové major verzi 11. Přehled novinek v Changelogu. CyberChef je webová aplikace pro analýzu dat a jejich kódování a dekódování, šifrování a dešifrování, kompresi a dekompresi, atd. Často je využívaná při kybernetických cvičeních a CTF (Capture the Flag).

    Ladislav Hagara | Komentářů: 0
    4.5. 20:11 | Nová verze

    Byla vydána nová verze 2.4.67 svobodného multiplatformního webového serveru Apache (httpd). Řešeno je mimo jiné 11 zranitelností.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (9%)
     (2%)
     (14%)
     (31%)
     (4%)
     (7%)
     (3%)
     (16%)
     (24%)
    Celkem 1515 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: Zavření non-block socketu během navazování připojení.

    Jardík avatar 25.10.2013 01:15 Jardík | skóre: 40 | blog: jarda_bloguje
    Zavření non-block socketu během navazování připojení.
    Přečteno: 333×
    Mám socket, vytvořený v non-block režimu a na něj zavolám connect(). Ten mi vrátí -1 a errno EINPROGRESS, což znamená, že spojení nemohlo být navázáno okamžitě a bude navázáno později.
    EINPROGRESS
    The socket is nonblocking and the connection cannot be completed immediately. It is possible to select(2) or poll(2) for completion by selecting the socket for writing. After select(2) indicates writability, use getsockopt(2) to read the SO_ERROR option at level SOL_SOCKET to determine whether connect() completed successfully (SO_ERROR is zero) or unsuccessfully (SO_ERROR is one of the usual error codes listed here, explaining the reason for the failure).
    Jde mi o to, jestli je během této doby bezpečné socket zavřít zavoláním close() a jestli bude zavřen buď okamžitě, popř. hned poté, co by bylo navázáno spojení nebo při tom došlo k chybě.
    Věřím v jednoho Boha.

    Řešení dotazu:


    Odpovědi

    25.10.2013 10:37 lofcek
    Rozbalit Rozbalit vše Re: Zavření non-block socketu během navazování připojení.
    Hm .. a co na tom by mohlo byt nebezpecne, pripadne pre koho? Ci myslis, ze ked to urobit vybuchne Temelin?

    Z pohladu tvojho procesu je spojenie ukoncene okamzite. A druhej strane (ak uz nahodou doslo k nadviazaniu) posle kernel notifikaciu (rovnako ako close pri kazdom nadviazanom spojeni). A ked k nadviazaniu nedoslo, tak vlastne nie je koho notifikovat.
    Josef Kufner avatar 25.10.2013 12:15 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Zavření non-block socketu během navazování připojení.
    Je důležité si uvědomit, že TCP garantuje doručení všech dat pouze, pokud bylo spojení korektně uzavřeno. To tedy znamená, že si na aplikační úrovni musíš buď posílat potvrzení (dlouho otevřená spojení) nebo detekovat předčasný konec dat (HTTP-like komunikace).

    TCP ti zaručí, že data přijdou ve správném pořadí, takže stačí poslat vždy jen potvrzení té poslední přijaté zprávy a tím potvrdíš i vše předtím. Toto potvrzování je docela rozumné spojit i s potvrzením zpracování přijatých dat, pokud to zpracování je rychlé. Pro dlouhodobější požadavky pak budeš potvrzovat zahájení zpracování, či zařazení do fronty.

    Spousta protokolů tohle nedělá a pak dochází ke ztrácení či poškozování dat. Například HTTP nekontroluje konec, Jabber ztrácí zprávy v rozpadlých spojeních (XEP 0184 není nedílnou součástí protokolu) a podobně.

    Jakmile budeš mít takovéto jednoduché potvrzování, nemusíš řešit, jak dobře jsi spojení uzavřel a celá tato otázka téměř pozbývá smyslu.
    Hello world ! Segmentation fault (core dumped)
    Řešení 1× (Jardík (tazatel))
    28.10.2013 14:35 luky
    Rozbalit Rozbalit vše Re: Zavření non-block socketu během navazování připojení.
    Jde mi o to, jestli je během této doby bezpečné socket zavřít zavoláním close() a jestli bude zavřen buď okamžitě, popř. hned poté, co by bylo navázáno spojení nebo při tom došlo k chybě.
    Jo, sitova vrstva ma svoji referenci a fyzicky se socket uvolni az navaze spojeni.

    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.