<?xml version="1.0" encoding="UTF-8" ?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
  <title>Latest snippets tagged sysadmin</title>
  <link rel="alternate" href="http://snippets.prendreuncafe.com/snippets/tagged/sysadmin/order_by/date"></link>
  <id>http://snippets.prendreuncafe.com/snippets/tagged/sysadmin/order_by/date</id>
  <updated>2009-06-01T11:25:27Z</updated>
  <author>
    <name>Symfony</name>
    <author_email>noreply@symfony-project.com</author_email>
  </author>
<entry>
  <title>Bannir les cronmails</title>
  <link href="http://snippets.prendreuncafe.com/snippet/100"></link>
  <updated>2009-06-01T11:25:27Z</updated>
  <id>100</id>
  <summary type="html">Si vous utilisez crontab, vous recevez sans doute souvent des emails à l'adresse du propriétaire du compte avec le détail des sorties standards et d'erreurs suite à l'execution des commandes programmées.

Pour éviter ces emails, on peut systématiquement masquer ces sorties lors de l'appel à la ligne, par exemple dans un crontab :

[code bash]
*/10 * * * * ./myprogram 1&gt; /dev/null 2&gt; /dev/null
[/code]
</summary>
</entry>
<entry>
  <title>Corriger l'encodage d'un fichier MYSql</title>
  <link href="http://snippets.prendreuncafe.com/snippet/69"></link>
  <updated>2007-06-08T14:54:18Z</updated>
  <id>69</id>
  <summary type="html">Pour corriger les caractères bizarres qui peuvent apparaitre à la place des accents après une remontée d'un fichier de dump, il est possible de fixer l'encodage pour la connexion en rajoutant au début du fichier la ligne :

[code]
SET CHARACTER SET &lt;encodage&gt;;
[/code]

J'utilise notamment souvent UTF8 dans ce cas, le fichier provenant d'un dump effectué sous linux, et remontant dans une base en latin1.</summary>
</entry>
<entry>
  <title>Dump de toutes les bases d'un serveur MySQL dans des fichiers multiples</title>
  <link href="http://snippets.prendreuncafe.com/snippet/67"></link>
  <updated>2007-04-26T18:49:13Z</updated>
  <id>67</id>
  <summary type="html">Si comme moi vous avez sous la main un serveur abritant plusieurs (dizaines, voir centaines de) bases de données, le jour où une des bases de données plante et qu'on vous demande de la restaurer, je vous souhaite bien du courage si vous n'avez qu'un résultat de mysqldump --all-databases sous la main. 

Afin de pallier ce problème, j'ai écris ce script bash qui vous facilitera bien la vie !

Au programme : 

 * sauvegarde des dump de chaque base dans des fichiers séparés compressés en gzip, eux même situés dans un dossier nommé en fonction de la date

 * suppression automatique du dump effectué il y a 7 jours.

Le script est destiné à être exécuté par un cron, par exemple toutes les nuits.

[code]
#!/bin/bash

#paramètres de configuration du script
#completer ici par le nom d'un utilisateur autorisé à dumper toutes vos bases :
strMysqlUser=&quot;&quot; 
#completer ici par le mot de passe de cet utilisateur :
strPassword=&quot;&quot; 
# completer ici par le chemin vers le repertoire de travail où va se trouver le dump
# il est possible de préfixer le répertoire  :
# &quot;/rep/de/travail/prefix_&quot; donnera alors /rep/de/travail/prefix_20070505
repTravail=&quot;&quot; 


#mémorisation de la date du jour et de la date d'il y a 7 jours
dateActuelle=$(date +%Y%m%d)
datePassee=$(date --date '7 days ago' +%Y%m%d)

#Suppression de la sauvegarde d'il y a 7 jours
echo &quot;[&quot;$(date +%F\ %X)&quot;] Suppression des dump du &quot;$datePassee
repTravailPasse=$repTravail$datePassee
rm -R $repTravailPasse

