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 22:22 | Komunita

Dle plánu byl měl Debian 9 s kódovým názvem Stretch vyjít v sobotu 17. června. Po celém světě se začínají plánovat Release Parties. Oznámeno bylo vydání čtvrté RC (release candidate) verze instalátoru pro Debian 9 Stretch.

Ladislav Hagara | Komentářů: 2
26.5. 22:22 | Komunita

V Norimberku probíhá do neděle 28. května openSUSE Conference 2017. Na programu je celá řada zajímavých přednášek. Sledovat je lze online. K dispozici jsou také videozáznamy (YouTube) již proběhnuvších přednášek. Dění lze sledovat na Twitteru.

Ladislav Hagara | Komentářů: 0
26.5. 11:33 | IT novinky

Red Hat kupuje společnost Codenvy stojící za stejnojmenným webovým (cloudovým) integrovaným vývojovým prostředím (WIDE) postaveném na Eclipse Che.

Ladislav Hagara | Komentářů: 0
26.5. 08:55 | Nová verze

V listopadu 2014 byl představen fork Debianu bez systemd pojmenovaný Devuan. Po dva a půl roce jeho vývojáři oznámili vydání první stabilní verze 1.0. Jedná se o verzi s dlouhodobou podporou (LTS) a její kódové jméno je Jessie, podle planetky s katalogovým číslem 10 464.

Ladislav Hagara | Komentářů: 10
25.5. 20:22 | Zajímavý článek

Nadace Raspberry Pi vydala již osmapadesáté číslo (pdf) stostránkového anglicky psaného časopisu MagPi věnovanému Raspberry Pi a projektům postaveným na tomto jednodeskovém počítači a druhé číslo (pdf) časopisu Hello World primárně určeného pro učitele informatiky a výpočetní techniky.

Ladislav Hagara | Komentářů: 0
25.5. 19:55 | Humor

Portál Stack Overflow informuje na svém blogu, že pomohl ukončit editor Vim už více než milionu vývojářů. V loňském roce například hledal odpověď na otázku Jak ukončit editor Vim v průměru 1 z 20 000 návštěvníků.

Ladislav Hagara | Komentářů: 12
25.5. 19:22 | Nová verze

Po pěti měsících od vydání verze 3.5.0 byla vydána nová stabilní verze 3.6.0, tj. první z nové řady 3.6, minimalistické linuxové distribuce zaměřené na bezpečnost Alpine Linux (Wikipedie). Z novinek lze zmínit například podporu dvou nových 64bitových platforem little-endian POWER machines (ppc64le) a IBM z Systems (s390x) nebo nové balíčky Rust 1.17.0, Cargo 0.18.0, GHC 8.0.2 a Julia 0.5.2.

Ladislav Hagara | Komentářů: 0
24.5. 21:33 | Bezpečnostní upozornění

V Sambě byla nalezena a opravena bezpečnostní chyba CVE-2017-7494. Má-li útočník právo ukládat soubory na vzdálený server, může tam uložit připravenou sdílenou knihovnu a přinutit smbd server k jejímu načtení a tím pádem ke spuštění libovolných příkazů. Chyba je opravena v upstream verzích 4.6.4, 4.5.10 a 4.4.14. Chyba se týká všech verzí Samby od verze 3.5.0 vydané 1. března 2010.

Ladislav Hagara | Komentářů: 7
24.5. 20:44 | Nová verze

Byla vydána nová stabilní verze 4.3.0 integrovaného vývojového prostředí (IDE) Qt Creator. Z novinek lze zmínit například integraci editoru kódu do Qt Quick Designeru.

Ladislav Hagara | Komentářů: 1
24.5. 20:11 | Bezpečnostní upozornění

Společnost Check Point informuje na svém blogu o novém vektoru útoku. Pomocí titulků lze útočit na multimediální přehrávače VLC, Kodi, Popcorn Time, Stremio a pravděpodobně i další. Otevření útočníkem připraveného souboru s titulky v neaktualizovaném multimediálním přehrávači může vést ke spuštění libovolných příkazů pod právy uživatele. Ukázka na YouTube. Chyba je opravena v Kodi 17.2 nebo ve VLC 2.2.6.

