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 17:33 | IT novinky

    Americký prezident Donald Trump vyzval nového generálního ředitele firmy na výrobu čipů Intel, aby odstoupil. Prezident to zdůvodnil vazbami nového šéfa Lip-Bu Tana na čínské firmy.

    Ladislav Hagara | Komentářů: 6
    včera 16:55 | Nová verze

    Bylo vydáno Ubuntu 24.04.3 LTS, tj. třetí opravné vydání Ubuntu 24.04 LTS s kódovým názvem Noble Numbat. Přehled novinek a oprav na Discourse.

    Ladislav Hagara | Komentářů: 0
    včera 16:44 | Nová verze

    Byla vydána verze 1.89.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

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

    Americká technologická společnost Apple uskuteční v USA další investice ve výši sta miliard dolarů (2,1 bilionu korun). Oznámil to ve středu šéf firmy Tim Cook při setkání v Bílém domě s americkým prezidentem Donaldem Trumpem. Trump zároveň oznámil záměr zavést stoprocentní clo na polovodiče z dovozu.

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

    Zálohovací server Proxmox Backup Server byl vydán v nové stabilní verzi 4.0. Založen je na Debianu 13 Trixie.

    Ladislav Hagara | Komentářů: 0
    6.8. 16:33 | Nová verze

    Byla vydána nová verze 1.54.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 Jan Václav.

    Ladislav Hagara | Komentářů: 0
    6.8. 14:11 | IT novinky

    Knižní edice správce české národní domény přináší novou knihu zkušeného programátora Pavla Tišnovského s názvem Programovací jazyk Go. Publikace nabízí srozumitelný a prakticky zaměřený pohled na programování v tomto moderním jazyce. Nejedná se však o klasickou učebnici, ale spíše o průvodce pro vývojáře, kteří s Go začínají, nebo pro ty, kdo hledají odpovědi na konkrétní otázky či inspiraci k dalšímu objevování. Tištěná i digitální verze knihy je již nyní k dispozici u většiny knihkupců.

    Ladislav Hagara | Komentářů: 2
    6.8. 13:11 | IT novinky

    OpenAI zpřístupnila (en) nové nenáročné otevřené jazykové modely gpt-oss (gpt-oss-120b a gpt-oss-20b). Přístupné jsou pod licencí Apache 2.0.

    Ladislav Hagara | Komentářů: 5
    6.8. 04:33 | Nová verze

    Byla vydána RC verze openSUSE Leap 16. S novým instalátorem Agama, Xfce nad Waylandem a SELinuxem.

    Ladislav Hagara | Komentářů: 0
    6.8. 03:44 | Nová verze

    Google Chrome 139 byl prohlášen za stabilní. Nejnovější stabilní verze 139.0.7258.66 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 12 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře. S verzí 139 přestal být podporován Android 8.0 (Oreo) a Android 9.0 (Pie).

    Ladislav Hagara | Komentářů: 0
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (41%)
     (23%)
     (4%)
     (6%)
     (3%)
     (1%)
     (1%)
     (20%)
    Celkem 277 hlasů
     Komentářů: 23, poslední 4.8. 13:01
    Rozcestník

    Dotaz: Neblokujici operace se socketem

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

    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: 72 | 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: 72 | 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.