at now +10 minutes <<< "rm -rf /tmp/tobedeleted"
at now +1 minutes <<< "init 6"
/etc/init.d/networking stop && /etc/init.d/networking start
atq
atrm 2
For multiline, consider a "HERE-doc"
at now +10 minutes <<ENDMARKER
rm -rf /tmp/tobedeleted
echo all done | mail -s 'completion notification' sysadmin@example.com
ENDMARKER
Un serveur, mais surtout un client pour faire du port knocking
screen -S machineA (ensuite on se co en ssh à machineA, puis CTRL A D pour detach)
screen -S machineB (ensuite on se co en ssh à machineB, puis CTRL A D pour detach)
etc
At the end of the day :
screen -ls affiche tous les screens (avec chacun une connexion vers le serv en ssh)
screen -r machineA pour aller sur le A
screen -r machineB pour aller sur le B
alias utiles :
alias sls='screen -ls' #Pour lister les screen
alias sr='screen -r' #Pour recover un screen
alias sn='screen -S' #Pour créer un nouveau screen
com > fic redirige la sortie standard de com dans le fichier fic,
com 2> fic redirige la sortie des erreurs de com dans le fichier fic,
com 2>&1 redirige la sortie des erreurs de com vers la sortie standard de com,
com < fic redirige l'entrée standard de com dans le fichier fic,
com1 | com2 redirige la sortie standard de la commande com1 vers l'entrée standard de com2.
Petit outil sympa qui donne l'explication de n'importe quelle commande shell (on peut c/c ce qu'on veut)l
Un wiki complet à lire sur quelques outils en bash
xargs sed cut awk grep find while for
bash# sed -i ’s/[texte_recherché]/[texte_de_remplacement]/’ monfichier.txt
Pour l’exercice nous allons dire que monfichier.txt comporte une liste d’anciennes adresses email @wanadoo.fr et que nous désirons les mettre à jour en @orange.fr .
bash# cat monfichier.txt
toto@wanadoo.fr
toto@wanadoo.fr
toto@wanadoo.fr
etc.
Donc dans ce cas, cela nous donnera :
bash# sed -i ’s/wanadoo/orange/g’ monfichier.txt
Voilà en détail l’explication :
On passe à la commande sed le paramètre “-i” pour l’édition du fichier monfichier.txt
Le paramètre “-s” (substituer) qui définit l’action de rechercher / remplacer,
l’expression régulière (REGEX),
puis le ‘g’ (action global) à la suite pour la modification de toutes les instances de la chaîne de caractères remplacer dans le fichier.
Dans le cas où on voudrait ne remplacer que la première qui aurait été trouvée, il faudra modifier comme suit : ‘s/texte1/texte2/’
Bon, cela fonctionne sur un fichier, maintenant dans le cas de plusieurs fichiers, voici la commande ‘find’ qui va compléter l’astuce.
bash# find . -maxdepth 1 -name “*.txt” -type f -exec sed -i ’s/wanadoo/orange/g’ {} \
En détail cela nous donne:
Nous utilisons la commande ‘find’ pour récupérer la liste des fichiers ‘.txt’ à traiter,
dans le dossier courant ‘.’ et de ne pas aller plus bas ‘-maxdepth 1′,
puis donc de lister les fichiers dont le nom finit par “*.txt” : ‘-name “*.txt” -type f’.
on utilise alors l’option ‘-exec’ pour dire à ‘find’ d’utiliser la commande qui suit sur les fichiers trouvés.
Et voilà, simple non ?
Site avec bon TD linux bash