abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 23:11 | Bezpečnostní upozornění

    Intel vydal 41 upozornění na bezpečnostní chyby ve svých produktech. Současně vydal verzi 20240514 mikrokódů pro své procesory řešící INTEL-SA-01051, INTEL-SA-01052 a INTEL-SA-01036.

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

    Společnost Raspberry Pi patřící nadaci Raspberry Pi chystá IPO a vstup na Londýnskou burzu.

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

    Google na své vývojářské konferenci Google I/O 2024 představil řadu novinek. Keynote byl věnován umělé inteligenci (DeepMind, Gemini, Responsible AI).

    Ladislav Hagara | Komentářů: 1
    včera 12:33 | Bezpečnostní upozornění

    V Gitu bylo nalezeno 5 zranitelností. Opraveny jsou ve verzích 2.45.1, 2.44.1, 2.43.4, 2.42.2, 2.41.1, 2.40.2 a 2.39.4. Útočník může připravit repozitář tak, že při jeho klonování (git clone) může dojít ke spuštění libovolného kódu.

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

    Virtualizační softwary VMware Workstation Pro a VMware Fusion Pro jsou nově pro osobní použití zdarma. Softwary VMware Workstation Player a VMware Fusion Player končí.

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

    Linuxová distribuce Endless OS (Wikipedie) byla vydána ve verzi 6.0.0. Přehled novinek i s náhledy v příspěvku na blogu, poznámkách k vydání a také na YouTube.

    Ladislav Hagara | Komentářů: 0
    14.5. 15:44 | Nová verze

    Byl vydán Mozilla Firefox 126.0. Přehled novinek v poznámkách k vydání, poznámkách k vydání pro firmy a na stránce věnované vývojářům. Vylepšena byla funkce "Zkopírovat odkaz bez sledovacích prvků". Přidána byla podpora zstd (Zstandard). Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 126 je již k dispozici také na Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    14.5. 15:22 | Nová verze

    Grafana (Wikipedie), tj. open source nástroj pro vizualizaci různých metrik a s ní související dotazování, upozorňování a lepší porozumění, byla vydána ve verzi 11.0. Přehled novinek v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 0
    14.5. 14:55 | Nová verze

    Byla vydána nová verze 24.0 linuxové distribuce Manjaro (Wikipedie). Její kódové jméno je Wynsdey. Ke stažení je v edicích GNOME, KDE PLASMA a XFCE.

    Ladislav Hagara | Komentářů: 2
    14.5. 13:00 | Nová verze

    Byla představena oficiální rozšiřující deska Raspberry Pi M.2 HAT+ pro připojování M.2 periferii jako jsou NVMe disky a AI akcelerátory k Raspberry Pi 5. Cena je 12 dolarů.

    Ladislav Hagara | Komentářů: 2
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (74%)
     (5%)
     (10%)
     (10%)
    Celkem 279 hlasů
     Komentářů: 16, poslední 14.5. 11:05
    Rozcestník

    Dotaz: UDP sockety thready, C++

    Beda0 avatar 29.1.2014 20:00 Beda0 | skóre: 29
    UDP sockety thready, C++
    Přečteno: 312×

    Zdravím.
    mám třídu (Odesilatel), která má simulovat přístroj - posílá data po UDP na danou ip po daném portu - konkrétním na 127.0.0.1:2023

    Druhá (Prijemce) třída přijímá data po UDP na danym portu (odkukoliv), zpracuje je (udělá z nich floaty) a uloží do bufferu.

    Pokud je simulátor puštěnej z jinýho programu než příjemce, vše funguje. Pokud jsou puštěny z jednoho, tak se přijme jen 92 packetů, pak jich to 260 přeskočí (+- 20, tehnle počet se mění, ale 92 jich to přijme vždy a 93 už je posunutej) a pak to zase přijímá normálně - další stovky packetů (nebo to občas začne zase přeskakovat).

    Odesilatel a příjemce jsou ve vlastních threadech. Wireshark říká, že odesilatel odešle data správně, při krokování je vidět, že příjemce je už v int size = read(socketDesc, data, 65535); dostane přeskonečené. Trápim se s tim celý den a nemam ponětí, co dělám špatně.

    Pokud nepošlu 981bytů, ale míň, tak to funguje normálně (asi by to začlo přeskakovat někde dál), takže předpokldám, že se něco někam nevejde, ale nemůžu přijít na to co/kam. Vidíte v tom někdo nějakou botu?

    
    Projemce p;
    Odesilatel o;
    o.start();
    p.startReadData();
    while(1){
       if(m.dataLength() > 0){
          Data<float> d = p.getData();
          for(int y = 0;y<d.length();y++)
             fprintf(outF,"%f;%f\n",...);//vypis dat do souboru  
       }
    }
    Prijemce:
    
    Prijemce::Prijemce(){
       socketDesc = socket( AF_INET, SOCK_DGRAM, IPPROTO_UDP );
       sockaddr_in serverSock;
       serverSock.sin_family = AF_INET;
       serverSock.sin_addr.s_addr = htonl(INADDR_ANY);
       serverSock.sin_port = htons(2023);
       bind( socketDesc, (const sockaddr*) &serverSock, sizeof(serverSock) );
    }
    void Prijemce::startReadData(){
     th = new std::thread(&MeterUDP::readPackets,this);
    }
    Data<float> Prijemce:getData(){
       mutex.lock();
       Data<float> ret = dataBuffer;
       dataBuffer.clear();
       mutex.unlock();
       return ret;
    }
    void Prijemce::readPackets(){
    
    ByteArray *bA;
       while(1){
          fd_set fds;
          timeval tv;
          FD_ZERO(&fds);
          FD_SET(socketDesc, &fds);
          tv.tv_sec = 1; 
          tv.tv_usec = 0;
    
          u8 data[65535];
          int test = 0;
          int ret = select(socketDesc+1, &fds, NULL, NULL, &tv); 
          if(ret == 1){
          int size = read(socketDesc, data, 65535);
          Bytes b;
          b.insert(b.end(),data,data+size);
          bA = new ByteArray(b);
          }
       }
       Data<float> dataBuffer = kouzla(bA);//konertuje ByteArray do pouzitelnyho formatu
    }
    Odesilatel:
    
    Odesilatel::Odesilatel(){
       sockfd = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP)
       bzero(&serv_addr, sizeof(serv_addr));
       serv_addr.sin_family = AF_INET;
       serv_addr.sin_port = htons(2023);
       net_aton("127.0.0.1", &serv_addr.sin_addr)
    }
    void Odesilatel::start(){
       th = new std::thread(&Odesilatel::sendData,this);
    }
    void Odesilatel::sendData(){
       while(1){
       u8 packet[981];
       for(int i = 0;i<981;i++)
          packet[i] = data;//tady naplnim data (ze souboru, ale to neni podstatny)
       sendto(sockfd, packet, 981, 0, (struct sockaddr*)&serv_addr, slen);
       }
    }

    Řešení dotazu:


    Odpovědi

    29.1.2014 20:17 Sten
    Rozbalit Rozbalit vše Re: UDP sockety thready, C++
    UDP je nezaručená komunikace, pakety nemusí dorazit nebo je může systém zahodit, protože je nečtete dostatečně rychle
    Beda0 avatar 29.1.2014 21:25 Beda0 | skóre: 29
    Rozbalit Rozbalit vše Re: UDP sockety thready, C++
    Teď si připadám jako blb. Tohle mě napadlo už na začátku a skoušel jsem zpomlovat zápis pomocí usleep(...) ale bezvýsledně. Teď jsem dal natvrdo za každý odeslaný packet usleep a funguje to... ale nechápu, proč to ve dvou aplikacích stíhá zapisovat i číst, ale v jedné ne. Přitom thready se použití i se dvěma aplikacemi.
    Aleš Janda avatar 29.1.2014 22:30 Aleš Janda | skóre: 23 | blog: kýblův blog | Praha
    Rozbalit Rozbalit vše Re: UDP sockety thready, C++
    Zřejmě plánovač tvého jádra rozhazuje vlákna jinak, když je to jedna nebo více aplikací.

    Je nějaký důvod, proč nepoužít TCP?
    Beda0 avatar 30.1.2014 06:08 Beda0 | skóre: 29
    Rozbalit Rozbalit vše Re: UDP sockety thready, C++
    Simuluje to komunikaci s přístrojem, který posílá data po UDP - bude to fungovat pouze po velmi jednoduché lokální síti, většinou jen "síť" mezi dvěma zařízeními, takže ztrácení packetů po cestě nehrozí. Je požadovaná rychlost, TCP má zbytečně velkou režii, UDP prostě tlačí data na požadovaný port a ip a je jedno, jestli někdo ty packety chytá nebo ne, to s TCP nejde, protože je spojový.
    30.1.2014 00:06 Sten
    Rozbalit Rozbalit vše Re: UDP sockety thready, C++
    Tipuji, že odesílatel stihne zapsat příliš mnoho paketů ještě předtím, než se příjemce stihne spustit. Zkuste spustit nejdříve příjemce.
    Beda0 avatar 30.1.2014 06:16 Beda0 | skóre: 29
    Rozbalit Rozbalit vše Re: UDP sockety thready, C++
    Jo, tak teď si připadá jako úpnej blb. Tohle mě taky napadlo už na začátku, ale nevim, proč jsem to jen nepřehoadil a místo toho tam cpal nějaký usleep... prohodil jsem pořadí Odesilatel a Prijemce, vyhodil vsechny usleep a funguje to, díky.

    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.