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í
×
    dnes 03:11 | Nová verze

    Poštovní klient Thunderbird byl vydán v nové verzi 145.0. Podporuje DNS přes HTTPS nebo Microsoft Exchange skrze Exchange Web Services. Ukončena byla podpora 32bitového Thunderbirdu pro Linux.

    Ladislav Hagara | Komentářů: 0
    dnes 02:33 | IT novinky

    U příležitosti státního svátku 17. listopadu probíhá na Steamu i GOG.com již šestý ročník Czech & Slovak Games Week aneb týdenní oslava a také slevová akce českých a slovenských počítačových her.

    Ladislav Hagara | Komentářů: 0
    včera 19:33 | Nová verze

    Byla vydána nová verze 9.19 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání. Vypíchnout lze například nový balíček BirdNET-Go, tj. AI řešení pro nepřetržité monitorování a identifikaci ptáků.

    Ladislav Hagara | Komentářů: 0
    včera 02:22 | Nová verze

    Byla vydána nová verze 3.38 frameworku Flutter (Wikipedie) pro vývoj mobilních, webových i desktopových aplikací a nová verze 3.10 souvisejícího programovacího jazyka Dart (Wikipedie).

    Ladislav Hagara | Komentářů: 0
    včera 01:33 | Nová verze

    Organizace Apache Software Foundation (ASF) vydala verzi 28 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.

    Ladislav Hagara | Komentářů: 0
    15.11. 16:11 | Nová verze

    Byl vydán Debian 13.2, tj. druhá opravná verze Debianu 13 s kódovým názvem Trixie. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 13 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.

    Ladislav Hagara | Komentářů: 0
    15.11. 12:11 | IT novinky

    Google představil platformu Code Wiki pro rychlejší porozumění existujícímu kódu. Code Wiki pomocí AI Gemini udržuje průběžně aktualizovanou strukturovanou wiki pro softwarové repozitáře. Zatím jenom pro veřejné. V plánu je rozšíření Gemini CLI také pro soukromé a interní repozitáře.

    Ladislav Hagara | Komentářů: 4
    14.11. 14:22 | Bezpečnostní upozornění

    V přihlašovací obrazovce LightDM KDE (lightdm-kde-greeter) byla nalezena a již opravena eskalace práv (CVE-2025-62876). Detaily v příspěvku na blogu SUSE Security.

    Ladislav Hagara | Komentářů: 5
    14.11. 13:22 | Nová verze

    Byla vydána nová verze 7.2 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Tor Browser byl povýšen na verzi 15.0.1. Další novinky v příslušném seznamu.

    Ladislav Hagara | Komentářů: 0
    14.11. 10:33 | IT novinky

    Česká národní banka (ČNB) nakoupila digitální aktiva založená na blockchainu za milion dolarů (20,9 milionu korun). Na vytvořeném testovacím portfoliu, jehož součástí jsou bitcoin, stablecoiny navázané na dolar a tokenizované depozitum, chce získat praktickou zkušenost s držením digitálních aktiv. Portfolio nebude součástí devizových rezerv, uvedla dnes ČNB v tiskové zprávě.

    Ladislav Hagara | Komentářů: 44
    Jaké řešení používáte k vývoji / práci?
     (35%)
     (46%)
     (19%)
     (18%)
     (23%)
     (15%)
     (23%)
     (16%)
     (16%)
    Celkem 356 hlasů
     Komentářů: 16, poslední 12.11. 18:21
    Rozcestník

    Dotaz: BASH script je příliš ukecaný

    19.8.2018 08:34 Käyttäjä 11133 | skóre: 58 | blog: Ajattelee menneisyyttä
    BASH script je příliš ukecaný
    Přečteno: 1067×
    Ahoj, snažím se napsat jednoduchý script, který mi namountuje LUKS šifrované disky na Turris Omnia... Zatím mám následující:
    #!/bin/bash
    
    verbose=0
    
    if [ -b /dev/sda ]; then
      echo "Disk /dev/sda detected!"
      set $disks
    else
      echo "Disk /dev/sda not detected!"
      unset $disks
    fi
    
    if [ -b /dev/sdb ]; then
      echo "Disk /dev/sdb detected!"
      set $disks
    else
      echo "Disk /dev/sdb not detected!"
      unset $disks
    fi
    
    if [ -z ${disks+x} ]; then
      if [ -b /dev/md0 ]; then
        echo "RAID md0 already exists"
      else
        if mdadm --assemble /dev/md0 /dev/sda /dev/sdb; then
          echo "RAID /dev/md0 assembled!"
        else
          echo "Raid /dev/md0 failed to assemble!"
        fi
      fi
    else
      echo "Disks sda and sdb are not present!"
    fi
    
    
    Avšak, když jej spustím, tak je neskutečně ukecaný, viz níže:
    root@turris01:~# mount-internal-crypto-drives bbb
    Disk /dev/sda detected!
    BASH=/bin/bash
    BASHOPTS=cmdhist:complete_fullquote:extquote:force_fignore:hostcomplete:interactive_comments:progcomp:promptvars:sourcepath
    BASH_ALIASES=()
    BASH_ARGC=([0]="1")
    BASH_ARGV=([0]="bbb")
    BASH_CMDS=()
    BASH_LINENO=([0]="0")
    BASH_SOURCE=([0]="/usr/local/bin//mount-internal-crypto-drives")
    BASH_VERSINFO=([0]="4" [1]="4" [2]="11" [3]="1" [4]="release" [5]="arm-openwrt-linux-gnu")
    BASH_VERSION='4.4.11(1)-release'
    DIRSTACK=()
    EUID=0
    GROUPS=()
    HOME=/root
    HOSTNAME=turris01.czko.perlur.cloud
    HOSTTYPE=arm
    IFS=$' \t\n'
    LOGNAME=root
    MACHTYPE=arm-openwrt-linux-gnu
    MAIL=/var/mail/root
    OPTERR=1
    OPTIND=1
    OSTYPE=linux-gnu
    PATH=/usr/bin:/usr/sbin:/bin:/sbin:/root/.acme.sh/:/usr/local/bin/
    PIPESTATUS=([0]="0")
    PPID=14913
    PS4='+ '
    PWD=/root
    SHELL=/bin/ash
    SHELLOPTS=braceexpand:hashall:interactive-comments
    SHLVL=2
    SSH_AUTH_SOCK=/tmp/ssh-NqAmXg83Kd/agent.14911
    SSH_CLIENT='192.168.1.12 53651 22'
    SSH_CONNECTION='192.168.1.12 53651 82.209.54.74 22'
    SSH_TTY=/dev/pts/0
    TERM=xterm-256color
    UID=0
    USER=root
    _='Disk /dev/sda detected!'
    verbose=0
    Disk /dev/sdb detected!
    BASH=/bin/bash
    BASHOPTS=cmdhist:complete_fullquote:extquote:force_fignore:hostcomplete:interactive_comments:progcomp:promptvars:sourcepath
    BASH_ALIASES=()
    BASH_ARGC=([0]="1")
    BASH_ARGV=([0]="bbb")
    BASH_CMDS=()
    BASH_LINENO=([0]="0")
    BASH_SOURCE=([0]="/usr/local/bin//mount-internal-crypto-drives")
    BASH_VERSINFO=([0]="4" [1]="4" [2]="11" [3]="1" [4]="release" [5]="arm-openwrt-linux-gnu")
    BASH_VERSION='4.4.11(1)-release'
    DIRSTACK=()
    EUID=0
    GROUPS=()
    HOME=/root
    HOSTNAME=turris01.czko.perlur.cloud
    HOSTTYPE=arm
    IFS=$' \t\n'
    LOGNAME=root
    MACHTYPE=arm-openwrt-linux-gnu
    MAIL=/var/mail/root
    OPTERR=1
    OPTIND=1
    OSTYPE=linux-gnu
    PATH=/usr/bin:/usr/sbin:/bin:/sbin:/root/.acme.sh/:/usr/local/bin/
    PIPESTATUS=([0]="0")
    PPID=14913
    PS4='+ '
    PWD=/root
    SHELL=/bin/ash
    SHELLOPTS=braceexpand:hashall:interactive-comments
    SHLVL=2
    SSH_AUTH_SOCK=/tmp/ssh-NqAmXg83Kd/agent.14911
    SSH_CLIENT='192.168.1.12 53651 22'
    SSH_CONNECTION='192.168.1.12 53651 82.209.54.74 22'
    SSH_TTY=/dev/pts/0
    TERM=xterm-256color
    UID=0
    USER=root
    _='Disk /dev/sdb detected!'
    verbose=0
    RAID md0 already exists
    root@turris01:~# 
    
    Nevíte čím to může být způsobeno?

    Řešení dotazu:


    Odpovědi

    19.8.2018 09:05 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    Je to způsobeno voláním set bez parametrů (konkrétně set $disks, kde $disks je nedefinovaná proměnná). set bez parametrů vypíše všechny proměnné prostředí.
    19.8.2018 21:22 Käyttäjä 11133 | skóre: 58 | blog: Ajattelee menneisyyttä
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    Ok, já myslel že právě set ji zadefinuje... :-/
    19.8.2018 09:06 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    Nikde jste nenastavil proměnnou disks a když spustíte příkaz set bez parametrů, vypíše hodnoty všech proměnných. Ale abych pravdu řekl, nením mi moc jasné, o co se to tam s tou proměnnou vlastně snažíte (a co očekáváte, že by v ní mělo být).
    19.8.2018 21:19 Käyttäjä 11133 | skóre: 58 | blog: Ajattelee menneisyyttä
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    Cokoli, pokud by v ní bylo cokoli tak se nespustí mdadm; samozřejmě script ještě nebyl kompletní, protože při kontrole sdb jsem ještě nekontroloval stav té proměnné, pokud by byla nenastavená tak by se test na sdb vůbec nespustil.
    k3dAR avatar 19.8.2018 21:27 k3dAR | skóre: 63
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    pak nemuzes "set $promena" ale "set promena"
    porad nemam telo, ale uz mam hlavu... nobody
    19.8.2018 21:32 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    V tom případě je problém asi v nepochopení, co dělají shellové příkazy set a unset. První umožňuje nastavit poziční parametry shellu (se kterými ale skript nepracuje) a druhý sice odstraní proměnnou, ale jako argument musí dostat její jméno (ne hodnotu).
    Řešení 2× (Filip Jirsák, mimi.vx)
    19.8.2018 21:36 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný

    Takže jestli to chápu dobře, ta pasáž na začátku měla vypadat spíš nějak takhle

    ALL_DISKS="/dev/sda /dev/sdb"
    
    disks=""
    for d in $ALL_DISKS; do
        if [ -b "$d" ]; then
            disks="$disks $d"
        fi
    done
    

    Výsledkem by bylo, že v proměnné disks budou ta ze zařízení v ALL_DISKS, která skript v systému najde.

    19.8.2018 10:03 mankind_boost
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    To mas z toho ze jsi veganska palice. Pichni si B12 a dalsich 100 vitaminu, ktere lze ziskat jen z masa, a nastav $disks
    19.8.2018 21:21 Käyttäjä 11133 | skóre: 58 | blog: Ajattelee menneisyyttä
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    Tady má někdo komplexy :) Má úroveň B12 je naprosto v pořádku, děkuji. Stejně tak železa, zinku, kalcia a vitamínu D.
    19.8.2018 21:58 mankind_boost
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    Vis jak poznas vegana? Rekne ti to
    20.8.2018 03:45 Käyttäjä 11133 | skóre: 58 | blog: Ajattelee menneisyyttä
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    A nechceš to své tvrzení alespoň ozdrojovat, když už plácáš hlouposti?
    k3dAR avatar 20.8.2018 06:55 k3dAR | skóre: 63
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    vis jak poznas hovado? zvoli si nick jako ty ;-)
    porad nemam telo, ale uz mam hlavu... nobody
    31.8.2018 13:29 mankind_boost | skóre: 7 | Hliněná chýše, 5482/3
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    Tak dík no.
    Jen skutečný mankind_boost je zárukou kvality.
    6.9.2018 10:35 Käyttäjä 11133 | skóre: 58 | blog: Ajattelee menneisyyttä
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    Komplexy? I to se dá léčit...
    6.9.2018 18:59 mankind_boost
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    Víš co už se nedá léčit? Osteoporóza. Dobře sis podělal život
    6.9.2018 20:24 Käyttäjä 11133 | skóre: 58 | blog: Ajattelee menneisyyttä
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    Škoda že tady nejdou postovat emoji ;-)
    6.9.2018 20:26 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    Když tak čtu tohle vlákno, napadá mne ještě jedna věc, která se moc nedá léčit…
    7.9.2018 12:03 manind_boost
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    7.9.2018 12:14 Käyttäjä 11133 | skóre: 58 | blog: Ajattelee menneisyyttä
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    There you go... and now go back in your corner to cry.
    7.9.2018 11:53 mankind_boost | skóre: 7 | Hliněná chýše, 5482/3
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    Všiml sis, že jsem jiná osoba než on? Nebo je to pro některé příliš mentálně náročný úkol...
    Jen skutečný mankind_boost je zárukou kvality.
    Řešení 2× (Filip Jirsák, Käyttäjä 11133 (tazatel))
    19.8.2018 10:28 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    Zkus tohle - je to ještě méně ukecané, než jsi původně zamýšlel
    #!/bin/bash
    
    declare -a disks=("/dev/sda" "/dev/sdb")
    raid="/dev/md0"
    for disk in ${disks[@]}; do
        if [ ! -b "$disk" ]; then
            echo "Disk $disk not detected!" >&2
            exit 1
        fi
    done
    if [ -b "$raid" ]; then
        echo "RAID $raid already exists" >&2
        exit 2
    fi
    mdadm --assemble "$raid" ${disks[@]}
    if [ ! -b "$raid" ]; then
        echo "Raid $raid failed to assemble!" >&2
        exit 3
    fi
    
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    19.8.2018 21:20 Käyttäjä 11133 | skóre: 58 | blog: Ajattelee menneisyyttä
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    Díky, s poli v bashi jsem už tak dlouho nedělal, že se mi s tí nechtělo patlat. Takže díky za pomoc. Tohle funguje, jen trošku poupravím!
    20.8.2018 13:42 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: BASH script je příliš ukecaný
    Dá se to udělat i se stringem - viz výše v jiném příspěvku.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.

    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.