GNU – Linux

Ecrire un script bash interactif avec saisie par l’utilisateur

Capture script bash interactifAprès mes premiers posts relatifs aux boucles while, for, expressions rationnelles, voici une utilisation combinée de ces petits scripts, pour construire un simple script interactif en BASH.

Le script utilisé ici est axé sur l’aspect didactique, permettant d’être utilisé comme une référence simple et facile pour écrire un script BASH interactif.

Ce script va dans l’ordre :
– Demander combien de saisies sont attendues
– Vérifier que les réponses sont cohérentes et non vides
– Stocker les résultat dans un tableau associatif (array) en variable
– Afficher le contenu du tableau associatif

[bash]
#!/bin/bash
# Ce script permet d’afficher un tableau suite a une saisie de liste simple
# Alexandre BLANC – http://blog.inforeseau.com – 11/2010

#Jusqu’a ce que la reponse soit composée par un nombre, j’attends la saisie
until [[ ${nombre} =~ ^[0-9]+$ ]]; do
echo "Combien de personnes a saisir ?"
read nombre
done

#Du nombre saisi jusqu’a 1 inclus, je vais executer
for (( i=${nombre}; i>=1; i– ))
do

#Tant que la variable est vide, j’attends la saisie
while [ -z ${nom[$i]} ]; do
echo "Veuillez saisir votre nom"
read nom[$i]
done

echo "Bienvenue ${nom[$i]}"

#Jusqu’a ce que la variable ne soit pas vide, j’attends la saisie
until [ ! -z ${prenom[$i]} ]; do
echo "Veuillez saisir votre prenom"
read prenom[$i]
done

echo "Ajouté ${prenom[$i]} ${nom[$i]}, on continue, plus que $i !"

done

echo "Listing de la totalité des noms :"

#Affiche tout le contenu du tableau (array) contenu dans la variable nom
echo ${nom[*]}

echo "Listing de la totalité du tableau associatif :"
for (( i=1; i<=${nombre}; i++ ))
do

echo ${prenom[$i]} ${nom[$i]}

done
#Sources :
#http://tldp.org/HOWTO/Bash-Prog-Intro-HOWTO-7.html
#http://tldp.org/LDP/abs/html/refcards.html#AEN21811
#http://www.linuxquestions.org/questions/programming-9/bash-scripting-check-for-numeric-values-352226/
#http://tldp.org/LDP/abs/html/arrays.html
[/bash]

Les points intéressants de ce script sont les différentes boucles utilisées (until, for, while), la lecture interactive de variables par l’utilisateur (read), le test de validation sur la première réponse, à l’aide de l’expression rationnelle (ou expressions régulières, regexp) pour s’assurer que la réponse est bien numérique.

Pour tester ce script, copier le contenu dans un fichier que vous nommerez par exemple « interactif.sh », auquel vous donnerez les droits d’exécution :
[bash]chmod +x interactif.sh[/bash]

Puis on le lance simplement :
[bash]./interactif.sh[/bash]

Sources :
http://tldp.org/HOWTO/Bash-Prog-Intro-HOWTO-7.html
http://tldp.org/LDP/abs/html/refcards.html#AEN21811
http://www.linuxquestions.org/questions/programming-9/bash-scripting-check-for-numeric-values-352226/
http://tldp.org/LDP/abs/html/arrays.html

Loading

Tags: , , , , , , , , ,

samedi, novembre 6th, 2010 Bash, GNU - Linux 5 Comments

Utiliser Xenu sous ubuntu linux pour vérifier les liens d’un site

Capture Xenu en fonction
L’outil Xenu est un petit programme très efficace pour vérifier l’intégrité des liens de votre site.

vous pouvez télécharger le logiciel à l’adresse suivante :
http://home.snafu.de/tilman/xenulink.html

Une fois téléchargé, vous obtenez un fichier xenu.zip qu’il convient de décompresser (sous GNU/Linux Ubuntu avec Gnome dans le cas présent), en cliquant avec le bouton droit de la souris, puis cliquer sur « extraire ici ».

