ht.xyz


Setting up a basic mail server

2022-11-04

After messing around for a LONG time, I finally have a way to set up a basic mail server using postfix + dovecot.

What this post will help you get

What you won't get

What you will need

The steps

Install postfix and dovecot.

sudo apt-get install postfix dovecot-common dovecot-imapd dovecot-pop3d

Open the postfix config file at /etc/postfix/main.cf and clear it. Replace the contents with the below code, but make sure you change some variables accordingly.

    smtpd_banner = $myhostname ESMTP $mail_name (Debian/GNU)     
    biff = no     
    append_dot_mydomain = no     
    readme_directory = no     
    compatibility_level = 2     
    smtpd_tls_cert_file=/etc/letsencrypt/live/example.com/fullchain.pem     
    smtpd_tls_key_file=/etc/letsencrypt/live/example.com/privkey.pem     
    smtpd_tls_security_level=may     
    smtp_tls_security_level=may     
    smtp_tls_session_cache_database = btree:${data_directory}/smtp_scache     
    smtpd_relay_restrictions = permit_mynetworks permit_sasl_authenticated defer_unauth_destination     
    myhostname = example.com     
    alias_maps = hash:/etc/aliases     
    alias_database = hash:/etc/aliases     
    myorigin = /etc/mailname     
    mydestination = $myhostname, example.com, localhost.in, , localhost     
    relayhost =      
    mynetworks = 127.0.0.0/8 [::ffff:127.0.0.0]/104 [::1]/128     
    mailbox_size_limit = 0
    recipient_delimiter = +     
    inet_interfaces = all     
    inet_protocols = ipv4     
    home_mailbox = .Mail/     
    smtpd_sasl_type = dovecot
    smtpd_sasl_path = private/auth

For line number 6 and 7 in the above code you will have to generate certificates using certbot for whichever domain you want to use.

sudo certbot -d example.com

Open /etc/postfix/master.cf and uncomment the line that starts with submission.

submission inet n - y - - smtpd

Now moving on to dovecot configuration, the default is fine apart from some minor changes listed below.

For /etc/dovecot/dovecot.conf, add the below lines:

protocols = imap pop3 listen = *, ;;

In /etc/dovecot/conf.d/10-ssl.conf define the path for the certificates you created before.

In /etc/dovecot/conf.d/10-mail.conf, edit the following

mail_location = maildir:~/.Mail

Restart postfix and dovecot.

sudo systemctl restart postfix.service sudo systemctl restart dovecot.service

I will not post testing and such, this is supposed to be a reference guide not a tutorial. Have fun!

Post a Comment