
아래에는 회사 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]$
누군가가 문제를 이해하고 해결하도록 도와줄 수 있습니까? 아니면 이 이메일 전송 스크립트를 구성하는 다른 방법이 있습니까? 도움을 주시면 감사하겠습니다. 미리 감사드립니다!