Ubuntu 26.04 (Resolute Raccoon) už nebude v desktopové instalaci obsahovat GUI nástroj 'Software & Updates'. Důvodem jsou obavy z jeho složitosti pro běžné uživatele a z toho plynoucích bezpečnostních rizik. Nástroj lze doinstalovat ručně (sudo apt install software-properties-gtk).
Thomas Dohmke, bývalý CEO GitHubu, představil startup Entire - platformu pro spolupráci vývojářů a agentů umělé inteligence. Entire získalo rekordních 60 milionů dolarů na vývoj databáze a nástrojů, které mají zefektivnit spolupráci mezi lidmi a agenty umělé inteligence. Dohmke zdůrazňuje potřebu přepracovat tradiční vývojové postupy tak, aby odpovídaly realitě, kdy většinu kódu produkuje umělá inteligence.
Toyota Connected North America oznámila vývoj open-source herního enginu Fluorite, postaveného na frameworku Flutter. Pro renderování grafiky využívá 3D engine Filament od společnosti Google a dle svého tvrzení cílí na konzolovou kvalitu her. Fluorite je zřejmě navržen tak, aby fungoval i na méně výkonném hardware, což naznačuje možnost použití přímo v ICE systémech vozidel. Zdrojový kód zatím zveřejněný není.
Byl vytvořen nástroj a postup pro překonání věkového ověření platforem Discord, Kick, Twitch, Snapchat (a možná dalších), kód je open-source a dostupný na GitHubu. Všechny tyto sítě používají stejnou službu k-ID, která určuje věk uživatele scanem obličeje a na původní server posílá pouze šifrovaná metadata, ty ale sociální síť už nedokáže sama nijak validovat, 'útok' spočívá ve vygenerování a podstrčení legitimně vypadajících ověřovacích metadat.
Jihokorejská kryptoměnová burza Bithumb přiznala vážné selhání interních systémů, které ji vystavilo riziku sabotáže a nezabránilo chybné transakci v hodnotě přes 40 miliard dolarů (814 miliard Kč). Druhá největší kryptoměnová burza v Koreji minulý týden při propagační akci omylem rozeslala zákazníkům zhruba 620 000 bitcoinů místo 620 000 wonů (8700 Kč). Incident vyvolal pokles ceny bitcoinu o 17 procent. Většinu
… více »Google Chrome 145 byl prohlášen za stabilní. Nejnovější stabilní verze 145.0.7632.45 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Zpátky je podpora grafického formátu JPEG XL, viz Platform Status. Odstraněna byla před třemi lety. Nový dekodér JPEG XL jxl-rs je napsán v Rustu. Zobrazování JPEG XL lze vyzkoušet na testovací stránce. Povolit lze v nastavení chrome://flags (Enable JXL image format).
Byla vydána nová verze 1.26 programovacího jazyka Go (Wikipedie). Přehled novinek v poznámkách k vydání.
CrossOver, komerční produkt založený na Wine, byl vydán ve verzi 26. Přehled novinek v ChangeLogu. CrossOver 26 vychází z Wine 11.0, D3DMetal 3.0, DXMT 0.72, Wine Mono 10.4.1 a vkd3d 1.18. Do 17. února lze koupit CrossOver+ se slevou 26 %.
KiCad je nově k dispozici také jako balíček ve formátu AppImage. Stačí jej stáhnout, nastavit právo na spouštění a spustit [Mastodon, 𝕏].
Šenčenská firma Seeed Studio představila projekt levného robotického ramena reBot Arm B601, primárně coby pomůcky pro studenty a výzkumníky. Paže má 6 stupňů volnosti, dosah 650 mm a nosnost 1,5 kilogramu, podporované platformy mají být ROS1, ROS2, LeRobot, Pinocchio a Isaac Sim, krom toho bude k dispozici vlastní SDK napsané v Pythonu. Kompletní seznam součástek, videonávody a nejspíš i cena budou zveřejněny až koncem tohoto měsíce.
… více »
U me v Gentoo to napr. vypada takhle:
/var/log/apache2/*log {
missingok
notifempty
sharedscripts
postrotate
/etc/init.d/apache2 reload > /dev/null 2>&1 || true
endscript
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.
Tiskni
Sdílej: