Tutorial

How To Install and Configure Postfix on Ubuntu 14.04

Published on April 29, 2014
How To Install and Configure Postfix on Ubuntu 14.04
Not using Ubuntu 14.04?Choose a different version or distribution.
Ubuntu 14.04

Introduction

Postfix is a very popular open source Mail Transfer Agent (MTA) that can be used to route and deliver email on a Linux system. It is estimated that around 25% of public mail servers on the internet run Postfix.

In this guide, we’ll teach you how to get up and running quickly with Postfix on an Ubuntu 14.04 server.

Prerequisites

In order to follow this guide, you should have a Fully Qualified Domain Name pointed at your Ubuntu 14.04 server. You can find help on setting up your domain name with DigitalOcean by clicking here.

Install the Software

The installation process of Postfix on Ubuntu 14.04 is easy because the software is in Ubuntu’s default package repositories.

Since this is our first operation with apt in this session, we’re going to update our local package index and then install the Postfix package:

sudo apt-get update
sudo apt-get install postfix

You will be asked what type of mail configuration you want to have for your server. For our purposes, we’re going to choose “Internet Site” because the description is the best match for our server.

Next, you will be asked for the Fully Qualified Domain Name (FQDN) for your server. This is your full domain name (like example.com). Technically, a FQDN is required to end with a dot, but Postfix does not need this. So we can just enter it like:

example.com

The software will now be configured using the settings you provided. This takes care of the installation, but we still have to configure other items that we were not prompted for during installation.

Configure Postfix

We are going to need to change some basic settings in the main Postfix configuration file.

Begin by opening this file with root privileges in your text editor:

sudo nano /etc/postfix/main.cf

First, we need to find the myhostname parameter. During the configuration, the FQDN we selected was added to the mydestination parameter, but myhostname remained set to localhost. We want to point this to our FQDN too:

<pre> myhostname = <span class=“highlight”>example.com</span> </pre>

If you would like to configuring mail to be forwarded to other domains or wish to deliver to addresses that don’t map 1-to-1 with system accounts, we can remove the alias_maps parameter and replace it with virtual_alias_maps. We would then need to change the location of the hash to /etc/postfix/virtual:

virtual_alias_maps = hash:/etc/postfix/virtual

As we said above, the mydestination parameter has been modified with the FQDN you entered during installation. This parameter holds any domains that this installation of Postfix is going to be responsible for. It is configured for the FQDN and the localhost.

One important parameter to mention is the mynetworks parameter. This defines the computers that are able to use this mail server. It should be set to local only (127.0.0.0/8 and the other representations). Modifying this to allow other hosts to use this is a huge vulnerability that can lead to extreme cases of spam.

To be clear, the line should be set like this. This should be set automatically, but double check the value in your file:

<pre> mynetworks = <span class=“highlight”>127.0.0.0/8 [::ffff:127.0.0.0]/104 [::1]/128</span> </pre>

Configure Additional Email Addresses

We can configure additional email addresses by creating aliases. These aliases can be used to deliver mail to other user accounts on the system.

If you wish to utilize this functionality, make sure that you configured the virtual_alias_maps directive like we demonstrated above. We will use this file to configure our address mappings. Create the file by typing:

sudo nano /etc/postfix/virtual

In this file, you can specify emails that you wish to create on the left-hand side, and username to deliver the mail to on the right-hand side, like this:

<pre> <span class=“highlight”>blah@example.com username1</span> </pre>

For our installation, we’re going to create a few email addresses and route them to some user accounts. We can also set up certain addresses to forward to multiple accounts by using a comma-separated list:

blah@example.com        demouser
dinosaurs@example.com   demouser
roar@example.com        root
contact@example.com     demouser,root

Save and close the file when you are finished.

Now, we can implement our mapping by calling this command:

sudo postmap /etc/postfix/virtual

Now, we can reload our service to read our changes:

sudo service postfix restart

Test your Configuration

You can test that your server can receive and route mail correctly by sending mail from your regular email address to one of your user accounts on the server or one of the aliases you set up.

Once you send an email to:

<pre> <span class=“highlight”>demouser</span>@<span class=“highlight”>your_server_domain.com</span> </pre>

You should get mail delivered to a file that matches the delivery username in /var/mail. For instance, we could read this message by looking at this file:

nano /var/mail/demouser