Vous obtiendrez alors un fichier « Setup.exe ». Pour l’exécuter nous aurons besoin d’avoir « Wine » installé, si ça n’est pas le cas, ouvrez un terminal et tapez :
[bash]sudo apt-get install wine[/bash]
(confirmez l’installation).

Une fois « Wine » installé, nous devons autoriser le fichier « Setup.exe » à être exécuté, donc un clic droit sur le fichier puis, « propriétés ». Dans l’onglet « Permissions », cochez la case « Autoriser l’exécution du fichier comme un programme ».

Fenetre propriété de Xenu setup.exe

On clique maintenant avec le bouton droit de la souris sur « Setup.exe », et on choisit « Ouvrir avec Wine – Chargeur de programmes windows ». Effectuer l’installation avec les options par défaut (Next => I Agree => Next => Next => Install => Next => on decoche les 2 cases puis, Finish).

Vous retrouvez l’accès au programme installé via le menu application => Wine => Programmes => Xenu’s Link sleuth => Xenu.

On lance donc Xenu pour la première fois, une fois lancé, je vous recommande de modifier les préférences par défaut pour ne pas trop charger votre serveur web lors de l’analyse. Par le menu « Options », puis « Préférences », on arrive dans l’onglet « Basic » de Xenu. L’option « Parallel Threads » est par défaut sur 30, je vous recommande de baisser cette option à 5, ou 7 maximum.

Modifier les options de Xenu

En effet, ceci représente le nombre de requêtes simultanées que vous allez effectuer sur votre serveur ! Trop de requêtes simultanées, sur un serveur un peu chargé ou en production risque de rendre l’accès aux sites hébergés dessus ralenti, voir impossible. Autant éviter de parasiter votre propre installation.

Attention également à ceux qui auraient la super idée d’infliger ce traitement aux sites concurrents, sachez que des mécanismes de sécurité peuvent bloquer votre IP dans un tel cas, car trop de requêtes simultanées peut être vues comme une attaque informatique. Dans le meilleur des cas vous risquez de ne plus pouvoir joindre le serveur pour un certain temps, dans le pire des cas, une plainte pourrait être déposée à votre encontre (via votre IP) et ça pourrait finir en justice.
N’utilisez donc ce logiciel que pour vos propres analyses, ou alors avec un nombre de « thread » (processus) réduit au minimum pour une analyse concurrentielle.

