-
-
Notifications
You must be signed in to change notification settings - Fork 662
Outbound Improvements
Things that need done to Outbound.js to make it more capable
Currently on a restart, with cluster enabled, the parent process reads the queue (directory) and sets itself up to send all the mails in the queue. We should have the parent process farm out that task to each child in a round-robin fashion.
NOTE: This is now implemented. When mail is queued it contains the PID in the filename. When that PID dies the parent redistributes queued mail with that PID to other children. When Haraka starts it scans all the PIDs and distributes mail for each PID to a unique child (using modulus(pid)).
Implement outbound rate limiting a-la plugins/rate_limit plugin.
DONE See https://github.com/haraka/haraka-plugin-limit
e.g. pool connections by [destination MX | IP address | domain name]
DONE in #1466
DONE: Implement tools for flushing the queue (force every item to be sent now), emptying the queue, and listing the queue.
haraka -c <path> --qlist
haraka -c <path> --qunstick <domain>
- TODO:
haraka -c <path> --qdelete <domain>
- Emptying the queue is done by
rm -f <path>/queue/*
We currently just do a "multiply by two" approach to this. We should do something a bit smarter.
See #2084
Support having multiple load balanced nodes (cluster), and preferably distribute the queue between the nodes. To support dynamic scaling of the number of nodes there should be some kind of manager on top that makes sure that all queue items are handled somewhere
Support with multiple IP stacks, to provide Google and other mail Provideren for the same recipients and senders in the same IP address for communicating. Because some mail providers have very strict guidelines here, especially with respect to the IPv6 addresses.
For this I would recommend the modulo on a CRC32 hash always choose from a pool based on either IPv4 or IPv6, depending on which destination address is selected at random. See smf his example.
crc32(array[IPv4 or v6 from MXs) + sender(from) + recipients) % modulo(outbound pool of IPv4 or v6)
NOTE: This could easily be implemented in a plugin. The get_mx
hook allows one of the return parameters (when returning an object) to be bind
. It shouldn't be a core feature.
Manual Config e.g.:
[outbound_ipv4]
123.123.123.100
123.123.123.101
123.123.123.105
[outbound_ipv6]
fe80::d250:99ff:fe74:56aa
fe80::d250:99ff:fe74:57aa
fe80::d250:99ff:fe74:58aa
Install Guides
How To
- Upgrade Haraka
- Google Safe Browsing
- Require TLS
- Configure my Editor
- Contribute
- Roll a Release
- Test Email
- Write a Plugin
Future Plans / TODO
Support RFC3464 in bounce messages- Decode Short URLs in data.uribl.js and test the destination URL instead
DKIM verifier
Additional Resources