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 00:11 | Nová verze

    Open source modální textový editor Helix, inspirovaný editory Vim, Neovim či Kakoune, byl vydán ve verzi 25.07. Přehled novinek se záznamy terminálových sezení v asciinema v oznámení na webu. Detailně v CHANGELOGu na GitHubu.

    Ladislav Hagara | Komentářů: 0
    včera 20:44 | IT novinky

    Americký výrobce čipů Nvidia získal od vlády prezidenta Donalda Trumpa souhlas s prodejem svých pokročilých počítačových čipů používaných k vývoji umělé inteligence (AI) H20 do Číny. Prodej těchto čipů speciálně upravených pro čínský trh by tak mohl být brzy obnoven, uvedla firma na svém blogu. Americká vláda zakázala prodej v dubnu, v době eskalace obchodního sporu mezi oběma zeměmi. Tehdy to zdůvodnila obavami, že by čipy mohla využívat čínská armáda.

    Ladislav Hagara | Komentářů: 4
    včera 17:22 | Nová verze

    3D software Blender byl vydán ve verzi 4.5 s prodlouženou podporou. Podrobnosti v poznámkách k vydání. Videopředstavení na YouTube.

    Ladislav Hagara | Komentářů: 0
    14.7. 22:22 | Komunita

    Open source webový aplikační framework Django slaví 20. narozeniny.

    Ladislav Hagara | Komentářů: 0
    14.7. 16:11 | Komunita

    V Brestu dnes začala konference vývojářů a uživatelů linuxové distribuce Debian DebConf25. Na programu je řada zajímavých přednášek. Sledovat je lze online.

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

    Před 30 lety, tj. 14. července 1995, se začala používat přípona .mp3 pro soubory s hudbou komprimovanou pomocí MPEG-2 Audio Layer 3.

    Ladislav Hagara | Komentářů: 28
    14.7. 10:55 | IT novinky

    Výroba 8bitových domácích počítačů Commodore 64 byla ukončena v dubnu 1994. Po více než 30 letech byl představen nový oficiální Commodore 64 Ultimate (YouTube). S deskou postavenou na FPGA. Ve 3 edicích v ceně od 299 dolarů a plánovaným dodáním v říjnu a listopadu letošního roku.

    Ladislav Hagara | Komentářů: 21
    13.7. 17:55 | Zajímavý projekt

    Společnost Hugging Face ve spolupráci se společností Pollen Robotics představila open source robota Reachy Mini (YouTube). Předobjednat lze lite verzi za 299 dolarů a wireless verzi s Raspberry Pi 5 za 449 dolarů.

    Ladislav Hagara | Komentářů: 17
    11.7. 16:44 | Komunita

    Dnes v 17:30 bude oficiálně vydána open source počítačová hra DOGWALK vytvořena v 3D softwaru Blender a herním enginu Godot. Release party proběhne na YouTube od 17:00.

    Ladislav Hagara | Komentářů: 3
    11.7. 14:55 | Humor

    McDonald's se spojil se společností Paradox a pracovníky nabírá také pomocí AI řešení s virtuální asistentkou Olivii běžící na webu McHire. Ian Carroll a Sam Curry se na toto AI řešení blíže podívali a opravdu je překvapilo, že se mohli přihlásit pomocí jména 123456 a hesla 123456 a získat přístup k údajům o 64 milionech uchazečů o práci.

    Ladislav Hagara | Komentářů: 16
    Jaký je váš oblíbený skriptovací jazyk?
     (59%)
     (26%)
     (7%)
     (3%)
     (1%)
     (1%)
     (4%)
    Celkem 399 hlasů
     Komentářů: 16, poslední 8.6. 21:05
    Rozcestník

    Dotaz: Skript puštěný z cronu běží neúměrně dlouho

    1.8.2013 14:46 CecilKa | skóre: 6 | blog: Vsehochut
    Skript puštěný z cronu běží neúměrně dlouho
    Přečteno: 380×
    Zdravím všechny a prosím o radu.

    Pro synchronizaci FTP (namountováno přes curlftpfs) na můj domácí disk spouštím skript s rsync.

    Pokud tento skript spustím "ručně" z terminálu, tak synchronizace složek trvá cca 30-40 minut, ale když ho spustím pomocí cronu, tak běží hodiny a konec se neblíží.

    Původně jsem zkoušel synchronizovat celý FTP do složky, po této zkušenosti jsem skript zkusil předělat na postupnou synchronizaci jednotlivých adresářů na FTP do jednotlivých podsložek na mém disku, ale výsledek - rychlost je stejná.

    Kde by mohla být chyba?

    Skript:

    #!/bin/bash
    
    SOURCEFOLDER='/mnt/ftp_xyz_cz'
    TARGETFOLDER='/home/karel/Backup/ftp'
    
    ZACATEK=$(date)
    if mountpoint -q /mnt/ftp_xyz_cz; then
      echo "FTP is mounted" > /home/karel/Backup/rsync_ftp.log
      find $SOURCEFOLDER/backup/*.jpa -mtime +30 -exec rm {} \;
      find $SOURCEFOLDER/backup/*.sql.gz -mtime +10 -exec rm {} \;
      for i in `ls -1 $SOURCEFOLDER`; do
        if ls $TARGETFOLDER/$i >/dev/null; then
          ZAC=$(date)
          echo -e "\n\n==========================================================" >> /home/karel/Backup/rsync_ftp.log
          echo "Synchronizuji adresář: "$TARGETFOLDER/$i >> /home/karel/Backup/rsync_ftp.log
          echo "==========================================================" >> /home/karel/Backup/rsync_ftp.log
          rsync -vhrtlz --exclude-from=/usr/local/bin/rsync_ftp_exclude.txt --delete $SOURCEFOLDER/$i/ $TARGETFOLDER/$i/ >> /home/karel/Backup/rsync_ftp.log
          KON=$(date)
          echo -e "\nZačátek v:\t$ZAC\nKonec v:\t"$KON >> /home/karel/Backup/rsync_ftp.log
        else
          echo "Vytvarim adresar: "$TARGETFOLDER/$i >> /home/karel/Backup/rsync_ftp.log
          mkdir $TARGETFOLDER/$i >> /home/karel/Backup/rsync_ftp.log
          ZAC=$(date)
          echo -e "\n\n==========================================================" >> /home/karel/Backup/rsync_ftp.log
          echo "Synchronizuji adresář: "$TARGETFOLDER/$i >> /home/karel/Backup/rsync_ftp.log
          echo "==========================================================" >> /home/karel/Backup/rsync_ftp.log
          rsync -vhrtlz --exclude-from=/usr/local/bin/rsync_ftp_exclude.txt --delete $SOURCEFOLDER/$i/ $TARGETFOLDER/$i/ >> /home/karel/Backup/rsync_ftp.log
          KON=$(date)
          echo -e "\nZačátek v:\t$ZAC\nKonec v:\t"$KON >> /home/karel/Backup/rsync_ftp.log
        fi
      done 
    else
      echo "FTP not mounted!" >> /home/karel/Backup/rsync_ftp.log
    fi
    KONEC=$(date)
    echo -e "\n\nZačátek v:\t$ZACATEK\nKonec v:\t"$KONEC >> /home/karel/Backup/rsync_ftp.log
    

    Řešení dotazu:


    Odpovědi

    Řešení 1× (voda)
    1.8.2013 16:47 CecilKa | skóre: 6 | blog: Vsehochut
    Rozbalit Rozbalit vše VYŘEŠENO: Skript puštěný z cronu běží neúměrně dlouho

    Tak chyba byla nalezena, do crontabu stačilo doplnit řádky:

    SHELL=/bin/bash
    PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin

    Snad moje blbost v budoucnu někomu pomůže.... :-)

    1.8.2013 17:07 Kit
    Rozbalit Rozbalit vše Re: VYŘEŠENO: Skript puštěný z cronu běží neúměrně dlouho
    Když jsem viděl tu hromadu neošetřených stringů, tak jsem ten skript ani nedočetl. Ten skript je od základu špatně a je jen otázkou času, kdy na to doplatíš.
    1.8.2013 17:23 CecilKa | skóre: 6 | blog: Vsehochut
    Rozbalit Rozbalit vše Re: VYŘEŠENO: Skript puštěný z cronu běží neúměrně dlouho
    A můžeš svůj názor více objasnit, abych věděl co hledat , upravovat...
    "Skript" zbastlím jednou za .... pár let? A kdybych teď náhodou nebyl po operaci, tak se k tomu ani nedostanu...
    Ale i tak díky za tvůj příspěvek.
    1.8.2013 18:41 potato
    Rozbalit Rozbalit vše Re: VYŘEŠENO: Skript puštěný z cronu běží neúměrně dlouho
    Tak pro začátek použít * namísto `ls`, kde se to okamžitě rozbije s mezerami v názvech souborů.

    Stejně tak všechny argumenty příkazů jako $SOURCEFOLDER/$i/ by měly být v uvozovkách, aby zůstaly vcelku.

    Ty findy jsou trochu svérázné, ale budiž. Alespoň použij -delete namísto spouštění rm.
    1.8.2013 18:45 Kit
    Rozbalit Rozbalit vše Re: VYŘEŠENO: Skript puštěný z cronu běží neúměrně dlouho
    Už jedna mezera v názvu způsobí, že ti skript přestane fungovat. Přitom stačí drobná změna:
    for i in "$SOURCEFOLDER"/*; do
        rsync -vhrtlz --exclude-from=/usr/local/bin/rsync_ftp_exclude.txt --delete \
            "$i" "$TARGETFOLDER/" >> /home/karel/Backup/rsync_ftp.log  
    done
    
    Skript je najednou jednodušší a bezpečnější. Na ty uvozovky nezapomínej.
    1.8.2013 19:11 CecilKa | skóre: 6 | blog: Vsehochut
    Rozbalit Rozbalit vše Re: VYŘEŠENO: Skript puštěný z cronu běží neúměrně dlouho
    TO: potato & kit
    Děkuji oběma za vaše tipy a nasměrování
    Na ten problém s mezerami v názvech jsem narazil při testování a mám ho tu poznamenaný, jako bod k řešení, ale vzhledem k tomu, že v tuto chvíli je na FTP vše bez mezer a ani nemám ve zvyku zapisovat názvy s mezerou - mám rád "_" :-), takže to nebyl prvořadý problém.

    Ono, když teď vím, kde byl zakopaný pes tak se asi mohu vrátit k mnohem jednodušší - původní variantě, kdy prostě dám synchronizovat jen složku, kde je namountován FTP a složku pro zálohy.

    A na ty uvozovky se budu snažit myslet - až zase jednou budu bastlit (kdyby jste věděli, kolik času jsem strávil nad "svéráznými findy" a ostatními řádky skriptu :-) ).

    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.