# début du dump
echo &quot;[&quot;$(date +%F\ %X)&quot;] Dump du : &quot;$dateActuelle
repTravailActuel=$repTravail$dateActuelle
mkdir $repTravailActuel
# récupération de la liste des bdd, &quot;tail -n +2&quot; est présent pour ne pas récupérer le titre &quot;Databases&quot; renvoyé par mysql
listDatabase=$(mysql --user=$strMysqlUser --password=$strPassword --exec=&quot;SHOW DATABASES;&quot; |  tail -n +2)

#dump de chaque base dans un fichier
for lineDatabase in $listDatabase
do
    echo &quot;[&quot;$(date +%F\ %X)&quot;] Debut du dump de la base &quot;$lineDatabase&quot; vers &quot;$repTravailActuel
    mysqldump --user=&quot;$strMysqlUser&quot; --password=&quot;$strPassword&quot; &quot;$lineDatabase&quot; | gzip &gt; &quot;$repTravailActuel&quot;/&quot;$lineDatabase&quot;.sql.gz
    echo &quot;[&quot;$(date +%F\ %X)&quot;] Dump compressé dans &quot;$repTravailActuel&quot;/&quot;$lineDatabase&quot;.sql.gz&quot;
done
echo &quot;[&quot;$(date +%F\ %X)&quot;] Fin de la sauvegarde&quot;
exit 0
 
[/code]</summary>
</entry>
<entry>
  <title>Lister le matériel de sa machine</title>
  <link href="http://snippets.prendreuncafe.com/snippet/59"></link>
  <updated>2007-02-26T16:22:29Z</updated>
  <id>59</id>
  <summary type="html">Lister toutes les informations de la machine : 

[code]
$ sudo lshw
[/code]


Il existe la possibilité d’exporter le résultat dans une page *.html : 

[code]
$ sudo lshw -html &gt; votre_nom_de_fichier.html
[/code]

via http://www.pastanque.be/splitsch/ubuntu/106/106.html et le planet ubuntu-fr (http://planet.ubuntu-fr.org)</summary>
</entry>
<entry>
  <title>Mailer un backup mysql comme attachement en ligne de commande</title>
  <link href="http://snippets.prendreuncafe.com/snippet/55"></link>
  <updated>2007-02-09T15:50:53Z</updated>
  <id>55</id>
  <summary type="html">On va utiliser mutt :

[code]
$ sudo apt-get install mutt
[/code]

La commande (cronable) :

[code]
$ mysqldump -uroot -p --all-databases --opt \
  | bzip2 &gt; /path/to/backup/export.sql.bz2 \
  &amp;&amp; echo &quot;En date du &quot; `date` \
  | mutt -s &quot;[Nikobox] Backup MySQL total du `date | awk '{ print $2,$3,$4}'`&quot; \
  -a /path/to/backup/export.sql.bz2 you@fai.com
[/code]</summary>
</entry>
<entry>
  <title>Sécuriser /tmp</title>
  <link href="http://snippets.prendreuncafe.com/snippet/54"></link>
  <updated>2007-02-05T22:10:24Z</updated>
  <id>54</id>
  <summary type="html">Beaucoup de script-kiddies s'amusent beaucoup avec le répertoire /tmp, par défaut aisément accessible et donc réceptacle à executables falacieux de tous poils.

Voici une méthode permettant de remplacer ce point de montage par un nouveau, de 40Mo mais dont la particularité sera de ne pas autoriser l'execution de programmes (héhé) :

[code bash]
# create a 40MB block device which will be the /tmp file system
cd /root
dd if=/dev/zero of=/root/tmpMnt bs=1024 count=40000
mkfs.ext3 -F /root/tmpMnt
# mount it at /tmp
mv /tmp /tmp.backup
mkdir /tmp
mount -o loop,noexec,nosuid,rw /root/tmpMnt /tmp
chmod 0777 /tmp
# make it so it is used on boot up
if ! grep -qai tmpMnt /etc/fstab ; then 
     echo &quot;/root/tmpMnt /tmp ext3 loop,noexec,nosuid,rw  0 0&quot; &gt;&gt; /etc/fstab
