Compléments à la documentation Conky
Les codes donnés ci dessous sont à placer après la section TEXT de votre conkyrc
Références des Variables
Dans les scripts donnés ci-dessous, on ne vous donne que les codes génériques.
Vous pouvez retrouver les scripts qui ont permit la réalisation des images sur les liens suivants :
IL vous suffira d'ouvrir un unique fichier texte, d'y coller « Avant TEXT » et toutes les parties désirées qui suivent à la suite.
Afficher des informations sur l'ordinateur. Dans l'ordre : la version de la distribution, le numéro de version, le nom de version, le kernel, l'architecure, la vitesse du processeur, le temps d'activité.
${execi 86400 lsb_release -si} : ${execi 86400 lsb_release -sr} ${execi 86400 lsb_release -sc} $sysname : $kernel $machine $freq_dyn_g GHz Uptime : $uptime
Afficher un graphique de l'utilisation processeur, avec indication en % dans ce graphique.
Ici on va utiliser la variable voffset (vertical offset) pour positionner l'utilisation du processeur en % sur le graphique de celui-ci.
${cpugraph 5e7b7b d8deeb} ${voffset -24}${alignc}${cpu cpu1}%
Afficher l'utilisation (restant / totalité / graphique ) de la mémoire RAM et SWAP.
${color2}RAM : ${color1}$memperc% $mem /$memmax $membar ${color2}Swap : ${color1}$swapperc% $swap /$swapmax $swapbar ${color2}Process : ${color1}$processes Running : $running_processes
Ici ${color} est utilisé afin de redonner la couleur du texte par défaut définit dans la section précédent TEXT
La gestion de la température est un peu compliquée, car il faut indiquer à conky l'identifiant du capteur de T° qu'on souhaite afficher (c'est souvent le processeur, mais ce n'est pas une obligation). Et l'identifiant du capteur varie selon les ordinateurs (car le nombre de capteurs varie selon les PC). Il faut donc d'abord repérer l'identifiant du capteur souhaité.
(pseudo - 6.5.0-10-generic) ~ : sensors coretemp-isa-0000 Adapter: ISA adapter Package id 0: +38.0°C (high = +100.0°C, crit = +100.0°C) Core 0: +38.0°C (high = +100.0°C, crit = +100.0°C) Core 1: +37.0°C (high = +100.0°C, crit = +100.0°C) pch_skylake-virtual-0 Adapter: Virtual device temp1: +39.5°C iwlwifi_1-virtual-0 Adapter: Virtual device temp1: +33.0°C
${exec sensors | grep 'Package id 0' | cut -c17-23}
La commande $exec lance la commande sensors à chaque rafraîchissement du conky.
Puis grep recherche le libellé de ligne qui vous intéresse. Ici 'Package id 0'.
Puis cut -c extrait les caractères qui vous intéressent. Ici les caractères 17 à 23, qui affichent la T° (à ajuster - en comptant - pour chaque cas).
Cette méthode est assez simple, mais l'exécution en tâche de fonds de la commande sensors peut consommer 1 à 2% de puissance processeur en plus par rapport à la méthode suivante, un peu plus légère mais un peu plus complexe. On reprend à l'étape 3, et on en ajoute d'autres.
Un exemple de conky tout simple :
${offset 250}${voffset 25}${font GE Inspira:size=12}${hwmon 4 temp 1}C°${font}
La commande $offset décale l'affichage de 250 px vers la droite, et la commande $voffset de 25 px vers le bas.
La commande $font définie une police et sa taille.
$hwmon affiche le capteur de T° 4-1 (ici, c'est celui du processeur).
Il est à noter que les capteurs listés dans /sys/class/hwmon ne sont pas forcément des capteurs de T°, et qu'ils peuvent aussi être affichés en adaptant le conky. Par exemple ${hwmon 3 fan 2} pour le ventilateur 2.
Pour la T° du disque dur, voir le chapitre ci-dessous sur conky et les disques durs.
Afficher différentes informations sur des partitions (dans ce cas : Taille des disques durs sda et sdb). La variable fs_bar
(file system bar) reçoit 2 valeurs, la hauteur (ici 5 pixels) et la largeur (ici 120 pixels). Ces valeurs peuvent être omises.
${fs_used_perc /point/de/montage/}% ${fs_free /point/de/montage/} ${fs_bar 5,120 /point/de/montage/}
A noter que pour votre partition par défaut, l'indication du point de montage n'est pas obligatoire. Vous pouvez donc simplement écrire :
Utilisé : $fs_used_perc% - Libre : $fs_free ${fs_bar 5,120}
Notez la variable if_mounted
qui permet de vérifier que les disques sont montés, avant de lancer l'affichage. Même si vos disques sont montés après le lancement de conky, ceux-ci seront automatiquement affichés.
${if_mounted /point/de/montage/}Intitulé : ${fs_used_perc /point/de/montage/}% ${fs_free /point/de/montage/} ${fs_bar 5,120 /point/de/montage/}${endif}
Après avoir installé hddtemp, il suffit d'ajouter les lignes :
Local : sda ${hddtemp /dev/sda}°
Et on obtient :
sda : 35C° sdb : 42C°
sudo dpkg-reconfigure hddtemp
et répondez Oui à la question "Faut-il exécuter hddtemp avec les privilèges du superutilisateur ?".
Récupérer la température d'un disque distant (pratique dans le cas d'un NFS)
Voir les valeurs en vrac (exemple)
nick@hostname:~$ nc 192.168.xxx.xxx 7634 |/dev/sg0|Maxtor 6Y160P0|42|C||/dev/s
Première variante
${exec nc <ip> <port> | cut -d'|' -f4}°C
Légende | |
<ip> | Ip de la machine contenant les disques à contrôler |
<port> | port de la machine distante (pensez à ouvrir ce port dans le pare-feu) par défaut : 7634 |
cut -d'| ' | on découpe tous les '| ' (pipe), ça crée un tableau |
-f4 | on récupère la valeur à la position 4 (ce qui se trouve juste avant le 4ème '| ' donc) |
Seconde variante
${exec nc <ip> <port> | awk -F'|' '{ print $4 }'}°C
On récupère ainsi la valeur '42°C' dans les deux cas
L'affichage de l'utilisation réseau se fait via les fonctions downspeedf (débit montant / vitesse de téléchargement) et upspeedf (débit descendant). totaldown donne le total des données téléchargées, et totalup le total envoyé.
On va interroger le port Ethernet si on est en filaire, ou Wlan si on est en wifi. Comme les noms des interfaces réseau sont très différents d'une machine à une autre, vous pouvez tapez la commande route au terminal pour les connaître. Ci-dessous, l'interface réseau est une interface wifi, et le nom à mettre dans le conky est dans la colonne Iface (wlp58so).
(pseudo - 6.5.0-10-generic) ~ : route Table de routage IP du noyau Destination Passerelle Genmask Indic Metric Ref Use Iface default mysmartwifi.loc 0.0.0.0 UG 600 0 0 wlp58s0 link-local 0.0.0.0 255.255.0.0 U 1000 0 0 wlp58s0 192.168.1.0 0.0.0.0 255.255.255.0 U 600 0 0 wlp58s0
L'affichage s'ajuste grâce à 'offset' (retrait sur la ligne) et 'voffset' (déplacement vertical de l'affichage).
Exemple avec une interface réseau dont le nom est eth1 (c'est donc du filaire) :
Down ${offset 45}${totaldown eth1} ${offset 8}Up ${alignr}${totalup eth1} ${downspeedgraph eth0 22,150 5e7b7b d8deeb} ${upspeedgraph eth0 22,150 99c8e8 618094} ${offset 40}${voffset -21}${downspeedf eth1}k/s ${offset 190}${voffset -14}${upspeedf eth1}k/s
Ici dans le cas de deux cartes réseau. L'une en réseau vers l'extérieure, l'autre en local.
eth1 : ${addr eth1}
Afficher l'ip publique.
${texeci 3600 wget http://checkip.dyndns.org -O - -o /dev/null | cut -d : -f 2 | cut -d \< -f 1}
Affichage simple et complet.
eth0 : ${addr eth0} | ${totaldown eth0} | ${totalup eth0}
Dans le cas d'une seconde carte, non configurée et non connectée, conky affiche « No Address » en place de l'adresse ip de la carte.
Il est possible de récupérer nativement le nombre de mails non lus en précisant les adresses des serveurs POP et/ou IMAP, le nom d'utilisateur et le mot de passe.
Pour un serveur IMAP
#L'option -i est utilisée pour effectuer cette vérification toute les x secondes (ici toutes les 60 secondes, donc toute les minutes :) ) ${imap_unseen Adresse_serveur_IMAP Utilisateur Mot_de_passe -i 60}
Pour un serveur POP
#L'option -i est utilisée pour effectuer cette vérification toute les x secondes (ici toutes les 60 secondes, donc toute les minutes :) ) ${pop3_unseen Adresse_serveur_POP3 Utilisateur Mot_de_passe -i 60}
Il est à noter que j'ai essayé de récupérer les mails non lus via le POP3 de Free et que cela n'a pas fonctionné. Cela fonctionne très bien en adoptant le mode IMAP (imap_unseen).
Afficher les résultats d'un 'top'
PROCESS ${hr 2} Name ${alignr}CPU ${alignr}RAM ${color #e09495} ${top name 1} ${alignr}${top cpu 1} ${alignr}${top mem 1} ${color #e0d094} ${top name 2} ${alignr}${top cpu 2} ${alignr}${top mem 2} ${color1} ${top name 3} ${alignr}${top cpu 3} ${alignr}${top mem 3} ${color1} ${top name 4} ${alignr}${top cpu 4} ${alignr}${top mem 4} ${color1} ${top name 5} ${alignr}${top cpu 5} ${alignr}${top mem 5}