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 23:33 | Nová verze

    Richard Biener oznámil vydání verze 16.1 (16.1.0) kolekce kompilátorů pro různé programovací jazyky GCC (GNU Compiler Collection). Jedná se o první stabilní verzi řady 16. Přehled změn, nových vlastností a oprav a aktualizovaná dokumentace na stránkách projektu. Některé zdrojové kódy, které bylo možné přeložit s předchozími verzemi GCC, bude nutné upravit.

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

    Zulip Server z open source komunikační platformy Zulip (Wikipedie, GitHub) byl vydán ve verzi 12.0. Přehled novinek v příspěvku na blogu.

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

    Před 30 lety, tj. v úterý 30. dubna 1996, byl spuštěn Seznam.cz.

    Ladislav Hagara | Komentářů: 4
    včera 11:44 | Komunita

    Byly zpracovány a zveřejněny všechny videozáznamy, které stojí za zveřejnění, z konference FOSDEM 2026.

    Ladislav Hagara | Komentářů: 0
    včera 01:11 | IT novinky

    Od úterý 28. dubna musí nově uváděné notebooky v Evropské unii podporovat nabíjení přes USB-C. Jednotná nabíječka byla schválena Evropským parlamentem v říjnu 2022.

    Ladislav Hagara | Komentářů: 53
    29.4. 23:44 | Bezpečnostní upozornění

    Byly publikovány informace o kritické zranitelnosti CVE-2026-31431 pojmenované Copy Fail v Linuxu, konkrétně v kryptografii (AF_ALG). Běžný uživatel může získat práva roota (lokální eskalaci práv). Na všech distribucích Linuxu vydaných od roku 2017. Pomocí 732bajtového skriptu. V upstreamu je již opraveno. Zranitelnost byla nalezena pomocí AI Xint Code.

    Ladislav Hagara | Komentářů: 4
    29.4. 17:44 | Nová verze

    Textový editor Zed dospěl do verze 1.0. Představení v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    29.4. 04:44 | Komunita

    Vývojáři svobodného 3D softwaru Blender představili (𝕏, Mastodon, Bluesky) nejnovějšího firemního sponzora Blenderu. Je ním společnost Anthropic stojící za AI Claude a úroveň sponzoringu je Patron, tj. minimálně 240 tisíc eur ročně. Anthropic oznámil sponzorství v tiskové zprávě Claude for Creative Work.

    Ladislav Hagara | Komentářů: 7
    29.4. 03:55 | Nová verze

    VNC server wayvnc pro Wayland kompozitory postavené nad wlroots - ne GNOME, KDE nebo Weston - byl vydán ve verzi 0.10.0. Vydána byla také verze 1.0.0 související knihovny neatvnc.

    Ladislav Hagara | Komentářů: 0
    28.4. 16:22 | Nová verze

    Bylo oznámeno vydání Fedora Linuxu 44. Ve finální verzi vychází šest oficiálních edic: Fedora Workstation a Fedora KDE Plasma Desktop pro desktopové, Fedora Server pro serverové, Fedora IoT pro internet věcí, Fedora Cloud pro cloudové nasazení a Fedora CoreOS pro ty, kteří preferují neměnné systémy. Vedle nich jsou k dispozici také další atomické desktopy, spiny a laby. Podrobný přehled novinek v samostatných článcích na stránkách

    … více »
    Ladislav Hagara | Komentářů: 7
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (8%)
     (2%)
     (13%)
     (31%)
     (3%)
     (6%)
     (3%)
     (15%)
     (24%)
    Celkem 1467 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: Neblokujici operace se socketem

    9.12.2010 12:43 roman
    Neblokujici operace se socketem
    Přečteno: 532×

    Dobry den, trochu si hraji se socketama v linuxu, takovy maly chat jen mezi dvema pocitaci, jednoduse se pripojim k druhemu stroji, ten muze poslat data nebo naopak je mohu poslat ja.

    Mam trochu problem jak do jednoho programu vmesnat i to odesilani, umim prijimat data, cekam v nekonecne smycce a ctu data ze socketu, pokud se nejaka objevi tak je jen zobrazim.

    Lze nejak zaridit neblokujici volani read? Abych mohl dovolit uzivateli v tu chvili i zadavat data, ukoncit enterem a odeslat?

    Nebo lze nejak zaridit, aby se po prichodu dat vyvolava nejaka mnou definovana fce? Nebo treba signal.

    Nebo tuto ulohu musim rozdeli do vlakna ve kterem budu jen cist data ze site a v hlavnim main programu budu cekat na uzivatelsky vstup a ten odesilat do site?

    Jo abych nezapomel, pisu to v jazyce C.

    Dekuji za info jak toto vyresit.

    Odpovědi

    9.12.2010 13:03 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Neblokujici operace se socketem
    Chcete-li neblokující čtení, můžete buď použít příznak O_NONBLOCK rovnou při volání open() nebo ho následně nastavit pomocí fcntl(). U socketu to asi jde jen tím druhým způsobem. Obvykle dávám přednost čtení v samostatném threadu nebo procesu, ale ve vašem případě bude možná neblokující čtení v kombinaci s poll() (nebo select()) jednodušší.
    9.12.2010 14:50 roman
    Rozbalit Rozbalit vše Re: Neblokujici operace se socketem
    Dekuji na informaci, zkusim variantu s vlaknem pro cteni, nebyl by nejaky example?
    9.12.2010 15:03 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Neblokujici operace se socketem
    Příloha:
    Zkuste se podívat do přílohy, jsou tam tři různé implementace serveru pro službu time (nebo daytime, nikdy si nepamatuji, která je která), mp-poll funguje pomocí poll(), mp-fork používá samostatné procesy a mp-thread samostatná vlákna. Není to sice zrovna to, co byste potřeboval (tahle služba od klienta nic nečte), ale třeba vám to k něčemu bude.
    9.12.2010 22:31 roman
    Rozbalit Rozbalit vše Re: Neblokujici operace se socketem
    dekuji mnohokrat, prostuduji to.
    10.12.2010 08:04 Pavel Löbl | skóre: 7 | blog: vadnej_pixel
    Rozbalit Rozbalit vše Re: Neblokujici operace se socketem
    Pouziti select je zde asi fakt jednodussi nez vlakna nebo procesy. Takhle by to mohlo jit, ale netvrdim ze to je nejlepsi reseni :) Je to jen navrh, bylo by asi jeste potreba cekat na konec zpravy (nejaky oddelovac), neni zaruceno ze ji prectete celou jednim volanim recv. atd
    
    int sock;
    
    ...
    
    struct timeval timeout;
    timeout.tv_usec = 0;
    	
    char buffer[BUFFER_SIZE];
    ssize_t ret;
    fd_set sock_set;
    
    FD_ZERO(&sock_set);
    		
    while(1)
    {
      timeout.tv_sec = TIMEOUT;
    
      /* nastaveni deskriptoru ktere budem sledovat */
      FD_SET(sock, &sock_set);
      FD_SET(STDIN_FILENO, &sock_set);	
    
      /* sledovani deskriptoru */		
      if((ret = select(MAX(sock, STDIN_FILENO)+1, &sock_set, 0, 0, &timeout)) == -1)
          /* osetreni chyby */
    
      /* pokud lze cist ze socketu */	
      if(FD_ISSET(sock, &sock_set))
      {
        if((ret = recv(sock, buffer, BUFFER_SIZE, O_NONBLOCK) == -1)
          /* osetreni chyby */
    
        if(ret == 0)
          break;
    			
        if((ret = write(STDOUT_FILENO, buffer, ret)) == -1)
          /* osetreni chyby */
      }		
    
      /* pokud lze cist ze std. vstupu */	
      if(FD_ISSET(STDIN_FILENO, &sock_set))
      {
        if((ret = read(STDIN_FILENO, buffer, BUFFER_SIZE)) == -1)
          /* osetreni chyby */ */
    	
        if(ret == 0)
          break;
    
        if((ret = send(sock, buffer, ret, O_NONBLOCK) == -1)
          /* osetreni chyby */
      }	
    
      ... 
    
    }
    11.12.2010 18:50 Mr.S1lent.cz
    Rozbalit Rozbalit vše Re: Neblokujici operace se socketem
    Co takhle normalne pouzit neblokujici rezim socketu? :-)
    int oldFlag = fcntl( sock_id, F_GETFL, 0 );
    fcntl( sock_id, F_SETFL, oldFlag | O_NONBLOCK );
    
    11.12.2010 19:05 Vojtěch Horký | skóre: 39 | blog: Vojtův zápisník | Praha
    Rozbalit Rozbalit vše Re: Neblokujici operace se socketem
    Viz #1.
    I am always ready to learn although I do not always like to be taught. (W. Churchill)

    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.