fi
# check your syntax is ok
mount -a
# check that programs in /tmp will not run
cp /bin/ls /tmp/
/tmp/ls
[/code]

Pour remonter /tmp avec droits d'execution :

[code bash]
# umount /tmp
# mount -o loop,rw /root/tmpMnt /tmp
[/code]

Et remonter la partition sans les droits d'execution :

[code bash]
# umount /tmp
# mount -o loop,noexec,nosuid,rw /root/tmpMnt /tmp
[/code]</summary>
</entry>
<entry>
  <title>Exclure un paquet d'un dist-upgrade</title>
  <link href="http://snippets.prendreuncafe.com/snippet/47"></link>
  <updated>2007-01-24T15:23:56Z</updated>
  <id>47</id>
  <summary type="html">Wajig permet de bloquer un paquet via sa sous-commande hold :

[code]
$ sudo apt-get install wajig
$ sudo wajig hold &lt;package_name&gt;
$ sudo apt-get update
$ sudo apt-get dist-upgrade
[/code]

Ici le paquet &lt;package_name&gt; ne sera pas mis à jour.

Avec aptitude, vous pouvez conserver un paquet en faisant :

[code]
$ aptitude hold package_name
[/code]

et enlever le drapeau « hold » avec

[code]
$ aptitude unhold package_name
[/code]
</summary>
</entry>
<entry>
  <title>Donner les pouvoirs d'administration système à un utilisateur</title>
  <link href="http://snippets.prendreuncafe.com/snippet/45"></link>
  <updated>2007-01-18T12:14:21Z</updated>
  <id>45</id>
  <summary type="html">En admettant l'existance d'un utilisateur toto :

[code]
$ sudo adduser toto admin
[/code]

L'utilisateur toto sera automatiquement ajouté aux sudoers et pourra donc executer le commande sudo en s'identifiant au moyen de son mot de passe.</summary>
</entry>
<entry>
  <title>Compter le nombre d'occurence d'un terme dans un répertoire</title>
  <link href="http://snippets.prendreuncafe.com/snippet/42"></link>
  <updated>2007-01-16T12:33:47Z</updated>
  <id>42</id>
  <summary type="html">Dans tous les fichiers de type texte, calcul du nombre d'occurence d'une chaîne de caractère avec grep et wc :

[code]
$ grep -r require_once /path/to/scan | wc -l
1454
[/code]

On peut aussi exclure certaines ressources ou répertoires, avec grep -v :

[code]
$ grep -r require_once /path/to/scan | grep -v .svn | wc -l
735
[/code]</summary>
</entry>
<entry>
  <title>Turn on Bash Smart Completion</title>
  <link href="http://snippets.prendreuncafe.com/snippet/37"></link>
  <updated>2007-01-11T13:07:14Z</updated>
  <id>37</id>
  <summary type="html">Just edit /etc/bash.bashrc

Uncomment the following lines, by removing the # in the beginning of the lines:

[code]
#if [ -f /etc/bash_completion ]; then
# . /etc/bash_completion
#fi
[/code]

Now, resource the modified file : 
[code]
$ source /etc/bash.bashrc
[/code]

Then try to tape apt-cache [TAB][TAB]

You will have this result in replacement of the habitual list of files and directories of your current path : 
[code]
$ apt-cache
add        dotty      dumpavail  pkgnames   rdepends   show       showsrc    unmet
depends    dump       gencaches  policy     search     showpkg    stats      xvcg
[/code]

It works with a lot of functions like cd (it will provide only directories), apt-get,...

It also enable code completion when using the sudo command.

Isn't it useful ?

Nota : The tip I give here is to activate Smart Completion for all users. If you want to activate it for only one user (or if you want to activate it but doesn't have write rights to /etc/bash.bashrc) you can modify your ~/.bashrc file and uncomment the same lines as described upper and resource it with 
[code]
$ source ~/.bashrc
[/code]</summary>
</entry>
</feed>
