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 04:11 | Komunita

    V Berlíně probíhá konference vývojářů a uživatelů desktopového prostředí KDE Plasma Akademy 2025. Při té příležitosti byla oznámena alfa verze nové linuxové distribuce KDE Linux.

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

    Byl vydán Debian 13.1, tj. první opravná verze Debianu 13 s kódovým názvem Trixie a Debian 12.12, tj. dvanáctá opravná verze Debianu 12 s kódovým názvem Bookworm. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 13 a Debianu 12 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.

    Ladislav Hagara | Komentářů: 2
    5.9. 23:44 | IT novinky

    Evropská komise potrestala Google ze skupiny Alphabet pokutou 2,95 miliardy eur (71,9 miliardy Kč) za porušení antimonopolní legislativy. Podle EK, která mimo jiné plní funkci antimonopolního orgánu EU, se Google dopustil protisoutěžních praktik ve svém reklamním byznysu. Google v reakci uvedl, že rozhodnutí považuje za chybné a hodlá se proti němu odvolat. EK ve věci rozhodovala na základě stížnosti Evropské rady vydavatelů. Podle

    … více »
    Ladislav Hagara | Komentářů: 18
    5.9. 23:11 | Komunita

    Podpora 32bitového Firefoxu pro Linux skončí v roce 2026. Poslední podporované 32bitové verze budou Firefox 144 a Firefox 140 s rozšířenou podporou, jehož podpora skončí v září 2026.

    Ladislav Hagara | Komentářů: 3
    5.9. 19:33 | IT novinky

    Společnost Raspberry Pi nově nabízí Raspberry Pi SSD s kapacitou 1 TB za 70 dolarů.

    Ladislav Hagara | Komentářů: 7
    5.9. 15:55 | Zajímavý software

    Microsoft BASIC pro mikroprocesor 6502 byl uvolněn jako open source. Zdrojový kód je k dispozici na GitHubu.

    Ladislav Hagara | Komentářů: 9
    5.9. 15:33 | IT novinky

    Národní úřad pro kybernetickou a informační bezpečnost (NÚKIB) se připojil k dokumentu „A Shared Vision of Software Bill of Materials (SBOM) for Cybersecurity“, který vydala americká Agentura pro kybernetickou a infrastrukturní bezpečnost (CISA) s Národní bezpečnostní agenturou (NSA), spolu s dalšími mezinárodními partnery. Dokument vznikl v rámci globálního expertního fóra pro SBOM, které má za cíl motivovat k širšímu využívání … více »

    Ladislav Hagara | Komentářů: 3
    4.9. 21:22 | IT novinky

    Švýcarská AI centra EPFL, ETH Zurich a CSCS představila otevřený vícejazyčný velký jazykový model (LLM) s názvem Apertus. Vyzkoušet lze na stránce Public AI Inference Utility.

    Ladislav Hagara | Komentářů: 27
    4.9. 17:22 | Nová verze

    Byl vydán Linux Mint 22.2 s kódovým jménem Zara. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze novou XApp aplikaci Fingwit pro autentizaci pomocí otisků prstů nebo vlastní fork knihovny libAdwaita s názvem libAdapta podporující grafická témata. Linux Mint 22.2 bude podporován do roku 2029.

    Ladislav Hagara | Komentářů: 2
    4.9. 12:55 | IT novinky

    Čínská společnost Tencent uvolnila svůj AI model HunyuanWorld-Voyager pro generování videí 3D světů z jednoho obrázku a určené trajektorie kamery. Licence ale nedovoluje jeho používání na území Evropské unie, Spojeného království a Jižní Koreje.

    Ladislav Hagara | Komentářů: 1
    Pro otevření více webových stránek ve webovém prohlížečí používám
     (83%)
     (7%)
     (2%)
     (3%)
     (3%)
     (2%)
    Celkem 151 hlasů
     Komentářů: 11, poslední 4.9. 16:12
    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: 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.