Description

L'échange de mails est le moyen standard de communication au ResEl. Il permet de nombreuses choses :

  • aux machines d'envoyer des rapports (bugs, logs, ...) aux autres machines (centralisateur de log, voir ELK), ainsi qu'aux admins.
  • aux personnes le souhaitant, d'utiliser un mail @resel.fr
  • de faire circuler des mails d'adresses externes aux adresses internes
  • de mettre en place des mailings-listes

Le ResEl possède une stack de services mail permettant de mettre en place ces échange de mail au sein du réseau.

warning Cette page ne traite pas des mailing-lists, allez plutôt voir la page sur Sympa pour cela.

Contexte

Voici quelques points pour bien remettre en contexte cette page, et pour définir les limites entre ceux à quoi sert la stack.

Fournisseurs externes

La plupart des membres du ResEl utilisent des adresses mail @telecom-bretagne.eu, @imt-atlantique.net voire @gmail.com, ou bien d'autre. Ce sont des fournisseurs de mail externe, et en rien notre infrastructure n'intervient la dedans.

Mécanisme mail Linux

Linux fournit un mécanisme de mail natif, qui permet d'échanger des messages entre les utilisateurs d'un système (command mail). Cependant une machine Linux ne sait pas envoyer ce mail à l'extérieur. Pour ce faire, le système doit avoir un MTA : Mail Transfer Agent, plus de détails plus bas. C'est dans la configuration de ce MTA qu'apparait l'infrastructure mail du ResEl, pour que la machine sache comment envoyer un mail à une adresse.

Mailing-listes

Les mailing-listes sont un outil pratique pour grouper un message pour plusieurs destinataires. Bien entendu, les personnes d'une mailing-listes ont toutes un fournisseur de mail différents, gmail, laposte, ... Le rôle de l'outil de mailing-listes du ResEl (qui est Sympa, plus de détails dans l'article spécifique) est de centraliser et dispatcher les mails envoyer à une mailing-listes. Pour ça il définit des adresses mails reposant sur l'infrastructure mail du ResEl.

Mise en place

Il faut, pour comprendre la mise en place, avoir une bonne idée de comment fonctionne le réseau mail, savoir ce qu'est un MTA, un LDA, les protocoles POP, IMAP et SMTP. On ne vas pas rentrer dans les détails, voir les cours pour cela, cependant voici un schéma résumé :

{{{{{{ title Les mails expliqués aux ResEl note left of Alice: Have a mail to send Alice->MTA Local: mail [SMTP] MTA Local->MTA Relai: mail [SMTP] MTA Relai->LDA Toad: mail [SMTP] note right of Bob: Want to check email Bob->LDA Toad: Get mail [IMAP] LDA Toad->Bob: Ok, here are your mails [IMAP] }}}}}}

{{{{{{ title essai diagramme mliste loop pour tout utilisateurs Mliste->Client: envoi mail end }}}}}}

Au ResEl, Postfix joue le rôle de MTA : Mail Transfer Agent, c'est lui qui route les mails depuis l'exterieur vers l'intérieur, ou inversement. Debian utilise par défaut Exim, mais nous utilisons Postfix au ResEl. Lorsque les mails sont à destination d'un usager du ResEl, il les envoie à Dovecot, notre LDA : Local Delivery Agent. C'est lui qui va permettre aux utilisateurs de se connecter à leur compte, de récuperer les derniers mails, en utilisant IMAP(s) ou POP(s). Finalement, c'est à nouveau Postfix qui va, de part son rôle de MTA, servir à envoyer le mail d'un membre à son correspondant via SMTP.

Tout ces services sont mise en place sur Toad.

De plus, chaque serveur du ResEl à une instance Postfix, configurée pour envoyer correctement des mails aux admins.

TODO détailler plus, faire un schéma si nécéssaire.

Utilisation

Côté utilisateur

Rien à faire, ça devrait être magique.

On peut avoir sa propre addresse mail @resel.fr

Côté administrateur

Gestion des boîtes mails Dovecot

Commandes utiles

  • doveadm user $username
  • doveadm mailbox list -u $username

Pour connaître la taille de la boite mail (potentiellement très long): doveadm -f table mailbox status -u $username "messages vsize" INBOX

Pour totalement vider la boite mail d'un utilisateur (attention, suppression non réversible) doveadm -v expunge -u $username mailbox INBOX all

Gestion de la file d'attente

La file d'attente des messages est gérée par postqueue.

Afficher le nombre de messages dans la queue: postqueue -p | tail -n 1. Afficher les messages dans la queue: postqueue -p. Retenter l'expédition des messages dans la queue: postqueue -f (déplace tous les messages dans la queue active).