2

I have a use case where I need to send 16000+ users unique mails. To do this I am using mandrill api( djrill). To make it more efficient and optimized I am trying to use send_mass_mail functionality along with celery.

While doing so I was checking the celery logs and found that for each email, the celery worker is creating a new http connection.

[2015-06-22 14:23:30,745: INFO/Worker-4] Starting new HTTPS connection (1): mandrillapp.com
[2015-06-22 14:23:31,521: INFO/Worker-4] Starting new HTTPS connection (1): mandrillapp.com
[2015-06-22 14:23:32,162: INFO/Worker-4] Starting new HTTPS connection (1): mandrillapp.com

This will be crippling for our network and will consume a lot of bandwidth.

Here is my code to do the same

@shared_task
def test_email_mass(merge_vars):

    messages = []   

    if DEBUG:
        for k,v in merge_vars.iteritems():
            message = []
            print v['content']

            message.append(title)                                        
            message.append(v['content'])
            message.append('foo@too.com')
            message.append([k])           
            messages.append(tuple(message))
        send_mass_mail(tuple(messages), fail_silently=False)

I was expecting that the above code will create only a single http connection.

Edit : I tried the following too.

 connection = get_connection()
    if DEBUG:
        for k,v in merge_vars.iteritems():
            message = []

            msg = EmailMessage(from_email="soo@too.com", subject=title)
            msg.template_name = "standard"
            msg.to = [k]
            msg.from_name = from_name
            messages.append(msg)              
    connection.send_messages(messages)
    connection.close()

It still shows that it creates a new http connection everytime.

4

0 回答 0