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 01:22 | Zajímavý článek

Julia Evans pomocí svých kreslených obrázků proniká do Linuxu a informačních technologií. Vedle ucelených zinů publikuje také jednotlivé kreslené obrázky (RSS).

Ladislav Hagara | Komentářů: 1
včera 13:22 | Zajímavý software

Jordi Sanfeliu vydal verzi 1.0.0 svého unixového jádra Fiwix (Wikipedie) určeného také pro výuku operačních systémů. Dle článku na OSNews na něm začal pracovat již před více než dvaceti lety. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT. Stáhnout a vyzkoušet lze živou disketu nebo CD s GNU/Fiwixem.

Ladislav Hagara | Komentářů: 3
včera 06:00 | Nová verze

Byla vydána nová verze 10.7 open source alternativy GitHubu, tj. softwarového nástroje s webovým rozhraním umožňujícího spolupráci na zdrojových kódech, GitLab (Wikipedie). Představení nových vlastností v příspěvku na blogu. Vývojáři GitLabu zdůrazňují Web IDE (YouTube) a SAST (Static Application Security Testing) pro Go a C/C++.

Ladislav Hagara | Komentářů: 0
22.4. 14:00 | Zajímavý článek

David Revoy, autor open source webového komiksu Pepper&Carrot nebo portrétu GNU/Linuxu, zveřejnil na svém blogu recenzi notebooku Librem 13 od společnosti Purism. Používá jej již sedm měsíců a s ním i jako umělec spokojen. Potřebu francouzské AZERTY klávesnice vyřešil přelepkami. Na displej se podíval kalibrační sondou, barvy vyladil pomocí open source softwaru DisplayCAL, v aplikaci Inkscape nastavil zvětšování na 170 % aby 1 cm v Inkscapu byl 1 cm v reálu. Webovou kameru, mikrofon, Wi-Fi a Bluetooth lze na Librem 13 hardwarově vypnout.

Ladislav Hagara | Komentářů: 7
21.4. 23:44 | Komunita

Několik posledních verzí GNOME Shellu obsahuje chybu způsobující memory leak (únik paměti). Viz například videozáznamy verzí 3.26 nebo 3.28. Nalezení chyby #64 a její opravě se věnuje Georges Basile Stavracas Neto v příspěvku na svém blogu [reddit].

Ladislav Hagara | Komentářů: 1
21.4. 10:33 | Komunita

V pondělí měl na YouTube online premiéru otevřený krátký 2D film Hero vytvořený v 3D softwaru Blender. Cílem stejnojmenného projektu Hero je vylepšit nástroj Grease Pencil (tužka) v Blenderu 2.8.

Ladislav Hagara | Komentářů: 4
20.4. 23:22 | Nová verze

Byla vydána verze 4.0 kolekce svobodného softwaru umožňujícího nahrávání, konverzi a streamovaní digitálního zvuku a obrazu FFmpeg (Wikipedie). Přehled novinek v Changelogu (GitHub).

Ladislav Hagara | Komentářů: 0
20.4. 17:22 | Komunita

Včera vydanou hru Rise of the Tomb Raider pro Linux lze do pondělí 23. dubna koupit na Steamu s 67% slevou. Místo 49,99 € za 16,49 €.

Ladislav Hagara | Komentářů: 0
20.4. 16:11 | Komunita

Na Humble Bundle lze získat počítačovou hru Satellite Reign (Wikipedie, YouTube) běžící také v Linuxu zdarma. Speciální akce končí v sobotu v 19:00.

Ladislav Hagara | Komentářů: 5
20.4. 15:44 | Zajímavý software

Společnost Apple koupila před třemi lety společnost FoundationDB vyvíjející stejnojmenný NoSQL databázový systém FoundationDB (Wikipedie). Včera byl tento systém uvolněn jako open source pod licencí Apache 2.0. Zdrojové kódy jsou k dispozici na GitHubu.

Ladislav Hagara | Komentářů: 0
Používáte na serverech port knocking?
 (2%)
 (7%)
 (46%)
 (27%)
 (17%)
Celkem 362 hlasů
 Komentářů: 29, poslední 5.4. 12:25
    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: 218×
    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: 68
    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.