Linux 서버에서 Python2.7을 사용하여 SMTP - "smtp.outlook.com",587에 연결할 수 없습니다.

Linux 서버에서 Python2.7을 사용하여 SMTP - "smtp.outlook.com",587에 연결할 수 없습니다.

아래에는 회사 Outlook 이메일로 이메일을 보내는 작은 Python 스크립트가 있습니다. 내 개인용 컴퓨터에서는 잘 작동하지만 서버에 배포할 때 계속 실행되고 시간 초과되지만 이메일을 보내지 않습니다.

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()

다음은 시간 초과가 발생했을 때 발생하는 오류입니다.

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

Outlook에 텔넷을 연결할 수 없으며 시간이 초과됩니다. 아래를 참조하세요:-

[linux_server Python]$ telnet smtp.outlook.com 587
Trying 40.101.4.2...

^C
[linux_server Python]$

아래는 이 서버의 수신 대기 포트입니다.

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]$

누군가가 문제를 이해하고 해결하도록 도와줄 수 있습니까? 아니면 이 이메일 전송 스크립트를 구성하는 다른 방법이 있습니까? 도움을 주시면 감사하겠습니다. 미리 감사드립니다!

관련 정보