Fixed mailer connection issues

This commit is contained in:
Marc Aymerich 2015-11-09 19:07:06 +00:00
parent 598bb39f84
commit d6f85f07df
4 changed files with 29 additions and 16 deletions

View file

@ -27,7 +27,8 @@
<span class="name">{{ seller.get_name }}</span> <span class="name">{{ seller.get_name }}</span>
</div> </div>
<div class="contact"> <div class="contact">
<p>{{ seller.address }}<br> <p>{{ seller.vat }}<br>
{{ seller.address }}<br>
{{ seller.zipcode }} - {% trans seller.city %}<br> {{ seller.zipcode }} - {% trans seller.city %}<br>
{% trans seller.get_country_display %}<br> {% trans seller.get_country_display %}<br>
</p> </p>

View file

@ -1,4 +1,5 @@
from django.conf import settings as djsettings from django.conf import settings as djsettings
from django.core.mail import get_connection
from django.core.mail.backends.base import BaseEmailBackend from django.core.mail.backends.base import BaseEmailBackend
from orchestra.core.caches import get_request_cache from orchestra.core.caches import get_request_cache
@ -27,6 +28,7 @@ class EmailBackend(BaseEmailBackend):
is_bulk = True is_bulk = True
default_priority = Message.NORMAL if is_bulk else Message.CRITICAL default_priority = Message.NORMAL if is_bulk else Message.CRITICAL
num_sent = 0 num_sent = 0
connection = None
for message in email_messages: for message in email_messages:
priority = message.extra_headers.get('X-Mail-Priority', default_priority) priority = message.extra_headers.get('X-Mail-Priority', default_priority)
content = message.message().as_string() content = message.message().as_string()
@ -40,8 +42,12 @@ class EmailBackend(BaseEmailBackend):
) )
if priority == Message.CRITICAL: if priority == Message.CRITICAL:
# send immidiately # send immidiately
send_message.apply_async(message) if connection is None:
connection = get_connection(backend='django.core.mail.backends.smtp.EmailBackend')
send_message.apply_async(message, connection=connection)
else: else:
message.save() message.save()
num_sent += 1 num_sent += 1
if connection is not None:
connection.close()
return num_sent return num_sent

View file

@ -14,17 +14,22 @@ from .models import Message
def send_message(message, connection=None, bulk=settings.MAILER_BULK_MESSAGES): def send_message(message, connection=None, bulk=settings.MAILER_BULK_MESSAGES):
if connection is None:
# Reset connection with django
connection = get_connection(backend='django.core.mail.backends.smtp.EmailBackend')
connection.open()
error = None
message.last_try = timezone.now() message.last_try = timezone.now()
update_fields = ['last_try'] update_fields = ['last_try']
if message.state != message.QUEUED: if message.state != message.QUEUED:
message.retries += 1 message.retries += 1
update_fields.append('retries') update_fields.append('retries')
message.save(update_fields=update_fields) message.save(update_fields=update_fields)
if connection is None:
connection = get_connection(backend='django.core.mail.backends.smtp.EmailBackend')
if connection.connection is None:
try:
connection.open()
except Exception as err:
message.defer()
message.log(error)
return
error = None
try: try:
connection.connection.sendmail(message.from_address, [message.to_address], smart_str(message.content)) connection.connection.sendmail(message.from_address, [message.to_address], smart_str(message.content))
except (SocketError, except (SocketError,
@ -42,13 +47,13 @@ def send_message(message, connection=None, bulk=settings.MAILER_BULK_MESSAGES):
def send_pending(bulk=settings.MAILER_BULK_MESSAGES): def send_pending(bulk=settings.MAILER_BULK_MESSAGES):
try: try:
with LockFile('/dev/shm/mailer.send_pending.lock'): with LockFile('/dev/shm/mailer.send_pending.lock'):
connection = None connection = get_connection(backend='django.core.mail.backends.smtp.EmailBackend')
cur, total = 0, 0 cur, total = 0, 0
for message in Message.objects.filter(state=Message.QUEUED).order_by('priority', 'last_try', 'created_at'): for message in Message.objects.filter(state=Message.QUEUED).order_by('priority', 'last_try', 'created_at'):
if cur >= bulk and connection is not None: if cur >= bulk:
connection.close() connection.close()
cur = 0 cur = 0
connection = send_message(message, connection, bulk) send_message(message, connection, bulk)
cur += 1 cur += 1
total += 1 total += 1
now = timezone.now() now = timezone.now()
@ -57,14 +62,15 @@ def send_pending(bulk=settings.MAILER_BULK_MESSAGES):
delta = timedelta(seconds=seconds) delta = timedelta(seconds=seconds)
qs = qs | Q(retries=retries, last_try__lte=now-delta) qs = qs | Q(retries=retries, last_try__lte=now-delta)
for message in Message.objects.filter(state=Message.DEFERRED).filter(qs).order_by('priority', 'last_try'): for message in Message.objects.filter(state=Message.DEFERRED).filter(qs).order_by('priority', 'last_try'):
if cur >= bulk and connection is not None: if cur >= bulk:
connection.close() connection.close()
cur = 0 cur = 0
connection = send_message(message, connection, bulk) send_message(message, connection, bulk)
cur += 1 cur += 1
total += 1 total += 1
if connection is not None:
connection.close()
return total return total
except OperationLocked: except OperationLocked:
pass pass
finally:
if connection.connection is not None:
connection.close()

View file

@ -9,9 +9,9 @@ from . import engine, settings
@task @task
def send_message(message): def send_message(message, connection=None):
message.save() message.save()
engine.send_message(message) engine.send_message(message, connection=connection)
@periodic_task(run_every=crontab(hour=7, minute=30)) @periodic_task(run_every=crontab(hour=7, minute=30))