django send_mail()函数需要几分钟

时间:2015-10-06 21:19:44

标签: python django email nginx sendmail

我试图在我的views.py文件中的函数中发送电子邮件。我已经按照与此处相同的方式在我的设置文件中设置了电子邮件。

Python Django Gmail SMTP setup

电子邮件发送确实有效但我的用户一直在抱怨需要几分钟的时间。我在我的var / log / mail.log文件中收到gethostbyaddress错误,我将在此处发布。我曾经得到nginx超时错误但是把#34; proxy_read_timeout 150;"进入我的/ etc / nginx / sites-enabled / django文件。

http://www.nginxtips.com/upstream-timed-out-110-connection-timed-out-while-reading-response-header-from-upstream/

这解决了与网站交互时的超时错误,但电子邮件仍需要几分钟才能加载。我使用的是digitalocean django液滴,我的所有水滴都出现了这么慢的速度。

这是我的观看功能

@login_required
def AnnouncementPostView(request, leaguepk):
    league = League.objects.get(pk=leaguepk)
    lblog = league.blog

    if request.method == 'POST':
        form = AnnouncementPostForm(request.POST)
        if form.is_valid():
            posttext = request.POST['text']

            newAnnouncement = Announcement(text=posttext, poster=request.user)
            newAnnouncement.save()
            lblog.announce.add(newAnnouncement)

            titleText = "%s Announcement" % (league.name)

            send_mail(titleText, posttext, settings.EMAIL_HOST_USER, ['mytestemail@gmail.com'], fail_silently=False)

       return HttpResponseRedirect(reverse('league-view', args=[league.pk]))
else:
    form = AnnouncementPostForm()

return render(request, 'simposting/announcementpost.html', {'form': form, 'league': league})

这已经奏效,公告发布到所需的页面,甚至通过电子邮件发送,这只是一个时间问题,人们已经开始期待几乎即时的电子邮件流程,这使得2-3分钟无法接受,尤其是注册也会导致2-3分钟的等待。

一个问题可能是,在尝试使用DigitalOcean支持团队解决此问题时,我将我的Droplet名称和主机名更改为我设置的域。

我当前的主机名和Droplet名称是mydomain.com。我在/ etc / hostname文件中设置了这种方式。我的/ etc / hosts文件看起来像这样

127.0.0.1 localhost.localdomain localhost mydomain.com
127.0.1.1 mydomain.com

每当我尝试发送邮件时,我的var / log / mail.log文件就会响应

Oct 6 16:13:24 "oldDropletName" sm-mta[13660]: gethostbyaddr(10.xxx.xx.x) failed: 1
Oct 6 16:13:24 "oldDropletName" sm-mta[13662]: starting daemon (8.14.4): SMTP+queueing@00:10:00

我希望这是足够的信息来帮助,它已经困扰了几个星期,通常我可以通过在这里查找东西或与支持团队合作解决我的问题,但它让我们难过。感谢您抽出宝贵时间提供帮助!

2 个答案:

答案 0 :(得分:9)

发送电子邮件是一项网络绑定任务,您不知道完成与您的情况完全相同需要多长时间。尽管您的网络可能存在延迟,但最好以异步方式执行此类任务,因此您的主线程是免费的。

我在一个项目中使用以下代码。

utils.py

import threading
from django.core.mail import EmailMessage


class EmailThread(threading.Thread):
    def __init__(self, subject, html_content, recipient_list, sender):
        self.subject = subject
        self.recipient_list = recipient_list
        self.html_content = html_content
        self.sender = sender
        threading.Thread.__init__(self)

    def run(self):
        msg = EmailMessage(self.subject, self.html_content, self.sender, self.recipient_list)
        msg.content_subtype = 'html'
        msg.send()


def send_html_mail(subject, html_content, recipient_list, sender):
    EmailThread(subject, html_content, recipient_list, sender).start()

只需从您的视图中调用send_html_mail即可。

答案 1 :(得分:0)

我对sendmail并不是特别熟悉(我使用postfix),但我怀疑这几乎肯定与sendmail有关,可能不是Django。第二个日志条目具有“SMTP +排队@00:10:00”。并且this link表示sendmail在启动时获取标志以确定处理邮件队列的频率。您可能希望查看init或启动脚本的位置,并查看sendmail的配置方式。此外,如果您使用Gmail,您实际上无法控制其结束时的任何延迟,因此在确定邮件服务器的配置时,您需要检查日志以确定操作实际发生的时间,例如正在排队的邮件/发送。是否在执行视图时在日志中显示该行的时间?如果是这样,它掌握在sendmail手中。