V Bostonu probíhá konference Red Hat Summit 2025. Vybrané přednášky lze sledovat na YouTube. Dění lze sledovat na síti 𝕏 (#RHSummit).
Společnost Red Hat oficiálně oznámila vydání Red Hat Enterprise Linuxu 10. Vedle nových vlastností přináší také aktualizaci ovladačů a předběžné ukázky budoucích technologií. Podrobnosti v poznámkách k vydání.
Tuto sobotu 24. května se koná historicky první komunitní den projektu Home Assistant. Zváni jsou všichni příznivci, nadšenci a uživatelé tohoto projektu. Pro účast je potřebná registrace. Odkazy na akce v Praze a v Bratislavě.
Troy Hunt představil Have I Been Pwned 2.0, tj. nový vylepšený web služby, kde si uživatelé mohou zkontrolovat, zda se jejich hesla a osobní údaje neobjevili v únicích dat a případně se nechat na další úniky upozorňovat.
Microsoft představil open source textový editor Edit bežící v terminálu. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.
V Seattlu a také online probíhá konference Microsoft Build 2025. Microsoft představuje své novinky. Windows Subsystem for Linux je nově open source. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.
Z příspěvku Turris Sentinel – co přinesl rok 2024 na blogu CZ.NIC: "Za poslední rok (únor 2024 – únor 2025) jsme zachytili 8,3 miliardy incidentů a to z 232 zemí a z jejich závislých území. Tyto útoky přišly od 6,2 milionu útočníků (respektive unikátních adres). SMTP minipot je stále nejlákavější pastí, zhruba 79 % útoků bylo směřováno na tento minipot, 16 % útoků směřovalo na minipot Telnet, 3 % útoků směřovaly na minipot HTTP a 2 % na minipot FTP. Dále jsme zaznamenali 3,2 milionu unikátních hesel a 318 tisíc unikátních loginů, které útočníci zkoušeli."
Byla vydána (Mastodon, 𝕏) nová verze 3.0.4 svobodné aplikace pro úpravu a vytváření rastrové grafiky GIMP (GNU Image Manipulation Program). Přehled novinek v oznámení o vydání a v souboru NEWS na GitLabu. Nový GIMP je již k dispozici také na Flathubu.
Byla vydána nová stabilní verze 7.4 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 136. Přehled novinek i s náhledy v příspěvku na blogu.
Spolek vpsFree.cz vydal statistiky týkající se distribucí nasazených na serverech členů. V dlouhodobém pohledu je zřejmé, že většina uživatelů z původního CentOS přechází na Rocky Linux. Pozoruhodný je také nárůst obliby distribuce NixOS, která dnes zaujímá třetí místo po Debianu a Ubuntu.
Ďakujem za komentáre a podnety ku minulému článku. Týmto ho skúsim ešte trochu doplniť.
Príkaz
ssh -D 12345 PC2otvorí šifrované spojenie z PC0:12345 na PC2 a sshd na PC2 bude plniť úlohu SOCKS proxy. Ľubovoľná aplikácia na PC0 (alebo v sieti PC0, ak je port 12345 otvorený do siete), ktorá dokáže používať SOCKS proxy, získa prístup ku prostriedkom, ako keby bežala priamo na PC2. Díky @jiwopene za tip!
ProxyCommand /bin/ncat --proxy-type socks5 --proxy socks_server:socks_port PC2 ssh_port2prípadne, ak socks_server sprístupňuje viaceré stroje/viaceré porty, dá sa napísať univerzálne
ProxyCommand /bin/ncat --proxy-type socks5 --proxy socks_server:socks_port %h %p(viď. TOKENS v
man ssh_config
).
Netcat binárka sa môže v niektorých distribúciách volať aj /bin/nc
, treba pozrieť svoj systém.
ssh
umožňuje zdieľať jeden tunel nielen pre viacero použití v rámci jedného príkazu (ako napr. viacero -L
), ale aj v čase, pre viacero klientov. Toto zdieľanie môže riadiť programátor v skripte, alebo môže byť nastavené ako automatické.
Príklad, ako zapnúť automatické zdieľanie spojení v ~/.ssh/config
:
Host * ControlMaster auto ControlPath ~/.ssh/control_%r@%h_%p ControlPersist 1mPríkazy, ako napr.
#!/bin/bash scp skript{1,2}.sh PC2:./ ssh PC2 ./skript1.sh ssh PC2 ./skript2.shsa potom všetky udejú v rámci jedného ssh spojenia.
Poznámka: Zdieľanie spojenia nefunguje v rámci Cygwin-u a z nejakých dôvodov sa mne nedalo kombinovať s X11 forwardingom. Keďže s X11 forwardingom som robil len pokusy a reálne som ho nepotreboval, hlbšiu príčinu som nezisťoval.
Skript beží na PC5, je spúšťaný pravidelne cez crontab a udržiava "živý" reverzný tunel, ktorý vyúsťuje na PC1. Ku prihlasovaniu na PC1 sa používa ssh kľúč bez hesla. Verejnú časť kľúča je nutné nahrať nielen do /home/user1/.ssh/authorized_keys
na PC1 ale aj do /home/user5/.ssh/authorized_keys
na PC5, kvôli overovaniu funkčnosti tunela. Voľba StrictHostKeyChecking accept-new
uľahčuje prvé spustenie. Voľby ServerAlive...
boli pridané vďaka námetu od @Jenda, díky!
Skript funguje vďaka mechanizmu zdieľania spojenia, tentokrát nie v automatickom režime, ako v minulej kapitole, ale "manuálne" riadenému: -M
štartuje nový master, -O
posiela riadiace príkazy masteru cez socket -S
.
Spustenie skriptu s parametrom stop
ukončí tunel a súčasne pozastaví proces jeho obnovovania (netreba editovať crontab). Parameter start
tunel zase obnoví, rovnako, ako reštart PC5 (pri reštarte sa obvykle zmaže /tmp/
.)
Poznámka: Riešenie s reverzným tunelom nesie zo sebou istú nepríjemnosť v podobe otravných pokusov o neautorizované pripojenie. PC1 o výsledku pripojovania klienta nič nevie, iba posiela nejaké dáta do tunela, takže nemôže takéto pokusy blokovať. Z pohľadu PC5 prichádzajú všetky spojenia z localhost-u, takže vie, ktoré prípady by sa mali blokovať, ale nevidí adresu. Jednoduché riešenie formou povedzme fail2ban sa nedá nasadiť. Ak máte niekto nápad, ako sa neautorizovaných pokusov zbaviť, podeľte sa, prosím, v diskusii. Vysoké číslo portu (54321) dnes už nepomáha. Ja som skeptický.
#!/bin/bash MyPort=54321 TheServer='PC1' TheServerSshPort=22 TheServerLogin='user1' LocalSshPort=22 ControlPath="$HOME/.ssh/server_tunnel_control" BlockPath='/tmp/server_tunnel_block' Identity="$HOME/tunel_test/id_rsa_port_forward" # Kluc musi byt ako v $Identity, tak aj v ~/.ssh/authorized_keys a to kvoli kontrole funkcnosti spojenia (function is_tunnel_working)! self="$(readlink -mn "$0")" function start_connection() { ssh -M -S "$ControlPath" -fnN -g -2 -4 \ -o 'StrictHostKeyChecking accept-new' \ -o 'ControlPersist yes' \ -o 'ExitOnForwardFailure yes' -o 'ServerAliveInterval 30' -o 'ServerAliveCountMax 3' \ -R "*:$MyPort:localhost:$LocalSshPort" \ -i "$Identity" \ -p "$TheServerSshPort" "$TheServerLogin"@"$TheServer" \ && rm -f "$BlockPath" } function control() { cmd=$1 ssh -S "$ControlPath" \ -O "$cmd" \ -i "$Identity" \ -p "$TheServerSshPort" "$TheServerLogin"@"$TheServer" } function stop_connection() { touch "$BlockPath" control exit >/dev/null } function ping_server() { ping -c 2 "$TheServer" >/dev/null } function is_tunnel_working() { # Tunel sa povazuje za funkcny, ak cez neho skript vidi sam seba. ssh -o 'StrictHostKeyChecking accept-new' \ -i "$Identity" -p "$MyPort" "$USER"@"$TheServer" \ /bin/ls "$(dirname "$self")" \ | grep -cxF "$(basename "$self")" } ###============================================================================ case "$1" in "start") ## iba pre pripad startu po zablokovani start_connection E=$? logger --stderr -t "[THESERVER_SSH]" "Port forwarding start ($E)" ;; "stop") ## zablokovanie forwardu, aby ho cron neobnovoval stop_connection E=$? logger --stderr -t "[THESERVER_SSH]" "Port forwarding stop ($E)" ;; "restart") stop_connection && start_connection E=$? logger --stderr -t "[THESERVER_SSH]" "Port forwarding restart ($E)" ;; *) ## default - ak nie je zablokovany, forward ma fungovat [ -f $BlockPath ] && exit 0 if ! ping_server ; then >&2 echo "Cannot ping $TheServer. Internet off?" exit 1 fi if [ ! -e "$ControlPath" ] ; then "$self" start exit $? fi T="$(mktemp)" control check >"$T" 2>&1 E=$? if [ "$E" -ne 0 ] ; then logger --stderr -t "[THESERVER_SSH]" "($E) $(cat "$T")" rm "$T" if [ "$E" -ne 255 ] ; then "$self" start exit $? fi else rm "$T" fi # funguje naozaj? C="$(is_tunnel_working)" if [ -z "$C" -o "$C" -eq 0 ] ; then "$self" restart E=$? else E=0 fi ;; esac exit $E
Tiskni
Sdílej:
ssh -N -D3081 user@machine -p 22Nebo aby byl proxy dostupny z jakehokoli PC v lokalni siti:
ssh -N -D192.168.1.100:3081 user@machine -p 22Pro pouziti proxy treba k webovemu prohlizeci Chromium:
chromium --incognito --proxy-server="socks5://192.168.1.100:3081"