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 15:44 | Humor

    Český úřad zeměměřický a katastrální zavedl u anonymního nahlížení do katastru nemovitostí novou CAPTCHA ve formě mapové puzzle: nepřihlášení uživatelé musí nově správně otočit devět dlaždic v 3x3 poli tak, aby dohromady daly souvislý obrázek výseče reálné mapy, přičemž na to mají pouze jeden časově omezený pokus. Test je podle uživatelů i odborníků příliš obtížný a na sociálních sítích pochopitelně schytává zaslouženou kritiku a

    … více »
    » FIDESZ🧡! « | Komentářů: 5
    dnes 15:33 | Nová verze

    Byla vydána verze 1.95.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
    dnes 15:22 | Zajímavý software

    Mozilla prostřednictvím své dceřiné společnosti MZLA Technologies Corporation představila open-source AI klienta Thunderbolt. Primárně je určený pro firemní nasazení.

    Ladislav Hagara | Komentářů: 0
    dnes 14:00 | IT novinky

    Firma Cal.com oznámila, že přesouvá svůj produkční kód z otevřeného do uzavřeného repozitáře z důvodu bezpečnostního rizika umělé inteligence, která prý dokáže vyhledávat a zneužívat zranitelnosti rychleji, než by je jejich vývojářský tým stíhal opravovat. Zároveň zveřejnila samostatnou, open-source verzi Cal.diy pod licencí MIT, ovšem bez řady původních funkcí. O tom, zda je toto opatření rozumné, existují pochyby. … více »

    » FIDESZ🧡! « | Komentářů: 5
    dnes 13:55 | Nová verze

    Vývojáři KDE na Mastodonu oznámili vydání balíku aplikací KDE Gear 26.04. Přehled novinek i s náhledy a videi v oficiálním oznámení.

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

    Kryptografická knihovna OpenSSL byla vydána v nové verzi 4.0. Přehled změn v souboru CHANGES.md na GitHubu. Odstraněna byla podpora SSLv2 Client Hello a SSLv3. Ve výchozím nastavení byla zakázána podpora odmítnutých eliptických křivek v TLS dle RFC 8422. Přibyla například podpora Encrypted Client Hello (ECH, RFC 9849).

    Ladislav Hagara | Komentářů: 0
    včera 20:55 | Komunita

    curl up 2026, tj. setkání vývojářů a uživatelů curlu, proběhne opět v Praze. O víkendu 23. a 24. května v Pracovně.

    Ladislav Hagara | Komentářů: 0
    včera 15:55 | IT novinky

    Aplikace pro ověřování věku uživatelů on-line platforem je technicky hotová a brzy bude k dispozici pro občany EU, oznámila dnes předsedkyně Evropské komise Ursula von der Leyenová. Půjde podle ní o bezplatné a snadno použitelné řešení, které pomůže chránit děti před škodlivým a nelegálním obsahem. Aplikace bude podle ní fungovat na jakémkoli zařízení a bude zcela anonymní.

    Ladislav Hagara | Komentářů: 14
    včera 04:33 | Komunita

    V prosinci 2012 byla z linuxového jádra odstraněna podpora procesorů 386. Včera započalo odstraňování podpory procesorů 486.

    Ladislav Hagara | Komentářů: 5
    včera 01:33 | IT novinky

    IuRe (Iuridicum Remedium) vyhlásila Ceny Velkého bratra za rok 2025. Slídily roku jsou automobilka Volkswagen, Meta a česká Ministerstva vnitra a průmyslu a obchodu. Autorem Výroku Velkého bratra je dánský ministr spravedlnosti zpochybňující právo na šifrovanou komunikaci. Naopak Pozitivní cenu získali studenti Masarykovy univerzity za odpor proti nucení do používaní aplikace ISIC.

    |🇵🇸 | Komentářů: 3
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (8%)
     (1%)
     (12%)
     (30%)
     (3%)
     (6%)
     (2%)
     (15%)
     (25%)
    Celkem 1340 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: Systemovy daemon pomoci select()

    tomes.io avatar 24.1.2014 17:41 tomes.io | skóre: 12 | blog: tomesh
    Systemovy daemon pomoci select()
    Přečteno: 278×
    Ahoj,

    mam za ukol napsat daemona v C jako takovou nahradu za syslog.

    Daemon přijímá data z pojmenované roury, zapisovat do tohoto souboru smí kdokoliv. Prvním parametrem daemona je název souboru, do kterého bude zapisovat události ve tvaru
    time caller: message
    A dale vytvorit knihovnu s funkcí pro zápis do této roury. dalším parametrem daemona je interval, ve kterém daemon zapisuje vlastní statistiku (počet obdržených zpráv) do syslogu.

    Daemon jsem napsal pomoci fce select(), ale nemuzu odstranit chybu, ktera spociva v ukonceni programu pote, co si precte prvni zpravu z roury a korektne ji zapise do zadaneho logu.

    V nasledujicim prubehu WHILE funkce select vrati hodnotu vetsi nez nula, jakoby dosla dalsi zprava, ale funkce read vrati nulu. Zajimalo by me, kde je chyba. Je to nekde v souboru s rourou, nebo v samotnem spatnem pouziti select ?

    Kod daemona:
    /*
     
    #define DEFAULT_INTERVAL 2
    #define SIZE 256
    
    char* get_current_time() {
    
        
            time_t current_time;
            char* c_time_string;
            int j;
            current_time = time(NULL); /* Obtain current time as seconds elapsed since the Epoch. */
     
            if (current_time == ((time_t)-1)) {
                
                    (void) fprintf(stderr, "Failure to compute the current time.");
                    exit(EXIT_FAILURE);
            }
                           
            c_time_string = ctime(¤t_time);  /* Convert to local time format. */
                                                   
            for ( j = 0; c_time_string[j] != '\n'; j++)  /*Get rid EOL*/
                                    ;                          
            c_time_string[j] = '\0';
     
            if (c_time_string == NULL) {
                
                    (void) fprintf(stderr, "Failure to convert the current time.");
                    exit(EXIT_FAILURE);
            }
            
            return c_time_string;   
    }
    
    void print_help() {
    
            printf("Programme must be run with with 2 arguments:\n"
                "argv[1] is a name of the file which the daemon wil be writting in\n"
                "argv[2] is an interval the daemon will be sending logs into syslog\n");
    }
    
    int main(int argc, char *argv[]) {
    
            if (argc != 3) {
        
                    print_help();
                    exit(1);
            }
            
            int c;
            while((c = getopt(argc, argv, "h")) != -1) {
    
                    switch (c) {
    
                    case 'h':
                            print_help();
                            break;
                            
                    case '?':
                            printf("try -h for help");
                            break;
                    default:
                        break;
                    }
    
            }
        
    
            FILE *fw;
            int fp;
            char buf[SIZE];
        char *linesep;
            int line, i, count; 
            buf[0] = '\0'; // in case there is nothing to read
            buf[SIZE] = '\0'; // guarentee a end-of-line
            fd_set readfds;
            struct timeval timeout;
            int r;
            int interval = atoi(argv[2]);
        openlog ("exampleprog", LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1);
            
        fprintf(stderr, "Daemonizing...\n");    
        //daemon(0,0);
    
        unlink("/tmp/pb173_syslog");
            mkfifo("/tmp/pb173_syslog", S_IWUSR | S_IRUSR | S_IRGRP | S_IROTH);
        
            fp = open("/tmp/pb173_syslog", O_RDONLY | O_NONBLOCK);
    
            if(fp == -1) {
            syslog (LOG_CRIT, "Could not open the pipe: %s\n", strerror(errno));
                    exit(1);
            }
    
        fw = fopen(argv[1], "a+");
    
            if(fw == NULL) {
            openlog ("exampleprog", LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1);
            syslog (LOG_CRIT, "Error openning logfile : %s\n", strerror(errno));
                    exit(1);
            }
    
            
            timeout.tv_sec = interval; 
            timeout.tv_usec = 0;
            count = 0;
           
        line = 0; 
        r = 0;
            while(1) {        
            FD_ZERO(&readfds);
            FD_SET(fp,&readfds);
                    r = select(fp+1, &readfds, NULL, NULL, &timeout);
            if (r == -1) {
                openlog ("daemon", LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1);
                syslog (LOG_CRIT, "Error openning logfile : %s\n", strerror(errno));
                close(fp);
                fclose(fw);
                exit(1);
            }
                if (r == 0) {
                timeout.tv_sec = interval;
                timeout.tv_usec = 0;
                setlogmask (LOG_UPTO (LOG_NOTICE));    
                            openlog ("daemon", LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1);
                            syslog (LOG_NOTICE, "Number of received messages: %d\n", count ); 
                            closelog ();        
            } else {
                line += (r = read(fp, buf+line, SIZE-line-1));
                if (r == 0) {
                    close(fp);
                    fclose(fw);
    
                    exit(EXIT_SUCCESS);
                }
                buf[line] = '\0';
    
                if (line && (linesep = strstr(buf, "\n"))) { 
                    *linesep = '\0';
                    char *caller;
                    int callerLength;
                    char *message;
                    caller = strtok(buf, "^");
                    callerLength = strlen(caller);
                    message = caller + callerLength + 1;
                    fprintf(fw, "%s %s: %s\n", get_current_time(), caller, message);
                    fflush(fw);
                    memmove(buf, linesep + 1, (line = strlen(linesep + 1)) + 1);                
                    count++;
                        }
                    }       
            }
            
            close(fp);
            fclose(fw);
    
            exit(EXIT_SUCCESS);
    }
    
    
    A kod funkce, ktera zapisuje do roury:
    
    int sl_log(const char *caller, const char* message) {
        
        int fp;
        fp = open("/tmp/pb173_syslog", O_WRONLY);
        char *msg;
    
        if (fp == -1) {
            perror("Could not open the pipe\n");
            exit(1);
        }
        
        asprintf(&msg, "%s^%s\n", caller, message);
        write(fp, msg, strlen(msg));
        free(msg);
        close(fp);
        return 0;
    } 
    

    Řešení dotazu:


    Odpovědi

    Josef Kufner avatar 25.1.2014 00:22 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Systemovy daemon pomoci select()
    Popisované chování odpovídá tomu, že rouru nezavíráš. Jakmile ti odesílatel zapíše do roury data a zavře ji, tak ji musí zavřít i příjemce. Pokud chce čekat na další data, musí ji znovu otevřít. Takže jakmile ti read vrátí nulu (konec souboru), tak rouru zavři a znovu otevři. Konec souboru je také důvod, proč select oznamuje aktivitu na filedeskriptoru.

    V praktické aplikaci pak raději použij unixový socket. Ten je narozdíl od rour na tento use-case stavěný.
    Hello world ! Segmentation fault (core dumped)
    tomes.io avatar 25.1.2014 17:59 tomes.io | skóre: 12 | blog: tomesh
    Rozbalit Rozbalit vše Re: Systemovy daemon pomoci select()
    Diky za vysvetleni, ted uz to pracuje jak ma.

    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.