This will contain all of the email messages, including the headers, in one big file. If you want to consume your email in a more friendly way, you might want to install a few helper programs:

sudo apt-get install mailutils

This will give you access to the mail program that you can use to check your inbox:

mail

This will give you an interface to interact with your mail.

Conclusion

You should now have basic email functionality configured on your server.

It is important to secure your server and make sure that Postfix is not configured as an open relay. Mail servers are heavily targeted by attackers because they can send out massive amounts of spam email, so be sure to set up a firewall and implement other security measures to protect your server. You can learn about some security options here.

<div class=“author”>By Justin Ellingwood</div>

Thanks for learning with the DigitalOcean Community. Check out our offerings for compute, storage, networking, and managed databases.

Learn more about our products

About the authors

Still looking for an answer?

Ask a questionSearch for more help

Was this helpful?
 
10 Comments


This textbox defaults to using Markdown to format your answer.

You can type !ref in this text area to quickly search our full set of tutorials, documentation & marketplace offerings and insert the link!

What records Do I have to write in the dns? What servers do I have to write in outlook?

Thanks

My mail just vanishes into thin air… I set up my server the way youdescribed, but sent mail never gets delivered.

I have the same issue. I tried adding ‘inet_protocols = ipv4’ to see if sending via IPv6 was the issue but that didn’t work either.

Hi Justin,

I would like to operate two different droplets - one for www and one for email. This would mean having to set up MX records that point to a different server than what they do for www. Is this possible with Postfix? I assume I can just point the domain to the MX record(s) of the Postfix email server?

Also, will there be a follow up tutorial for Dovecot? My understanding is Postfix allows you to receive and send on the server but Dovecot then allows you to configure POP3/IMAP so that email can be accessed by other means?

Thanks in advance.

Andrew

I follow this tutorial but I’m only receiving emails; when I try to send I get no error message, but does not send anything. Does anyone know how to solve this? thanks

Andrew SB
DigitalOcean Employee
DigitalOcean Employee badge
May 20, 2014

@luizhrmello: How are you trying to send the message? Did you try:

<pre> echo “Subject: test” | /usr/lib/sendmail -v user@destination.com Example </pre>

Could you pastebin the contents of <code>/var/log/mail.err</code> and <code>/var/log/mail.log</code> ?

Perfect! All this worked first time for me, no problems :)

I also followed Andrew SB’s instruction for sending email and this worked fine. The server seemed to hang for 30s or so but nothing major - I received the email.

Also, I did install ‘sendmail’ with

sudo apt-get install sendmail

Not sure if this was required but I presume it is?

Thanks again, folks.

Well…This is not working for me.AT ALL

At first…it kept giving me X-Postfix; unknown user: “username” error as a reply mail.

So after some searching, I changed my main.cf settings as below

mydestination = localhost, localhost.localdomain

(before : mydestination = example.com, localhost, localhost.localdomain)

After that…I didn’t get any reply mails from postfix saying about errors, But I didn’t receive any mail either…When I send an email to the server,it just vanishes.

I uninstalled SendMail too, because it gave errors while starting postfix mail system…

Im getting tired of this…Can anyone help me ?

Andrew SB
DigitalOcean Employee
DigitalOcean Employee badge
May 22, 2014

@prabhashwara: Remember to replace the values in red with the ones that match your domain and users.

Of course I did it…I just posted it here as example.com

I still couldn’t find any solution.It keeps telling X-Postfix; unknown user: “mymail”

Try DigitalOcean for free

Click below to sign up and get $200 of credit to try our products over 60 days!

Sign up

Join the Tech Talk
Success! Thank you! Please check your email for further details.

Please complete your information!

Become a contributor for community

Get paid to write technical tutorials and select a tech-focused charity to receive a matching donation.

DigitalOcean Documentation

Full documentation for every DigitalOcean product.

Resources for startups and SMBs

The Wave has everything you need to know about building a business, from raising funding to marketing your product.

Get our newsletter

Stay up to date by signing up for DigitalOcean’s Infrastructure as a Newsletter.

New accounts only. By submitting your email you agree to our Privacy Policy

The developer cloud

Scale up as you grow — whether you're running one virtual machine or ten thousand.

Get started for free

Sign up and get $200 in credit for your first 60 days with DigitalOcean.*

*This promotional offer applies to new accounts only.