82

How can I make crontab email me with the output of its jobs? I have MAILTO=redacted@yahoo.com.au above the jobs, but it doesn't work.

I know I need to use something like Postfix or Sendmail but for the life of me I cannot find out how to achieve this. I've searched and searched for a simple guide on setting up Postfix but they're all insanely complicated and expect you to be setting up a whole server to send and receive email and to know all the terms (like, what is a domain name for outgoing emails?).

All I want to do is have crontab email me. Why is this so difficult??

Additional Info:

My crontab file looks like this:

MAILTO=redacted@yahoo.com.au
1 0 * * * ~/Desktop/toskymesh.sh
59 6 * * * ~/Desktop/tooptus.sh
0 3 * * * snapraid sync

More Additional Info:

The output of ps -ef | grep '[s]endmail'

root 6840 1370 0 10:26 ? 00:00:00 sendmail: MTA: accepting connections

I know for sure cron is working, but I'm testing the mail command with echo Test | mail -s Test redacted@yahoo.com.au anyway.

Clonkex
  • 1,684

6 Answers6

56

In the end I used sSMTP. It's far simpler than either Postfix or sendmail and does the job beautifully.

For future reference, here's how to use sSMTP with Yahoo Mail (don't worry, it's a lot less complex than it looks):

  • Use your package manager to download ssmtp. I used Synaptic, but sudo apt-get install ssmtp should work as well.

  • Open the config file at /etc/ssmtp/ssmtp.conf.

  • Make the config look like this:

    root=yourRealEmail@yahoo.com.au       <--- Use your real email here
    mailhub=smtp.mail.yahoo.com:587       <--- This will depend on your email provider
    FromLineOverride=YES
    UseSTARTTLS=YES
    AuthUser=yourRealEmail@yahoo.com.au   <--- Use your real email here
    AuthPass=yourRealYahooPassword        <--- Use your real email password here
    TLS_CA_File=~/cert.pem
    
  • Create the cert.pem file with OpenSSL. I used openssl req -x509 -newkey rsa:2048 -keyout key.pem -out cert.pem -days 9999 -nodes (more info at How to create a self-signed certificate with OpenSSL). You can stick the file anywhere, but I just chucked it in ~/. Wherever you put it, make sure you point the TLS_CA_File= line in ssmtp.conf to the correct location.

  • Open the file /etc/ssmtp/revaliases and add the line (replacing the appropriate sections with your details):

    yourPCUsername:yourRealEmail@yahoo.com.au:smtp.mail.yahoo.com:587
    

    If you're running as root, I assume you would need to add another line replacing your name with 'root'.

  • That's it, you're good to go! To test, the easiest way (IMO) is to create a file with the following in it:

    To: yourRealEmail@yahoo.com.au                       <--- Use your real email here...
    From: "whateverYaWant" <yourRealEmail@yahoo.com.au>  <--- ...and here
    Subject: Some Notifying Email
    MIME-Version: 1.0
    Content-Type: text/plain
    

    Body of your email goes here. Hello world!

  • Check that you don't have the real sendmail installed by running sendmail -V. It should say 'sSMTP'.

  • Finally, run cat fileWithEmailInIt.txt | sendmail -i -t, then wait a few seconds (10-30) and check your email!

Additional note 1: If you have trouble with Gmail, try option 1 of this answer.
(Thanks to Ben Creasy!)

Additional note 2: If mail is sending from the command line but not through crontab, try changing FromLineOverride to NO in /etc/ssmtp/ssmtp.conf. You can also get more detailed logging by adding Debug=YES to ssmtp.conf - the extra logging goes to /var/log/mail.log.
(Thanks Jakub Kukul!)

Clonkex
  • 1,684
24

Install Postfix. It is more complicated than most other packages but it's still not complicated.

sudo apt-get install postfix

Select "Internet Site" and then accept all the defaults. Then we just need to stop outside connections, turning this into a "null client". Run: sudoedit /etc/postfix/main.cf and find the inet_interfaces setting (near the end) and change it to loopback-only, like so:

