Organizace Apache Software Foundation (ASF) vydala verzi 30 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.
Byla vydána nová verze 7.0 svobodného open source redakčního systému WordPress. Kódové jméno Armstrong bylo vybráno na počest amerického jazzového trumpetisty a zpěváka Louise Armstronga (What A Wonderful World).
V Drupalu byla nalezena a opravena kritická zranitelnost SA-CORE-2026-004 (CVE-2026-9082). Útočník může provádět libovolné SQL dotazy na webech používajících databázi PostgreSQL.
Richard Hughes oznámil, že službu Linux Vendor Firmware Service (LVFS) umožňující aktualizovat firmware zařízení na počítačích s Linuxem, nově sponzoruje také společnost HP.
O víkendu proběhla demopárty Outline 2026. Publikována byla prezentovaná dema. Upozornit lze na 16 bajtové, opravdu šestnáct bajtové, zvukově obrazové demo Wake Up! 16b (YouTube).
Byla vydána nová verze 9.5 multiplatformní digitální pracovní stanice pro práci s audiem (DAW) Ardour. Přehled novinek, vylepšení a oprav v poznámkách k vydání a na YouTube.
Dnes a zítra probíhá vývojářská konference Google I/O 2026. Sledovat lze na YouTube a na síti 𝕏 (#GoogleIO).
Canonical vydal Ubuntu Core 26. Vychází z Ubuntu 26.04 LTS a podporováno bude 15 let. Ubuntu Core je minimální neměnný operační systém určený pro vestavěné systémy.
Bylo vydáno OpenBSD 7.9. Po dlouhé době opět se songem: Diamond in the Rough.
Byl vydán Mozilla Firefox 151.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 151 bude brzy k dispozici také na Flathubu a Snapcraftu.
Zdravim dobri lide,
potreboval bych poradit s jednim skriptikem.
Jde mi o neustale zjistovani dostupnosti hosta. Pokud je host online, skript by se mel pripojit telnetem na port 21 a vystup ukladat do souboru. Pokud se klient odpoji, spojeni by se melo zavrit a opet pokracovat v overeni dostupnosti a tak dokola. Pokusil jsem se na to neco napsat, ale neni to 100% funkcni. Nekdy to skonci na cyklu while u read - skript si mysli, ze je klient online, ale neni a ceka na data, ktera nejdou.
#!/bin/bash
ADRESA=$1
while [ 1 ]
do
PING=$(ping -W 1 -c 1 $ADRESA | grep "from" | awk '{print $(NF-1)}')
if [[ $PING == *time* ]]; then
# Je online
# Otevreme spojeni
#echo "Online, oteviram socket"
exec 3</dev/tcp/$ADRESA/21
# Zacneme cist data
while read <&3
do
set -- ${REPLY//$'\r'/}
TODAY=$(/bin/date +'%Y%m%d')
TIME=$(/bin/date +'%H:%M:%S')
#echo "ctu ..."
echo -e "$TIME\n$REPLY\n" >> /scripts/kas/logs/$TODAY-$ADRESA.log
PING=$(ping -W 1 -c 1 $ADRESA | grep "from" | awk '{print $(NF-1)}')
# Jestlize neni odezva, prerusime cyklus a zavreme socket
if [[ $PING != *time* ]]; then
#echo "Disconnected"
exec 3<&-
break;
fi
done
#else
# Neni online
#echo "Timed out"
fi
sleep 1
done
Nemel by z Vas nekdo lepsi napad, jak by se to dalo vylepsit a osetrit tuhle chybu?
Mockrat diky!
Kaja
Řešení dotazu:
V příloze máš ukázkový skriptík v Pythonu. Řešit takového klient v Bashi nemá smysl.
Když ho spustíš, tak se pokusí připojit na:
$ nc -l -p 5000 127.0.0.1
Pokud se nepodaří připojit k serveru, uloží tuto informaci do logu a za 3s to zkusí znovu, pokud se to znovu nepodaří, tak neprovádí logování stejné chyby, pouze pokud by se vyskytla za dobu delší než 60s. Používat ping je zbytečné. Log sype do:
$ tail -f /tmp/client.log
2010-03-10 11:40:10,674 - INFO - starting client 0.1.0
2010-03-10 11:40:10,675 - INFO - create connection to 127.0.0.1:5000
2010-03-10 11:40:17,377 - INFO - receive data: 'Hello'
2010-03-10 11:40:18,969 - INFO - receive data: 'Bye'
2010-03-10 11:40:19,898 - INFO - close connection to 127.0.0.1:5000
2010-03-10 11:40:22,896 - ERROR - TCP client exception
Traceback (most recent call last):
File "./client.py", line 43, in main_thread
self.socket.connect((self.address, self.port))
File "<string>", line 1, in connect
error: (111, 'Connection refused')
2010-03-10 11:45:04,681 - INFO - received signal 2
2010-03-10 11:45:04,682 - INFO - exit
Tiskni
Sdílej: