I have a small python script below which sends emails to my company outlook email. it works fine on my personal computer but when i am deploying it to server it keeps running and timeout but doesn't send email .
import os
import smtplib
import subprocess
from sys import exit
cmd = 'df -kh'
p1 = subprocess.Popen(cmd,shell=True,stdout=subprocess.PIPE,stderr=subprocess.PIPE)
std,err = p1.communicate()
output=std.decode()
#print (output)
smtp=smtplib.SMTP('smtp.outlook.com', 587)
smtp.ehlo()
smtp.starttls()
smtp.ehlo()
smtp.login('email','password')
subject = 'Send_Disk_Info_Daily'
body = output;
msg = (("subject : {} ".format(subject))+("\n\n{}".format(body)))
smtp.sendmail('email', 'email',msg)
smtp.quit()
Below is the error when it gets timedout-
Traceback (most recent call last):
File "send_disk_info.py", line 16, in <module>
smtp=smtplib.SMTP_SSL('smtp.outlook.com', 587, timeout=20)
File "/usr/lib64/python2.7/smtplib.py", line 789, in __init__
SMTP.__init__(self, host, port, local_hostname, timeout)
File "/usr/lib64/python2.7/smtplib.py", line 255, in __init__
(code, msg) = self.connect(host, port)
File "/usr/lib64/python2.7/smtplib.py", line 315, in connect
self.sock = self._get_socket(host, port, self.timeout)
File "/usr/lib64/python2.7/smtplib.py", line 794, in _get_socket
new_socket = socket.create_connection((host, port), timeout)
File "/usr/lib64/python2.7/socket.py", line 571, in create_connection
raise err
socket.error: [Errno 101] Network is unreachable
I am not able to do telnet to outlook, it also gets timed out. see below:-
[linux_server Python]$ telnet smtp.outlook.com 587
Trying 40.101.4.2...
^C
[linux_server Python]$
below are listening ports on this server.
linux_server Python]$ netstat -tulpn|grep -i listen
(Not all processes could be identified, non-owned process info
will not be shown, you would have to be root to see it all.)
tcp 0 0 0.0.0.0:5666 0.0.0.0:* LISTEN -
tcp 0 0 127.0.0.1:199 0.0.0.0:* LISTEN -
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN -
tcp 0 0 127.0.0.1:25 0.0.0.0:* LISTEN -
tcp6 0 0 :::5666 :::* LISTEN -
tcp6 0 0 :::37712 :::* LISTEN 45077/java
tcp6 0 0 :::8080 :::* LISTEN 44458/java
tcp6 0 0 :::8085 :::* LISTEN 44458/java
tcp6 0 0 :::22 :::* LISTEN -
tcp6 0 0 ::1:25 :::* LISTEN -
tcp6 0 0 :::32858 :::* LISTEN 44648/java
[linux_server Python]$
Can someone help me understand the issue and fix it. Or is there any alternate way to config this email sending script.
Any help is appreciated . Thanks in advance !