inet_interfaces = loopback-only

And finally restart Postfix with sudo /etc/init.d/postfix restart (reloading won't do).

You now have a Postfix install that won't relay email for outside machines, it'll just accept connections on 127.0.0.1 (and ::1 for IPv6).


On a separate note, your cron lines are probably not working because you're using non-relative paths and paths with Bash substitutions in. sh doesn't understand ~ and it might not have a proper PATH set. So replace them with (I'm just guessing at the actual paths):

1 0 * * *   /home/clonkex/Desktop/toskymesh.sh
59 6 * * *  /home/clonkex/Desktop/tooptus.sh
0 3 * * *   /usr/bin/snapraid sync

And if your scripts require to be run from a specific directory, make sure they cd into the right directory. Don't assume that cron will be in the right place as it likely won't.

Oli
  • 299,380
5

I had very good luck with exim4.

sudo apt-get install alpine exim4 mailutils eximon4 spf-tools-perl swaks

(alpine is just the mail client I like using)

After that, I ran

sudo dpkg-reconfigure exim4-config

and followed through the prompts. This page: https://help.ubuntu.com/community/Exim4 was very helpful as well. It took me about 10 minutes to get it running.

Oh Ar
  • 51
  • 1
  • 1
4

In case you don't want email notifications, but want to log cron jobs' output somewhere to be able to inspect it if need be:

# apt install postfix

Select "Local only" when asked for a mail server configuration type.

To confirm that cron will be able to send mail:

# apt install mailutils
# echo test body | mail -s 'test subject' root
# cat /var/mail/root

Alternatively add a cron job:

* * * * * date

Wait for it to run (journalctl -ef or watch date), then cat /var/mail/root.

x-yuri
  • 621
3

From sSMTP manpage: "It does not do aliasing, which must be done either in the user agent or on the mailhub. Nor does it honor .forwards, which have to be done on the recieving host. It especially does not deliver to pipelines."

So, if you want to receive all msgs sent to root on your extenal email, it's a bad idea to use sSMTP, because it does not support aliases.

Instead, you could user postfix. It's still very simple. Here's how to use it with gmail as your smtp for sending messages:

sudo apt-get install postfix mailutils

General type of mail configuration: Satellite system

System mail name: The preferred fully-qualified name of the mail server, e.g., mail.example.com

SMTP relay host (blank for none): [smtp.gmail.com]:587

Add to /etc/postfix/main.cf:

smtp_use_tls = yes
smtp_sasl_auth_enable = yes
smtp_sasl_password_maps = hash:/etc/postfix/sasl/sasl_passwd
smtp_sasl_security_options = noanonymous
smtp_sasl_tls_security_options = noanonymous

Create /etc/postfix/sasl/sasl_passwd

[smtp.gmail.com]:587 emailtouseforsending@gmail.com:password

Then:

sudo postmap /etc/postfix/sasl/sasl_passwd
sudo chown -R root:postfix /etc/postfix/sasl
sudo chmod 750 /etc/postfix/sasl
sudo chmod 640 /etc/postfix/sasl/sasl_passwd*

Edit /etc/aliases and add:

root: email@example.com

Lastly, run:

sudo newaliases
sudo systemctl stop postfix.service
sudo systemctl start postfix.service

Now, you can test if redirecting is working:

echo "Test to root." | mail -s "Test message to root" root

Hope it helps.

duli
  • 489
1

I used a pretty simple method to get cron to send emails: Backup Linux configuration, scripts and documents to Gmail.

Simplest way to automate sending email

From Send email alerts using ssmtp we find the simplest way of sending email automated from terminal or script. The installation steps are straight forward:

sudo apt install ssmtp
sudo nano /etc/ssmtp/ssmtp.conf
# Change "MyEmailAddress" and "MyPassword" to your own.

There is one step not mentioned; Google will send you an email confirming you want to allow a "less secure" application to send mail with your account:

gmail turns on less secure apps for email

There is an annoyance of getting too much mail. For example every time you mistype your sudo password you will get an email: Stop emailing me bad sudo password attempts