Ladislav Hagara | Komentářů: 14
Chystáte se pořídit CPU AMD Ryzen?
 (6%)
 (33%)
 (1%)
 (8%)
 (44%)
 (9%)
Celkem 629 hlasů
 Komentářů: 62, poslední 19.5. 01:57
    Rozcestník

    Dotaz: basch script a podmínka

    24.5.2011 19:12 Martin
    basch script a podmínka
    Přečteno: 269×

    Dobrý den, potřeboval bych poradit se scriptem. Mám script pomocí kterého do souboru zapíšu [OK]. Pokud je tato podmínka splněna tak se vše ukončí se zápisem do logu. Pokud místo "echo "[OK] 2011-05-24 18:23:50" > $LOGNAME" zadám "echo "[OOOK] 2011-05-24 18:23:50" > $LOGNAME, tak vše taky proběhne tak jak má a zapíše se do error logu.

    Potřeboval bych udělat to aby když bude vše OK, tak aby se mi spustil ještě jedena část a to konkrétně toto: echo "[PAIR] 2011-05-24 18:23:50" > $LOGNAME2 ale jen v případě toho že předchozí podmínka bude OK. Jinak ať se vše okončí tím že se zapíše do error logu error, ale logname2 se nevytvoří.

     

    cat test.sh
    #!/bin/bash

    COMPANY="Test"
    SLEEP="2"
    TRIES="3"

    # let it "as is" until you know what you're doing
    SCRIPTNAME="$0"
    SCRIPTPATH=$(cd ${SCRIPTNAME%/*} && pwd)
    LOGNAME="$SCRIPTPATH/log/stop_$$.log"
    LOGNAME2="$SCRIPTPATH/log/pair-_$$.log"
    LASTSTATUS="$SCRIPTPATH/log/laststatus.log"
    ERRLOGS="$SCRIPTPATH/log/errors"
    OKLOGS="$SCRIPTPATH/log/allright"
    COUNT="0"


    checklog(){
    if [ ! -f $1 ] ; then
    return 1
    elif [ $(tail -n 1 $1 | grep -c '^\[WARNING\]') -eq 1 ] ; then
    return 2
    elif [ $(tail -n 1 $1 | grep -c '^\[OK\]') -eq 0 ] ; then
    return 1
    else
    return 0
    fi
    }

    # better to run as www user and with mutt installed
    [ -d $ERRLOGS ] || mkdir -p $ERRLOGS
    [ -d $OKLOGS ] || mkdir -p $OKLOGS

    while [ $COUNT -lt $TRIES ]; do
    if ! checklog $LOGNAME ; then

    # real stop
    echo "[OK] 2011-05-24 18:23:50" > $LOGNAME

    # take some sleep after unsuccessful run
    if [ $COUNT -gt 0 ] ; then
    sleep $SLEEP
    fi
    # raise counter
    COUNT=$((COUNT + 1))
    else
    # break counter
    COUNT=$((TRIES + 1))
    fi
    done

    [ -f $LOGNAME ] && TAIL=$(tail -n1 $LOGNAME)

    # alert mail in case of any problem (and exit)
    if ! checklog $LOGNAME ; then
    echo -e "$COMPANY stop was not proceeded properly: $TAIL"  gzip -9 $LOGNAME
    gzip -9 $LOGNAME
    [ -d $ERRLOGS ] && mv $LOGNAME.gz $ERRLOGS/$(date +%Y%m%d_%H%M).gz
    echo "$TAIL" > $LASTSTATUS
    exit 0
    fi

    # delete logfile in the end of successful run
    if [ -f $LOGNAME ] ; then
    gzip -9 $LOGNAME
    [ -d $OKLOGS ] && mv $LOGNAME.gz $OKLOGS/$(date +%Y%m%d_%H%M).gz
    fi

    # "OK mail" in case of successful run after previous error run
    if ! checklog $LASTSTATUS ; then
    echo -e "$COMPANY stop is all right now.\n\nScript exited with [OK] string. Number of tries: $TRIES. Here is last line from script: $TAIL"
    fi

    # log last output line to statusfile for test and "OK mail" eventually
    echo "$TAIL" > $LASTSTATUS

    exit 0

    Odpovědi

    24.5.2011 21:12 Mercuriuz | skóre: 16 | blog: Mercuriuz | V hospodě =)
    Rozbalit Rozbalit vše Re: basch script a podmínka
    nevím jestli sem úplně pochopil co potřebuješ, ale takhle by to mělo fungovat n?
    cat test.sh 
    #!/bin/bash
    COMPANY="Test"
    SLEEP="2"
    TRIES="3"
    
    # let it "as is" until you know what you're doing
    SCRIPTNAME="$0"
    SCRIPTPATH=$(cd ${SCRIPTNAME%/*} && pwd)
    LOGNAME="$SCRIPTPATH/log/stop_$$.log"
    LOGNAME2="$SCRIPTPATH/log/pair-_$$.log"
    LASTSTATUS="$SCRIPTPATH/log/laststatus.log"
    ERRLOGS="$SCRIPTPATH/log/errors"
    OKLOGS="$SCRIPTPATH/log/allright"
    COUNT="0"
    
    
    checklog(){
    if [ ! -f $1 ] ; then
    return 1
    elif [ $(tail -n 1 $1 | grep -c '^\[WARNING\]') -eq 1 ] ; then
    return 2
    elif [ $(tail -n 1 $1 | grep -c '^\[OK\]') -eq 0 ] ; then
    return 1
    else
    return 0
    fi
    }
    
    # better to run as www user and with mutt installed
    [ -d $ERRLOGS ] || mkdir -p $ERRLOGS
    [ -d $OKLOGS ] || mkdir -p $OKLOGS
    
    while [ $COUNT -lt $TRIES ]; do
    if ! checklog $LOGNAME ; then
    
    # real stop
    echo "[OK] 2011-05-24 18:23:50" > $LOGNAME
    echo "[PAIR] 2011-05-24 18:23:50" > $LOGNAME2
    
    # take some sleep after unsuccessful run
    if [ $COUNT -gt 0 ] ; then
    sleep $SLEEP
    fi
    # raise counter
    COUNT=$((COUNT + 1))
    else
    # break counter
    COUNT=$((TRIES + 1))
    fi
    done
    
    [ -f $LOGNAME ] && TAIL=$(tail -n1 $LOGNAME)
    
    # alert mail in case of any problem (and exit)
    if ! checklog $LOGNAME ; then
    echo -e "$COMPANY stop was not proceeded properly: $TAIL"  gzip -9 $LOGNAME
    gzip -9 $LOGNAME
    [ -d $ERRLOGS ] && mv $LOGNAME.gz $ERRLOGS/$(date +%Y%m%d_%H%M).gz
    echo "$TAIL" > $LASTSTATUS
    exit 0
    fi
    
    # delete logfile in the end of successful run
    if [ -f $LOGNAME ] ; then
    gzip -9 $LOGNAME
    [ -d $OKLOGS ] && mv $LOGNAME.gz $OKLOGS/$(date +%Y%m%d_%H%M).gz
    fi
    
    # "OK mail" in case of successful run after previous error run
    if ! checklog $LASTSTATUS ; then
    echo -e "$COMPANY stop is all right now.\n\nScript exited with [OK] string. Number of tries: $TRIES. Here is last line from script: $TAIL"
    fi
    
    # log last output line to statusfile for test and "OK mail" eventually
    echo "$TAIL" > $LASTSTATUS
    
    exit 0
    
    priste to prosim dej jako formatovanej kod, lip se to pak cte ;-)
    Linux users everywhere, raise your keyboards into the air, we´re warriors, warriors of the world.
    24.5.2011 21:20 Martin
    Rozbalit Rozbalit vše Re: basch script a podmínka
    ne to není ono co potřebuji, potřebuji aby se to druhé echo vypsalo jen v případě že ta první podmínka bude OK. Pokud dopadne špatně tak aby se to druhé echo vůbec nezapsalo.
    24.5.2011 22:07 Mercuriuz | skóre: 16 | blog: Mercuriuz | V hospodě =)
    Rozbalit Rozbalit vše Re: basch script a podmínka
    specifikuj prosim tu "prvni podminku"
    Linux users everywhere, raise your keyboards into the air, we´re warriors, warriors of the world.
    24.5.2011 21:30 NN
    Rozbalit Rozbalit vše Re: basch script a podmínka
    if ! checklog $LOGNAME ; then
    Mam pocit, ze tahle podminka vubec nenastane, jelikoz funkce checklog vzdy vrati hodnotu a tudiz je vzdy true ,ale mozna se pletu.
    else
    # break counter
    COUNT=$((TRIES + 1))
    Zaprve na co cekat (?) a zadruhe je jednoduzsi pouzit
    break
    Btw, proc vubec pouzivat ciklus, kdyz stejne kontrolujes jen posledni radek ?
    # better to run as www user and with mutt installed
    Really ?
    # alert mail in case of any problem (and exit)
    if ! checklog $LOGNAME ; then
    
    # "OK mail" in case of successful run after previous error run
    if ! checklog $LASTSTATUS ; then
    
    Proc provadet tu samou vec trikrat, kdyz se da udelat jen nednou ?
    SCRIPTNAME="$0"
    TRIES="3"
    Na co pouzivat promenne, kdyz je pouzijes jen jednou ?

    silenost,

    NN

    PS: pouzivet tag pre diky..
    24.5.2011 22:36 NN
    Rozbalit Rozbalit vše Re: basch script a podmínka
    SCRIPTPATH=$(cd ${SCRIPTNAME%/*} && pwd)
    Coze? Tak takhle urcite ne..

    NN
    25.5.2011 05:34 Ash | skóre: 53
    Rozbalit Rozbalit vše Re: basch script a podmínka
    Podmínka ! checklog foo nastane v závislosti na návratové hodnotě funkce checklog (nula versus nenulová hodnota).

    Proměnné nejí něco, co "nahrazuje věci které se dělají víckrát". Proměnné jsou i symbolická jména a rovněž mohou plnit funkci konfiguračních proměnných.

    25.5.2011 06:03 Ash | skóre: 53
    Rozbalit Rozbalit vše Re: basch script a podmínka
    Vidím že tam nikde nepoužíváte žádné stavové proměnné, rozhodně checklog by bylo lepší volat jen jednou, možná by pomohlo něco jako:
    company_exited_flawlessly=false
    
    if checklog $LOGNAME ; then
    company_exited_flawlessly=true
    else
    company_exited_flawlessly=false
    fi
    
    (nebo víc skripťácky:
    checklog $LOGNAME && company_exited_flawlessly=true
    )
    
    if $company_exited_flawlessly; then
    ...
    else
    ...
    fi
    a to i v jiných místech.

    Pro ukončení smyčky lépe použít break (jak radí NN).

    Funkci checklog bych zlidštil a asi i nějak přejmenoval, aby už její název evokoval, jestli se v případě úspěchu očekává 0 nebo spíš 1. Dost to pomáhá čitelnosti, zvlášť pokud výsledek ještě navíc negujete (! checklog). Pokud by takových funkciček a podmínek bylo víc, umí to pokazit den.
    log_ok(){
    if [ -f $1 ] ; then
      if [ $(tail -n 1 $1 | grep -c '^\[OK\]') -eq 1 ] ; then
         return 0
       fi
    fi
    return 1
    }
    
    log_ok $LOGNAME && company_exited_flawlessly=true
    
    P.S. Jestli jsem funkci checklog někde použil obráceně tak se omlouvám, připadá mi že ji máte opačně, ale možná že ne, takhle po ránu bych fakt potřeboval spíš log_ok $LOGNAME && company_exited_flawlessly=true

    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.