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 23:00 | IT novinky

    Společnost Pebble představila (YouTube) chytré hodinky Pebble Round 2. S kulatým e-paper displejem, s open source PebbleOS a vydrží baterie přibližně dva týdny. Předobjednat je lze za 199 dolarů s plánovaným dodáním v květnu.

    Ladislav Hagara | Komentářů: 6
    včera 14:22 | Humor

    Na novoroční inauguraci starosty New Yorku Zohrana Mamdaniho bylo zakázáno si s sebou přinést Raspberry Pi anebo Flipper Zero. Raspberry Pi i Flipper Zero jsou explicitně uvedeny v seznamu zakázaných věcí jak na na veřejné pozvánce, tak i na oficiálních stránkách města.

    NUKE GAZA! 🎆 | Komentářů: 23
    včera 11:33 | Nová verze

    OpenTTD (Wikipedie), tj. open source klon počítačové hry Transport Tycoon Deluxe, byl vydán v nové stabilní verzi 15.0. Přehled novinek v seznamu změn a také na YouTube. OpenTTD lze instalovat také ze Steamu.

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

    Správce oken IceWM byl vydán ve verzi 4.0.0, která např. vylepšuje navigaci v přepínání velkého množství otevřených oken.

    |🇵🇸 | Komentářů: 4
    včera 01:33 | Zajímavý projekt

    Od 1. ledna 2026 jsou všechny publikace ACM (Association for Computing Machinery) a související materiály přístupné v její digitální knihovně. V rámci této změny je nyní digitální knihovna ACM nabízena ve dvou verzích: v základní verzi zdarma, která poskytuje otevřený přístup ke všem publikovaným výzkumům ACM, a v prémiové zpoplatněné verzi, která nabízí další služby a nástroje 'určené pro hlubší analýzu, objevování a organizační využití'.

    NUKE GAZA! 🎆 | Komentářů: 5
    1.1. 16:44 | IT novinky

    S koncem roku 2025 skončila standardní podpora operačního systému HP-UX (Hewlett Packard Unix).

    Ladislav Hagara | Komentářů: 10
    1.1. 14:33 | Nová verze

    K 1. lednu 2026 končí 70leté omezení majetkových autorských práv děl autorů zesnulých v roce 1955, viz 2026 in public domain. V americkém prostředí vstupují do public domain díla z roku 1930, viz Public Domain Day.

    |🇵🇸 | Komentářů: 4
    31.12. 15:00 | Nová verze

    Všem vše nejlepší do nového roku 2026.

    Ladislav Hagara | Komentářů: 13
    31.12. 13:33 | Zajímavý software

    Crown je multiplatformní open source herní engine. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT a GPLv3+. Byla vydána nová verze 0.60. Vyzkoušet lze online demo.

    Ladislav Hagara | Komentářů: 0
    31.12. 12:11 | Zajímavý článek

    Daniel Stenberg na svém blogu informuje, že po strncpy() byla ze zdrojových kódů curlu odstraněna také všechna volání funkce strcpy(). Funkci strcpy() nahradili vlastní funkcí curlx_strcopy().

    Ladislav Hagara | Komentářů: 6
    Které desktopové prostředí na Linuxu používáte?
     (0%)
     (4%)
     (0%)
     (15%)
     (35%)
     (10%)
     (5%)
     (6%)
     (11%)
     (31%)
    Celkem 80 hlasů
     Komentářů: 1, poslední včera 06:15
    Rozcestník

    Dotaz: príliš skorá expanzia príkazu

    jose17 avatar 22.3.2007 13:06 jose17 | skóre: 44 | blog: Joseho_blog | Bratislava
    príliš skorá expanzia príkazu
    Přečteno: 168×
    prosím, potrebujem pomôcť s nasledovným kódom:
    ssh -o StrictHostKeyChecking=no host02 ssh -o StrictHostKeyChecking=no host01 'echo "`if [ $(ps -ef | grep xntpd | wc -l) -ne 0 -a \"$(ntpq -p | sed -n 3p | sed \"s/[^ ]* *[^ ]* *\([^ ]*\) *.*/\1/\")\" != 1 ]; then echo \"yes\"; else echo \"no\"; fi`;'
    
    čiže sa jedná o spustenie kódu na vzdialenom stroji (host01), na ktorý sa pripájam z iného vzdialeneho stroja (host02). problém je v tom, že ntpq sa spustí lokálne.

    nejak si s tým už neviem dať rady. díky za pomoc,

    -- jose
    Ja vim, on vi, ty nano!

    Odpovědi

    22.3.2007 14:20 Ondřej Kubečka | skóre: 29 | blog: datlovo | Ulm
    Rozbalit Rozbalit vše Re: príliš skorá expanzia príkazu
    Nejsem si jistý, zda to souvisí, ale rozhodně Vám tam chybí jedny uvozovky úplně na konci parametru příkazu echo.

    ...tedy pokud jsem dobře koukal. ;)
    jose17 avatar 22.3.2007 14:28 jose17 | skóre: 44 | blog: Joseho_blog | Bratislava
    Rozbalit Rozbalit vše Re: príliš skorá expanzia príkazu
    jo, máte recht. ale ich pridanie nepomôže.
    Ja vim, on vi, ty nano!
    22.3.2007 14:54 JMP | skóre: 30
    Rozbalit Rozbalit vše Re: príliš skorá expanzia príkazu
    a mozna by to chtelo dalsi tak, aby to vzalo druhy ssh i s parametrama jako jeden prikaz?
    22.3.2007 15:18 Ondřej Kubečka | skóre: 29 | blog: datlovo | Ulm
    Rozbalit Rozbalit vše Re: príliš skorá expanzia príkazu
    Tak jsem na to ještě koukal a uteklo mi, že tam máte jeden krok mezi. Vypadá to, že věc se má takhle:

    ssh host01 ssh host02 echo $HOSTNAME

    expanduje $HOSTNAME rovnou na mašině, kde to spouštíte, to je celkem ještě jasné.

    ssh host01 ssh host02 'echo $HOSTNAME'

    By člověk možná čekal, že se nic neexpanduje a ssh spojení na host02 dostane 'echo $HOSTNAME' jako svůj parametr... jenomže host jedna prostě spustí:

    ssh host02 echo $HOSTNAME

    Jsme tedy o krok blíže, ale ještě ne tam, kde jsme chtěli.

    Tak to escapujeme i pro interpretaci na host02 a voila:

    ssh host01 ssh host02 'echo \$HOSTNAME'

    máme hostname z host02. Drobný detail, pro $(...) budete muset escapovat vše, tedy: \$\(...\), ale to byste brzy jistě zjistil sám, ono už by si to postěžovalo.
    Medved09 avatar 22.3.2007 15:24 Medved09 | skóre: 26 | Havlíčkův Brod / Brno
    Rozbalit Rozbalit vše Re: príliš skorá expanzia príkazu

    jen tak z hlavy - zkousel jste

    ... \\"$(ntpq -p | sed -n 3p ...
    Fordem tam, vlakem zpátky :-)
    23.3.2007 09:35 Jan Martinek | skóre: 43 | blog: johny | Brno
    Rozbalit Rozbalit vše Re: príliš skorá expanzia príkazu
    Myslím, že bude výrazně přehlednější, když na cílový stroj nakopíruješ skript, který se má spustit. Kdyby se navíc dalo zbavit toho "StrictHostKeyChecking=no", mohlo by se psát jen
    ssh host02 ssh host01 skript
    
    A co se týče toho skriptu, napsal bych ho takhle:
    #!/usr/bin/env python
    
    from subprocess import *
    command = ['/usr/sbin/ntpq', '-p']
    process = Popen(command, stdout = PIPE, stderr = STDOUT)
    
    #precti vsechny radky
    for line in process.stdout:
        pass
    #na konci cyklu bude v promenne line posledni radek
    
    if 'Connection refused' in line: #demon asi neni spusten
        raise SystemExit, 'ntpd is not running'
    
    #posledni radek rozsekej po mezerach
    splitted = line.split()
    
    #vyber treti polozku a preved ji na cislo
    status = int(splitted[2])
    
    #vypis status
    print 'status is %d' %status
    
    Není nutné předem testovat, zda démon běží. Dá se rovnou pustit "ntpq -p" a odchytávat hlášku "Connection refused".

    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.