Outils pour utilisateurs

Outils du site


linux:memo_bash

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentesRévision précédente
Prochaine révision
Révision précédente
linux:memo_bash [27/02/2014 16:59] daniellinux:memo_bash [10/09/2020 09:58] (Version actuelle) – [Memo BASH] daniel
Ligne 3: Ligne 3:
   * [[http://abs.traduc.org/abs-fr/index.html|Guide avancé d'écriture des scripts Bash]]   * [[http://abs.traduc.org/abs-fr/index.html|Guide avancé d'écriture des scripts Bash]]
   * http://www.davidpashley.com/articles/writing-robust-shell-scripts/   * http://www.davidpashley.com/articles/writing-robust-shell-scripts/
 +  * https://www.shellcheck.net/
 +  * https://bash3boilerplate.sh/ 
 +  * https://devhints.io/bash
 +  * https://devdocs.io/bash/
  
-===== vrac ===== 
  
 +===== vrac =====
  
  
Ligne 11: Ligne 15:
 Pour rediriger les erreurs dans le meme log : commande >log 2>&1 Pour rediriger les erreurs dans le meme log : commande >log 2>&1
  
-Cf http://wiki.bash-hackers.org/howto/redirection_tutorial#an_example pour un exemple instructif de file descriptors +  * http://www.tldp.org/LDP/abs/html/ioredirintro.html et http://www.tldp.org/LDP/abs/html/ioredirintro.html 
- +  * http://wiki.bash-hackers.org/howto/redirection_tutorial#an_example pour un exemple instructif de file descriptors 
-Cf http://xensoft.com/content/use-exec-direct-all-bash-script-output-file-syslog-or-other-command pour capture de stdout|stderr dans un script+  http://xensoft.com/content/use-exec-direct-all-bash-script-output-file-syslog-or-other-command pour capture de stdout|stderr dans un script
  
 Cf aussi  Cf aussi 
   trap commande signal   trap commande signal
 pour exécuter une commande en cas de signal (le try/catch du bash) pour exécuter une commande en cas de signal (le try/catch du bash)
 +
 +Attention, si on capture stdout avec un truc comme 
 +<code bash>
 +exec > >(while read line; do echo "[$(date '+%F %T')] $line" >> $LOGRAP; done)
 +</code>
 +le contenu du fichier $LOGRAP est pas immédiatement disponible dans le script principal (quand un sous-shell écrit dans un fichier, faut visiblement qu'il ait terminé pour que le parent soit sûr de récupérer le contenu.
  
 ==== gestion des processus liés au terminal (avant/arrière plan, attachés/détachés) ==== ==== gestion des processus liés au terminal (avant/arrière plan, attachés/détachés) ====
Ligne 29: Ligne 39:
 ==== jobs et at ==== ==== jobs et at ====
 On peut lister les jobs en cours avec ''jobs -p'', mais ça ne concernent pas les jobs en attente de at (du genre ''echo 'faire un truc' | at 14:42''), qui sont dans /var/spool/cron/atjobs/, mais que l'on peut lister avec ''atq'' ou virer avec ''atrm $numero_du_job''. On peut lister les jobs en cours avec ''jobs -p'', mais ça ne concernent pas les jobs en attente de at (du genre ''echo 'faire un truc' | at 14:42''), qui sont dans /var/spool/cron/atjobs/, mais que l'on peut lister avec ''atq'' ou virer avec ''atrm $numero_du_job''.
- 
- 
  
 ==== variables ==== ==== variables ====
Ligne 202: Ligne 210:
  
 ===== Commandes ===== ===== Commandes =====
 +Cf http://ss64.com/bash/ pour une liste de commandes bash et programmes gnu
  
 ==== vrac ==== ==== vrac ====
Ligne 230: Ligne 239:
 </file> </file>
  
-Pour RECOPIER UNE ARBORESCENCE (et son contenu) se placer dans le répertoire de destination et entrer 
-(cd /rep_a_copier ; tar cf - *) | tar xvf -  
-explication dans "le système Linux", p188 
-Apparemment devenu inutile depuis que cp a l'option -R. 
- 
-==== cat ==== 
-<file> 
-  -b, --number-nonblank    number nonblank output lines 
-  -E, --show-ends          display $ at end of each line 
-  -n, --number             number all output lines 
-  -s, --squeeze-blank      never more than one single blank line 
-  -T, --show-tabs          display TAB characters as ^I 
-  -v, --show-nonprinting   use ^ and M- notation, except for LFD and TAB 
-</file> 
-==== tail ==== 
-<file> 
-Usage: tail [OPTION]... [FILE]... 
-Print the last 10 lines of each FILE to standard output. 
-With more than one FILE, precede each with a header giving the file name. 
-With no FILE, or when FILE is -, read standard input. 
- 
-      --retry              keep trying to open a file even if it is 
-                             inaccessible when tail starts or if it becomes 
-                             inaccessible later -- useful only with -f 
-  -c, --bytes=N            output the last N bytes 
-  -f, --follow[={name|descriptor}] output appended data as the file grows; 
-                             -f, --follow, and --follow=descriptor are 
-                             equivalent 
-  -n, --lines=N            output the last N lines, instead of the last 10 
-      --max-unchanged-stats=N 
-                           with --follow=name, reopen a FILE which has not 
-                             changed size after N (default 5) iterations 
-                             to see if it has been unlinked or renamed 
-                             (this is the usual case of rotated log files) 
-      --pid=PID            with -f, terminate after process ID, PID dies 
-  -q, --quiet, --silent    never output headers giving file names 
-  -s, --sleep-interval=S   with -f, each iteration lasts approximately S 
-                             (default 1) seconds 
-  -v, --verbose            always output headers giving file names 
-      --help               display this help and exit 
-      --version            output version information and exit 
- 
-If the first character of N (the number of bytes or lines) is a `+', 
-print beginning with the Nth item from the start of each file, otherwise, 
-print the last N items in the file.  N may have a multiplier suffix: 
-b for 512, k for 1024, m for 1048576 (1 Meg).  A first OPTION of -VALUE 
-or +VALUE is treated like -n VALUE or -n +VALUE unless VALUE has one of 
-the [bkm] suffix multipliers, in which case it is treated like -c VALUE 
-or -c +VALUE. 
- 
-With --follow (-f), tail defaults to following the file descriptor, which 
-means that even if a tail'ed file is renamed, tail will continue to track 
-its end.  This default behavior is not desirable when you really want to 
-track the actual name of the file, not the file descriptor (e.g., log 
-rotation).  Use --follow=name in that case.  That causes tail to track the 
-named file by reopening it periodically to see if it has been removed and 
-recreated by some other program. 
-</file> 
- 
-==== ls ==== 
-<file> 
--l format long 
--h human readable 
--S sort by file size 
--t sort by modification time 
--X sort alphabetically by entry extension 
-</file> 
- 
-==== wc ==== 
-"word count" 
- 
-  wc -l donne le nb de lignes 
- 
-  cat toto.txt | grep titi | wc -l 
-donne le nb de lignes où 'titi' apparait dans le fichier toto.txt, mais vaut mieux le faire avec 
-  grep -c titi toto.txt 
- 
-==== tar ==== 
- 
-  tar cvzf archive.tgz repertoire_a_archiver 
-prends tous les fichiers de repertoire_a_archiver (sous-rep inclus) et les mets dans archive.tgz, idem en bzip2 avec 
-  tar cvjf archive.tar.bz2 repertoire_a_archiver 
- 
-  tar xvzf archive.tgz decompresse l'archive (dans le rep courant) 
-et en général 
-  tar xvf archive.tgz 
-suffit 
- 
-==== gzip ==== 
-<file> 
-usage: gzip [-cdfhlLnNrtvV19] [-S suffix] [file ...] 
- -c --stdout      write on standard output, keep original files unchanged 
- -d --decompress  decompress 
- -f --force       force overwrite of output file and compress links 
- -h --help        give this help 
- -l --list        list compressed file contents 
- -L --license     display software license 
- -n --no-name     do not save or restore the original name and time stamp 
- -N --name        save or restore the original name and time stamp 
- -q --quiet       suppress all warnings 
- -r --recursive   operate recursively on directories 
- -S .suf  --suffix .suf     use suffix .suf on compressed files 
- -t --test        test compressed file integrity 
- -v --verbose     verbose mode 
- -V --version     display version number 
- -1 --fast        compress faster 
- -9 --best        compress better 
- file...          files to (de)compress. If none given, use standard input. 
-</file> 
 ==== find ==== ==== find ====
  
-pour afficher tous les fichiers de + de 20Ko (FreeBSD, 20k autorise sous linux)+pour afficher tous les fichiers de + de 20Ko (FreeBSD, notation 20k autorisée sous linux)
   find /path \( -size +20000c \) -exec ls -l {} \;   find /path \( -size +20000c \) -exec ls -l {} \;
 lister les fichier de /tmp de 0 octets de + de 60mn lister les fichier de /tmp de 0 octets de + de 60mn
Ligne 348: Ligne 248:
 pour renommer les mp3 en swf pour renommer les mp3 en swf
   for i in *.mp3; do mv $i ${i%mp3}swf ;done   for i in *.mp3; do mv $i ${i%mp3}swf ;done
- 
-==== grep ==== 
-<file> 
-Usage: grep [OPTION]... PATRON [FICHIER] ... 
-Search for PATTERN in each FILE or standard input. 
-Example: grep -i 'hello world' menu.h main.c 
- 
-Regexp selection and interpretation: 
-  -E, --extended-regexp     PATRON est une expression regulière étendue 
-  -F, --fixed-regexp        PATRON est une chaîne fixe séparée par des retour de chariot 
-  -G, --basic-regexp        PATRON est une expression régulière de base 
-  -e, --regexp=PATTERN      utiliser le PATRON comme expression régulière 
-  -f, --file=FILE           obtenir le PATRON du FICHIER 
-  -i, --ignore-case         ignorer la distrinction de la casse 
-  -w, --word-regexp         forcer l'appariement du PATRON que sur des mots complets 
-  -x, --line-regexp         forcer l'appariement du PATRON que sur des lignes entières 
-  -z, --null-data           terminer la ligne de données par ZÉRO et 
-                            non pas par un retour de chariot 
- 
-Divers: 
-  -s, --no-messages         supprimer les messages d'erreur 
-  -v, --revert-match        sélectionner les lignes sans concordances 
-  -V, --version             afficher le nom et la version du logiciel 
-      --help                afficher l'aide et quitter 
-      --mmap                utiliser la table de mémoire à l'entrée si possible 
- 
-Output control: 
-  -b, --byte-offset         print the byte offset with output lines 
-  -n, --line-number         print line number with output lines 
-  -H, --with-filename       print the filename for each match 
-  -h, --no-filename         suppress the prefixing filename on output 
-  -q, --quiet, --silent     suppress all normal output 
-      --binary-files=TYPE   assume that binary files are TYPE 
-                            TYPE is 'binary', 'text', or 'without-match'. 
-  -a, --text                equivalent to --binary-files=text 
-  -I                        equivalent to --binary-files=without-match 
-  -d, --directories=ACTION  how to handle directories 
-                            ACTION is 'read', 'recurse', or 'skip'. 
-  -r, --recursive           equivalent to --directories=recurse. 
-  -L, --files-without-match only print FILE names containing no match 
-  -l, --files-with-matches  only print FILE names containing matches 
-  -c, --count               only print a count of matching lines per FILE 
-  -Z, --null                print 0 byte after FILE name 
- 
-Contrôle du contexte: 
-  -B, --before-context=N    imprimer N lignes du contexte d'en-tête 
-  -A, --after-context=N     imprimer N lignes du contexte finale 
-  -C, --context[=N]         imprimer N lignes (2 par défaut) du contexte 
-                            à moins que -A ou -B ne soit spécifié 
-  -N                        identique à --context=N 
-  -U, --binary              ne pas enlever les caractères CR sur 
-                            les fins de lignes (MS-DOS) 
-  -u, --unix-byte-offsets   afficher les adresses relatives comme si 
-                            aucun CR n'était présent (MS-DOS) 
- 
-`egrep' est équivalent à `grep -E'. `fgrep' est équivalent à `grep -F'. 
-Sans FICHIER, ou si - est utilisé comme nom de FICHIER, la lecture 
-se fait de l'entrée standard. S'il y a moins de 2 FICHIERS, l'option -h 
-est implicite. Termine avec 0 s'il y a concordance avec 1 si aucune. 
-Termine avec 2 s'il y a des erreurs de syntaxe ou de système. 
-</file> 
  
 ==== sed ==== ==== sed ====
Ligne 451: Ligne 290:
 Voir aussi tr qui remplace des caractères (sans regexp, lire le man pour les pbs avec l'utf8). Voir aussi tr qui remplace des caractères (sans regexp, lire le man pour les pbs avec l'utf8).
  
-sed est aussi efficace pour afficher une ligne particulière +sed est aussi efficace pour afficher une ligne particulière (ici la ligne 288) 
-  sed -e '288 !d' </etc/apache/httpd.conf +  sed -e '288 !d' <fichier 
-affichera la ligne 288 (ou plutôt n'effacera pas, le "!d", la 288e ligne du fichier en entrée) +ou  
-et +  sed -ne '288 p
 + 
 +ou un bloc de lignes
   sed -e '288,291 !d' </etc/apache/httpd.conf   sed -e '288,291 !d' </etc/apache/httpd.conf
-affichera les lignes 288 à 291, tout comme+ou
   sed -ne '288,291 p' </etc/apache/httpd.conf   sed -ne '288,291 p' </etc/apache/httpd.conf
-(on affiche pas sauf demande explicite) 
  
 ==== cut ==== ==== cut ====
Ligne 466: Ligne 306:
 pour récupérer les GUIDuser du log nl3i pour récupérer les GUIDuser du log nl3i
 grep kne nl3i_access.log | grep 'GET /kne/index.php?GUIDUser' | cut -d' ' -f7 | cut -d= -f2 | cut -d'&' -f1 grep kne nl3i_access.log | grep 'GET /kne/index.php?GUIDUser' | cut -d' ' -f7 | cut -d= -f2 | cut -d'&' -f1
- 
-==== php ==== 
-<file> 
-sur ns2230, le binaire php est dans /usr/local/bin/php 
-Usage: php [-q] [-h] [-s] [-v] [-i] [-f <file>] 
-       php <file> [args...] 
-  -a               Run interactively 
-  -C               Do not chdir to the script's directory 
-  -c <path>|<file> Look for php.ini file in this directory 
-  -n               No php.ini file will be used 
-  -d foo[=bar]     Define INI entry foo with value 'bar' 
-  -e               Generate extended information for debugger/profiler 
-  -f <file>        Parse <file> Implies `-q' 
-  -h               This help 
-  -i               PHP information 
-  -l               Syntax check only (lint) 
-  -m               Show compiled in modules 
-  -q               Quiet-mode.  Suppress HTTP Header output. 
-  -s               Display colour syntax highlighted source. 
-  -v               Version number 
-  -w               Display source with stripped comments and whitespace. 
-  -z <file>        Load Zend extension <file>. 
-</file> 
  
 ==== mysql ==== ==== mysql ====
Ligne 514: Ligne 331:
  
 ex de backup & mail ex de backup & mail
 +
 <code bash> <code bash>
 #!/bin/sh #!/bin/sh
Ligne 524: Ligne 342:
 /usr/bin/uuencode $fichier_attache $nom_fichier| mail -s "$sujet" $envoyer_a; /usr/bin/uuencode $fichier_attache $nom_fichier| mail -s "$sujet" $envoyer_a;
 </code> </code>
 +
 +==== mail ====
  
 un simple un simple
linux/memo_bash.1393516786.txt.gz · Dernière modification : 27/02/2014 16:59 de daniel