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 18:22 | IT novinky

    V uplynulých dnech byla v depu Českých drah v Brně-Maloměřicích úspěšně dokončena zástavba speciální antény satelitního internetu Starlink od společnosti SpaceX do jednotky InterPanter 660 004 Českých drah. Zástavbu provedla Škoda Group. Cestující se s InterPanterem, vybaveným vysokorychlostním satelitním internetem, setkají například na linkách Svitava Brno – Česká Třebová – Praha nebo Moravan Brno – Břeclav – Přerov – Olomouc.

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

    Byla vydána nová verze 8.7.0 správce sbírky fotografií digiKam (Wikipedie). Přehled novinek i s náhledy v oficiálním oznámení (NEWS). Nejnovější digiKam je ke stažení také jako balíček ve formátu AppImage. Stačí jej stáhnout, nastavit právo ke spuštění a spustit.

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

    Před 30 lety, k 1. 7. 1995, byl v ČR liberalizován Internet - tehdejší Eurotel přišel o svou exkluzivitu a mohli začít vznikat první komerční poskytovatelé přístupu k Internetu [𝕏].

    Ladislav Hagara | Komentářů: 5
    včera 11:33 | Nová verze

    Byla vydána (𝕏) nová verze 7.4 open source monitorovacího systému Zabbix (Wikipedie). Přehled novinek v oznámení na webu, v poznámkách k vydání a v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 0
    včera 05:44 | Bezpečnostní upozornění

    Balíček s příkazem sudo byl vydán ve verzi 1.9.17p1. Řešeny jsou zranitelnosti CVE-2025-32462 (lokální eskalace práv prostřednictvím volby host) a CVE-2025-32463 (lokální eskalace práv prostřednictvím volby chroot).

    Ladislav Hagara | Komentářů: 6
    včera 05:22 | IT novinky

    Do služeb Seznam.cz se lze nově přihlásit pomocí služby MojeID [𝕏].

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

    Bezpečnostní výzkumníci zveřejnili informace o osmi zranitelnostech, které postihují více než 700 modelů tiskáren, skenerů a štítkovačů značky Brother. Bezpečnostní upozornění vydali také další výrobci jako Fujifilm, Ricoh, Konica Minolta a Toshiba. Nejzávažnější zranitelnost CVE-2024-51978 umožňuje útočníkovi vzdáleně a bez přihlášení získat administrátorská oprávnění prostřednictvím výchozího hesla, které lze odvodit ze

    … více »
    Ladislav Hagara | Komentářů: 0
    30.6. 16:00 | Komunita

    Společnost Oracle vlastní ochrannou známku JAVASCRIPT. Komunita kolem programovacího jazyka JavaScript zastoupena společností Deno Land vede právní bitvu za její osvobození, viz petice a otevřený dopis na javascript.tm. Do 7. srpna se k nim má vyjádřit Oracle (USPTO TTAB).

    Ladislav Hagara | Komentářů: 6
    30.6. 13:11 | IT novinky

    Byl představen samostatný rádiový modul Raspberry Pi Radio Module 2 s Wi-Fi a Bluetooth.

    Ladislav Hagara | Komentářů: 6
    30.6. 12:44 | Upozornění

    Certifikační autorita Let’s Encrypt ukončila k 4. červnu zasílání e-mailových oznámení o vypršení platnosti certifikátů. Pokud e-maily potřebujete, Let’s Encrypt doporučuje některou z monitorovacích služeb.

    Ladislav Hagara | Komentářů: 0
    Jaký je váš oblíbený skriptovací jazyk?
     (59%)
     (28%)
     (7%)
     (2%)
     (0%)
     (1%)
     (3%)
    Celkem 337 hlasů
     Komentářů: 16, poslední 8.6. 21:05
    Rozcestník

    Administrace komentářů

    Jste na stránce určené pro řešení chyb a problémů týkajících se diskusí a komentářů. Můžete zde našim administrátorům reportovat špatně zařazenou či duplicitní diskusi, vulgární či osočující příspěvek a podobně. Děkujeme vám za vaši pomoc, více očí více vidí, společně můžeme udržet vysokou kvalitu AbcLinuxu.cz.

    Příspěvek
    2.11.2004 13:23 gogo
    Rozbalit Rozbalit vše Re: Rotovani Apache Logu

    jo. stop posle pouze signal a na poravdu pretizenych servrech to muze trvat i nekolik vterin, nez skonci vsechny httpd procesy. cronolog mi jeste porad nevyhovoval, tak jsem misto toho sesmolil (pouzivame to uz pres rok) todle: -u include chybi < > protoze se me s tim nechtelo prepisovat HOWG. -

    #define	_GNU_SOURCE
    #include stdio.h
    #include time.h
    #include string.h
    #include unistd.h
    #include sys/types.h
    #include sys/stat.h
    #include fcntl.h
    #include sys/time.h
    #include errno.h
    #include stdlib.h
    
    #define	DEBUG	fprintf
    
    
    extern int errno;
    
    static int log= -1;
    static char *jmeno=NULL;
    static char *webal=NULL;
    static int firstmem=1;
    char last='\n';
    int findnewline=0;
    
    
    int newlinereset(void);
    void cas(struct tm *plogtime);
    void konci( int);
    void linkwebal(struct tm *caslogu, char *webal, char *prefix);
    void pojmenuj(struct tm *caslogu, char *prefix);
    void otevri( char *jmeno, char *param);
    
    
    int main(int argc, char **argv)
    {
    	struct tm caslogu, casted;
    	struct stat staty;
    	
    	char buff[4096];
    	int ret;
    
    	buff[0]='\0';
    
    	/* neblokuj pri cteni vstupu */
    	fcntl( fileno(stdin), O_NONBLOCK);
    	
    	/* kontrola parametru */
    	if ( argc!=2) {
    		DEBUG(stderr, "spatny pocet argumentu\n");
    		konci(1);
    	}
    
    	/* webalizerovy link */
    	ret= strlen("webalizer") + strlen( argv[1]);
    	webal= malloc( ret+1);
    	strcpy( webal, argv[1]);
    	strcat( webal, "webalizer" );
    	DEBUG( stderr, "%s\n", webal);
    
    	/* vnejsi cyklus, ktery se stara o soubory */
    	do {
    		/* nacti cas */
    		cas(&caslogu);
    		/* vytvor link pro webalizer */
    		linkwebal( &caslogu, webal, argv[1]);
    		/* vytvor jmeno */
    		pojmenuj(&caslogu, argv[1]);
    		/* otevri log soubor */
    		otevri( jmeno, argv[1]);
    
    		/* vnitrni cyklus ktery se stara o cteni a preruseni jen na \n */
    		do {
    			/* smazany log? */
    			ret=stat(jmeno, &staty);
    			if (0!=ret) {
    				DEBUG(stderr, "nekdo smazal soubor? chyba stat(): %s\n",
    						strerror(errno));
    				if (newlinereset()) break;
    			}
    
    			/* kontrola casu */
    			cas(&casted);
    
    			/* zmena dne je zmena logu (na konci radky) */
    			if (caslogu.tm_yday!= casted.tm_yday) {
    				DEBUG(stderr, "zmena casu. bude se menit soubor\n");
    				if (newlinereset()) break;
    			}
    
    			if ( strlen(buff)) {
    				if (strlen(buff)!= write(log, buff, strlen(buff))) {
    					konci(3);
    				} else {
    					last= buff[strlen(buff)-1];
    				}
    			}
    		} while ( !feof(stdin) && !ferror(stdin) &&
    			fgets(buff, sizeof(buff), stdin)!=NULL);
    
    	} while ( !feof(stdin) && !ferror(stdin));
    	/* nikdy */
    	close( log);
    	free(jmeno);
    	return(0);
    }
    
    
    /* korektne skonci */
    void konci(int kod)
    {
    	if (log>=0) close(log);
    	if (!firstmem && NULL!=jmeno) free(jmeno);
    	exit(kod);
    }
    
    /* nacti cas */
    void cas(struct tm *plogtime)
    {
    	time_t ted= time(NULL);
    	localtime_r( &ted, plogtime);
    }
    
    /* vytvor link pro webalizer */
    void linkwebal(struct tm *caslogu, char *webal, char *prefix)
    {
    	int ret;
    	struct tm oldlogtime;
    	struct stat wstaty;
    	time_t vcera= time(NULL) - 86400;
    
    	/* zkontroluj existenci "webalizer" hardlinku */
    	ret=stat( webal, &wstaty);
    	if ( ret && !ENOENT== errno) perror("webalizer link - stat");
    	
    	/* pokud existuje, tak jej odstran */
    	if (( 0== ret) || (! ENOENT== errno)) {
    		if ( (0== ret) || (-1 == ret && (! ENOENT== errno))) {
    			ret= unlink( webal);
    			if (ret) perror("webalizer link - unlink");
    		}
    	}
    
    	/* pokud je to po stratu, tak vyrob jmeno z minuleho dne */
    	if ( NULL== jmeno) {
    		localtime_r( &vcera, &oldlogtime);
    		pojmenuj( &oldlogtime, prefix);
    	}
    
    	/* pokud existuje, tak proved hardlink */
    	ret= stat( jmeno, &wstaty);
    	if (! ret) {
    		ret= link( jmeno, webal);
    		if ( ret) perror("webalizer link - link");
    	}
    }
    
    /* vytvor jmeno z casu */
    void pojmenuj(struct tm *caslogu, char *prefix)
    {
    	int delka, cela;
    	char strcas[10];
    
    	if (8!=strftime( strcas, 9, "%Y%m%d", caslogu)) {
    		DEBUG(stderr, "spatna delka prevedeneho casu\n");
    		konci(2);
    	}
    	strcas[8]='\0';
    
    	/* vyrob jmeno logu */
    	delka= strlen(prefix);
    	cela= delka+ strlen(strcas)+ 1;
    	if (firstmem) {
    		jmeno= (char *)malloc( cela);
    		firstmem=0;
    		if ( NULL==jmeno) {
    			DEBUG(stderr, "nepodarilo se alokovat pamet\n");
    			konci(3);
    		}
    	}
    
    	/* pospojuj argument a cas do jmena */
    	strncpy(jmeno, prefix, delka);
    	jmeno[delka]='\0';
    
    	strncpy( (char *)&(((char *)jmeno)[delka]), strcas, cela-delka);
    	jmeno[cela]='\0';
    }
    
    /* otevri soubor */
    void otevri( char *jmeno, char *param)
    {
    	log= open( jmeno, O_WRONLY | O_CREAT | O_APPEND, 384);
    	if (-1==log) {
    		DEBUG(stderr, "nepodarilo se otevrit soubor\n");
    		konci(4);
    	}
    	unlink(param );
    	link( jmeno, param);
    }
    
    /* kontroluj jestli je posledni zapsany \n */
    int newlinereset(void)
    {
    	fdatasync( fileno(stdin));
    	/* byl napsan naposled konec radku */
    	if (last=='\n') {
    		DEBUG(stderr, "newlinereset(): last \\n\n");
    		findnewline=0;
    		close( log);
    		return(1);
    		/* je potreba najit konec radku */
    	} else if (last!='\n') {
    		DEBUG(stderr, "newlinereset(): last neni \\n\n");
    		findnewline=1;
    		return(0);
    	}
    }
    
    

    v konfiguraku pak

    CustomLog "|/usr/local/bin/jmeno /usr/local/apache2/logs/access_log" combined
    

    no a zalohovani resim z cronu jen pro stary logy nejak takhle:

    #!/bin/bash
    
    store="/mnt/backup/log/apache";
    log="${store}/default.tar";
    
    if test -f ${log} && test -r ${log}; then
            if test `date +%u` = 2; then
                    newlog=`date +%Y%m%d_%s`;
                    mv ${log} ${store}/default_do_${newlog}.tar;
                    bzip2 -9z ${store}/default_do_${newlog}.tar;
            fi
    fi
    
    for F in `cat /usr/local/var/logs/default.log`; do
            dir=`dirname ${F}`;
            find ${dir} -mtime +3 | grep -e "${F}[0-9]\+" | xargs --no-run-if-empty tar vuf ${log} --exclude ${F} --exclude ${F}`date +%Y%m%d` --remove-files
    done
    

    kdyz tak na to letmo koukam, tak uz ani presne nevim co ten skript dela... ale par jich necha ne puvodnim miste a zbytek hodi do tar archivu kterej po case zrotuje a zbali bzipem. ale funguje a to je hlavni.

    V tomto formuláři můžete formulovat svou stížnost ohledně příspěvku. Nejprve vyberte typ akce, kterou navrhujete provést s diskusí či příspěvkem. Potom do textového pole napište důvody, proč by měli admini provést vaši žádost, problém nemusí být patrný na první pohled. Odkaz na příspěvek bude přidán automaticky.

    Vaše jméno
    Váš email
    Typ požadavku
    Slovní popis
    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.