BASH
(→dump-Backupskript) |
(→IP-Validierung) |
||
| Zeile 97: | Zeile 97: | ||
==IP-Validierung== | ==IP-Validierung== | ||
| − | + | <source lang="bash"> | |
function valid_ip() | function valid_ip() | ||
{ | { | ||
| Zeile 120: | Zeile 120: | ||
echo "IP ist eine IPv4-Adresse" | echo "IP ist eine IPv4-Adresse" | ||
fi | fi | ||
| + | </source> | ||
==dump-Backupskript== | ==dump-Backupskript== | ||
Version vom 19. Dezember 2011, 18:55 Uhr
Inhaltsverzeichnis |
(Viele) Zeilen modifizieren, in denen ein Suchmuster (regex) vorhanden ist.
sed -e '/regex/command' eingabedatei > ausgabedatei
Bsp.: Alle Zeilen Löschen, in denen "ABC" am Anfang der Zeile steht.:
sed -e '/^ABC/d' eingabedatei.txt > ausgabedatei.txt
Vorsicht: ist die Eingabedatei gleich der Ausgabedatei, dann wird die Ausgabedatei am Ende leer sein. :-(
Bash Bashing
Unlesbare Bash-Skripte, unnötige externe Programmaufrufe und überlange Befehlsketten sind vermeidbar. Interessante Beiträge aus der gleichnamigen Beitragsserie des Linux-Magazins und weitere Anregungen folgen hier in Kurzform.
cut, sed, grep & Co. vermeiden
Quelle: Folge 5, Linux-Magazin 02/10
Parameter-Expansion
Nach dem Schema ${<Variable><Zeichen><Suchmuster>} erledigt die Bash viele Aufgaben selbst, die sonst mit cut, sed, grep oder awk gelöst werden. Als Zeichen # % / ^ , zulässig, die doppelte Angabe schaltet jeweils in den gierigen Modus und ersetzt alles bis zum letzten Vorkommen des Suchmusters.
| Zeichen | Bedeutung | Beispiel |
|---|---|---|
| # | Löschen von links | X="aabcabcc"; ${X#a}; löscht das erste a |
| ## | Löschen von links | X="aabcabcc"; ${X##a}; löscht alle führenden a (funktioniert in Bash 3.2 nicht, wo ist der Fehler?) |
| % | Löschen von rechts | X="aabcabcc"; ${X%c}; löscht das letzte c |
| %% | Löschen von rechts | X="aabcabcc"; ${X%c}; löscht alle c am Ende (funktioniert in Bash 3.2 nicht, wo ist der Fehler?) |
| / | Ersetzen (substitude) | X="aabcabcc"; ${X/b/d}; ersetzt 1. b durch d |
| / | Ersetzen (substitude) | X="aabcabcc"; ${X/b}; löscht 1. b |
| // | Ersetzen (substitude) | X="aabcabcc"; ${X//b/d}; ersetzt alle b durch d |
| // | Ersetzen (substitude) | X="aabcabcc"; ${X//b}; löscht alle b |
| funktioniert erst ab Bash 4 | ||
| ^ | Umwandeln in Großbuchstaben (uppercase) | X="aabcabcc"; ${X^a}; wandelt erstes a in A |
| ^^ | Umwandeln in Großbuchstaben (uppercase) | X="aabcabcc"; ${X^^bc}; wandelt alle bc in BC |
| ^^ | Umwandeln in Großbuchstaben (uppercase) | X="aabcabcc"; ${X^^}; wandelt alles in Grossbuchstaben |
| , | Umwandeln in Kleinbuchstaben (lowercase) | X="AABCABCC"; ${X,A}; wandelt erstes A in a |
| ,, | Umwandeln in Kleinbuchstaben (lowercase) | X="AABCABCC"; ${X,,BC}; wandelt alle BC in bc |
| ,, | Umwandeln in Kleinbuchstaben (lowercase) | X="AABCABCC"; ${X,,}; wandelt alles in Kleinbuchstaben |
praktische Beispiele:
VERZEICHNIS="${0%/*}"
löscht alles bis zum ersten / von rechts
ersetzt:
VERZEICHNIS=$(dirname "$0")
SKRIPTNAME="${0##*/}"
löscht alles bis zum letzten / von links
ersetzt:
SKRIPTNAME=$(basename "$0")
IP-Validierung
<source lang="bash">
function valid_ip()
{
local ip=$1
local stat=1
# bash 2:
# if ( echo $ip | egrep '^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$' > /dev/null ) ; then
# bash 3:
if [[ $ip =~ ^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$ ]]; then
OIFS=$IFS
IFS='.'
ip=($ip)
IFS=$OIFS
[[ ${ip[0]} -le 255 && ${ip[1]} -le 255 && ${ip[2]} -le 255 && ${ip[3]} -le 255 ]]
stat=$?
fi
return $stat
}
if valid_ip $IP; then
echo "IP ist eine IPv4-Adresse"
fi
</source>
dump-Backupskript
Enthält ein paar interessante Hacks.
<source lang="bash">
#!/bin/bash
# Funktionen
function backup_age() {
LEVEL=$1
if ! test -f /tmp/backups/home/$LEVEL; then
return 1
fi
LAST_DUMP=$(file /tmp/backups/home/$LEVEL \
| grep -o "... ... .. ..:..:.. ...." | head -1)
LAST_DUMP_EPOCH=$(date +%s -d "$LAST_DUMP")
NOW_EPOCH=$(date +%s)
echo $((NOW_EPOCH - LAST_DUMP_EPOCH))
}
function cleanup() {
LEVEL=$1
rm -f /tmp/backups/home/*.tmp
for file in /tmp/backups/home/*
do
base=$(basename $file)
test "$base" = "*" && break
test "$base" -le $LEVEL && continue
rm $file
done
}
# Programm
if ! test $(id -u) = 0; then
echo "$0: Keine Root-Rechte!" >&2
exit 1
fi
if ! backup_age 0 \
|| test $(backup_age 0) -gt 604800; then
dump -u -0 -f /tmp/backups/home/0.tmp /home \
&& mv /tmp/backups/home/0{.tmp,}
cleanup 0
elif ! backup_age 1 \
|| test $(backup_age 1) -gt 86400; then
dump -u -1 -f /tmp/backups/home/1.tmp /home \
&& mv /tmp/backups/home/1{.tmp,}
cleanup 1
else
dump -u -2 -f /tmp/backups/home/2.tmp /home \
&& mv /tmp/backups/home/2{.tmp,}
cleanup 2
fi
</source>
Datei einer bestimmten Größe mit zufälligem Inhalt erstellen
Brauchbar z.B. für Bandbreitentests.
dd if=/dev/urandom bs=1M count=4096 of=4gb_testdatei
In diesem Beispiel wird eine 4GB große Datei erstellt.
Zufälligen String mit einer definierten Länge erzeugen
- Kann z.B. zum erzeugen eines neuen Passwortes genutzt werden.
- Das Bsp.-script prüft:
- ob ein Parameter für die Länge des zu erzeugenden Strings übergeben wird,
- ob dieser ein Integer ist
- und dieser kleiner als 1000000 ist (dient gegen Rechnerstress).
- Die Standardlänge des Strings ist hier 10 Zeichen.
<source lang="bash">
#!/bin/bash
#
# function for random string
#
function randstrg () {
local strgLength
local strg
if [ $1 ]; then
strgLength=$1
else
strgLength=10
fi
strg=</dev/urandom tr -dc A-Za-z0-9 | head -c $strgLength
return $strg
}
#
# ERROR-handling if parameter 1 set, not to big and not a integer
#
if [ ${1} ]; then
if [ ! $(echo "${1}" | grep -E "^[0-9]+$") ] || [ "${1}" -gt 1000000 ]; then
echo 'wrong 1. parameter ( Must be an INTEGER <= 1000000! )'
echo 'usage:'
echo "${0} [ INTEGER ]"
exit
fi
fi
#
# GO
#
strg= randstrg ${1}
echo $strg
</source>