Vous êtes maintenant prêts à lancer une analyse, pour cela, il suffit de passer par le menu « File » puis « Check URL », ou d’utiliser le raccourcis CTRL+N.
Dans le premier champs, saisissez l’adresse de votre site (http://www.votresite.com), et décochez « Check external links ». Par défaut il n’est pas nécessaire d’analyser les liens extérieurs, vous pourrez refaire l’analyse avec cette option une fois que votre site est entièrement optimisé.

Cliquez enfin sur « OK », et l’analyse démarre. Plus votre site comporte de liens, plus l’analyse prendra du temps.

L’avancement du processus est indiqué en bas à droite, une fois l’analyse terminée, Xenu vous propose de vous créer un rapport sitemap, il s’agit d’un plan du site (sitemap) issu de la recherche.

La création d’un sitemap via un outil comme Xenu ne présente que peu d’intérêt, car le travail que fait le programme (suivre les liens) est réalisé de la même façon par les robots d’indexation des moteurs de recherche. L’utilisation d’un sitemap n’est pertinent que si celui ci est alimenté dynamiquement, au fur et à mesure de l’ajout de contenu sur le site.

Vous pouvez maintenant consulter la liste de l’ensemble des URL présentes sur votre site. Tout ce qui apparaît en rouge est un problème que vous devriez corriger.

De plus, vous pouvez également vérifier que l’ensemble de vos liens possèdent bien une balise « title », ainsi qu’une description.

Voilà, un bon outil, utilisable sous GNU/Linux simplement grâce à Wine.

Loading

Tags: , , , , , , , , , , ,

samedi, novembre 6th, 2010 GNU - Linux, Reseau, Technologie 3 Comments

Suivre les logs systèmes en temps réel avec tail sous gnu/linux

Console - terminalUn atout dans les systèmes GNU/Linux, c’est principalement la « verbosité » du système.

Cela signifie, que lorsque vous avez un système GNU/Linux installé, soit sur votre machine, soit sur un serveur distant, vous pouvez consulter en temps réel les informations renvoyées par le système (dans une console / fenêtre terminal en local, ou connecté en SSH à un serveur distant).

Ce post s’adresse évidemment à un niveau plutôt débutant.

Les principales remontées d’informations sont les logs systèmes, le plus généralement inscrits dans le fichier /var/log/messages.

Pour suivre l’activité du fichier, vous allez pouvoir utiliser la commande « tail » comme ceci :
[bash]tail -f /var/log/messages[/bash]

Avec cette commande, les informations vont défiler automatiquement sur la sortie standard (votre console). Pour interrompre la consultation, pressez :
CTRL+C (les 2 touches en même temps).

Vous pouvez également conserver le processus actif, et reprendre la main sur la console, en plaçant le processus en arrière plan :
Lancement de la commande :
[bash]tail -f /var/log/messages[/bash]
Presser CTRL+Z (passage en arrière plan, en pause)
Taper : bg
La tache reste active en arrière plan (background).

Vous noterez qu’après avoir pressé CTRL+Z, la tache est numérotée [1] (ici 1, la première en arrière plan), et se retrouve à l’état « Stopped ». C’est en tapant « bg » et en validant, que la tache devient active.
Vous pouvez ainsi taper d’autres commandes, tout en ayant la visibilité sur les logs. Notez que les logs s’affichent quoi que vous fassiez, ce qui peut parasiter si vous être en train de taper autre chose.

L’intérêt de la chose, est, par exemple, de pouvoir monitorer en temps réel plusieurs fichiers de log, et pouvoir agir.

Par exemple, je veux surveiller en même temps mes logs systèmes, et mes logs apache (serveur web httpd) lorsque je le relance pour voir si tout va bien.

On part du principe qu’on est connecté en root (ou sudo bash) dans le terminal :
Analyse des logs système :
[bash]tail -f /var/log/messages[/bash]
Puis je presse CTRL+Z
Activation de la tâche en arrière plan :
taper : bg
Analyse simultanée des logs apache :
[bash]tail -f /var/log/httpd/error_log[/bash]
Passage en arrière plan : CTRL+Z
Activation de cette autre tâche en arrière plan :
bg
(vous noterez le petit [2] indiquant qu’il s’agit de la deuxième tâche tournant en arrière plan).
Puis je relance mes services pour voir ce que ça donne :
[bash]/etc/init.d/httpd restart[/bash]
(Vous aurez évidemment apache d’installé sur votre machine pour cet exemple !).

Vous verrez donc défiler les informations « habituelles » de redémarrage du service, et les logs générés par tout ceci.

Enfin, car vous allez en avoir besoin, il faut ramener les tâche en premier plan afin de pouvoir les interrompre !
Vous pouvez donc rappeler vos processus, soit simplement via la commande « fg » (foreground) comme ceci :
[bash]fg[/bash]
Soit en appelant la commande voulue par son numéro :
[bash]fg 1[/bash]
Puis il suffit de presser CTRL+C pour interrompre la tâche. Répétez la commande « fg » jusqu’à avoir le message :
[bash]bash: fg: current : tâche inexistante[/bash]
C’est bon il ne reste aucun processus en arrière plan !

Ceci est évidemment utilisable avec tous les logs renvoyés par le système, que vous trouvez généralement dans le dossier /var/log.

S’il vous arrive par erreur d’utiliser la commande « tail » sur un binaire (un programme), l’environnement de votre console peut être « chamboulé » et les caractères affichés devenir illisibles. Dans ce cas, appuyez sur CTRL+C et tapez la commande
[bash]reset[/bash]
(même si les caractères ne s’affichent pas correctement) et la situation devrait être rétablie.

J’espère que ce petit article pourra être utile à certains.

Source image : http://www.openclipart.org/detail/25561

Loading

Tags: , , , , , , , , , ,

mardi, novembre 2nd, 2010 Bash, GNU - Linux, Reseau, Technologie 5 Comments
Not f'd — you won't find me on Facebook
novembre 2024
L M M J V S D
 123
45678910
11121314151617
18192021222324
252627282930  
 

 
Suivez moi sur twitter - follow me on twitter
 
Follow on LinkedIn
[FSF Associate Member]
 
Free Software, Free Society
VIRTUALISATION :
Compacter une image virtualbox VDI
Bon petit tutoriel esxi
Marche d'appliances vmware
Installer ESXi sur un disque IDE
Installer ESXi 3.5 sur un disque USB
Installer proxmox avec DRBD et migration / réplication à chaud
Installer OSSEC avec VMware
Information sur le VDI
SECURITE - FIREWALL :
Ouvrir des ports dynamiquement iptables - knockd
Autre tres bon tuto knockd
Docs Arp poisoning - Anglais
Metasploit test de pénétration
Zone H - sites piratés en temps réel
Blog invisible things
Tips protection sécurité wordpress
Pfsense - distribution firewall opensource - adsl internet failover
Iproute 2 mini how to - linux advanced routing
ClearOS - la passerelle sécuritaire lan - wan
HAUTE DISPONIBILITE :
CDN - Accélération de la distribution de données
drbd iscsi ocfs2 dm multipath tutoriel
Load balancing LVS
Load balancing opensource list
HA-Proxy :
HAproxy - http load balancer
Simple tutoriel HAproxy
HAproxy - debian tutoriel
Centos - Ip failover
Configuratoin DM-Multipath Redhat
VMware Doubletake - continuité
Quelques liens sur la réplication MySQL : Manuel MySQL, chapitre sur la réplication
Manuel MySQL, Tutoriel clair sur la mise en place
Autre tuto sur la mise en place de la réplication MySQL
Références pour optimisation du serveur MySQL
Utilisation de EXPLAIN mysql pour optimiser vos bases
optimiser vos bases - requetes et index
STOCKAGE RESEAU :
Un outil de clonage disque en reseau
Internet NAS 250Go 250 accès VPN
Server ISCSI avec Ubuntu tuto
ISCSI centos redhat tutoriel
Gérer et étendre un LVM
Créer sa piratebox ! trop cool
Deaddrops, les clés USB dans les murs, aussi cool !
OPTIMISATION WORDPRESS :
Télécharger Xenu
Comment utiliser Xenu
optimisation hébergement wordpress
Super howto wordpress (En)
Test de charge serveur web - Load impact
VPN - ROUTEUR - LAN:
Zeroshell - le mini-routeur wifi tout en un
Retroshare, votre réseau d'échange crypté!
Openvpn sur centos redhat
Intégrer Linux dans active directory
Routage inter-vlan avec Linux
Routage avec OSPF
Network Weathermap
TENDANCES - WEB:
Boutons twitter
Analyser les tendances des recherches Google
Protocole sitemap - robots.txt
Creer des animations CSS3
Code php pour interagir avec twitter
E reputation
Jquery
TRUCS ET ASTUCES GNU/LINUX :
Tuxmachines.org - Actus et tips linux
Configurer GRUB2 et grub2 ici
Panoet - en anglais - tips & tricks
Readylines tips and trick pertinents
Squid Clamav - proxy antivirus
Apprendre Unix en 10 minutes
13 tips sur les expressions régulières
IE Sous linux IES
LDAP 2.4 Quickstart guide
Tutoriel LDAP
Installation annuaire LDAP
Serveur Mail Postfix - Dovecot - LDAP - MDS
Créer un linux personnalisé en ligne - custom linux
Super site sur linux - en
Capistrano - déploiement automatisé
MONITORING :
Nagios tutoriel et doc
Nagios plugin NRPE tuto
Nagios plugin NRPE autre tuto
Nagios plugin NRPE officiel
Zabbix - fonctionnalités
Zabbix - installation
Guide MRTGsys - grapher la charge locale
MRTGsys - ajouter des graphs
MRTGsys - interpréter les données
Shinken - Monitoring
Thruk Monitoring webinterface
Shinken - Tutoriel
Shinken - Référence chez Nicolargo
AUTRES LIENS :
RemixJobs IT jobs
USB Multiboot
Reset mot de passe windows
Java python et autres tips, intéressant !
Forum inforeseau
Open Clipart
Excellent comic en ligne
Inforeseau.fr