MailWizz List Cleaning and Hygiene Automation — Scheduled Cleanup and Automated Suppression Rules
List hygiene in MailWizz is not a one-time import step — it is an ongoing process that must run continuously as campaigns generate bounce data, FBL complaints, and engagement signals. Automating this process prevents the gradual list quality degradation that erodes deliverability over months.
Automated MailWizz Cleanup Commands
# Daily list cleanup cron (apply suppression rules) 0 2 * * * php -q /var/www/mailwizz/apps/console/console.php lists-clean-up # Delete old delivery logs (free database space) 0 3 * * 0 php -q /var/www/mailwizz/apps/console/console.php delete-campaign-delivery-logs # Process pending bounces from bounce server configuration */10 * * * * php -q /var/www/mailwizz/apps/console/console.php process-delivery-and-bounce-log
Soft Bounce Threshold Configuration
# Backend → Settings → Campaigns # Soft bounce count before unsubscribe: 3 (recommended) # This suppresses addresses after 3 soft bounces in a row # Prevents continued sending to temporarily unreachable addresses # that are likely permanently inactive
Re-Engagement Campaign Logic for Hygiene
- Segment subscribers who have not opened or clicked in 90+ days
- Send a 're-engagement' campaign: 'We haven't heard from you...'
- Subscribers who do not engage with 2-3 re-engagement attempts should be suppressed
- This removes disengaged subscribers before they become complaint sources
External Email Verification Integration
# Automated verification workflow: # 1. Export new imports before first campaign send # 2. Run through NeverBounce, ZeroBounce, or similar API # 3. Import valid addresses to MailWizz list # 4. Import invalid addresses to MailWizz blacklist detection and delisting # NeverBounce API integration (custom script): curl -X POST 'https://api.neverbounce.com/v4/jobs/create' \ -H 'Authorization: Bearer YOUR_API_KEY' \ -F 'input_location=remote_url' \ -F 'input=https://your-server/exports/new-subscribers.csv'
Automated list hygiene is not a substitute for upstream list quality — it is the last line of defense. The most effective hygiene practice is collecting only verified opt-in subscribers through double opt-in. Cleaning lists of addresses that should never have been collected creates ongoing overhead that proper collection practices would prevent.
Troubleshooting Common Issues
Production MailWizz deployments encounter predictable issues at predictable stages. Understanding the diagnostic workflow for the most common problems in this configuration area saves time and prevents the escalating complexity that comes from applying fixes to a misdiagnosed problem. The diagnostic approach is always the same: identify the symptom precisely (not just "it's not working"), isolate the layer where the failure occurs (MailWizz application, delivery server connection, DNS, ISP rejection), and fix at the correct layer.
Systematic Diagnosis Approach
Check MailWizz logs first (available in Backend → Misc → Application Logs), then check the delivery server SMTP logs, then check the PowerMTA accounting log. Most issues surface in one of these three places. A problem that does not appear in any of these logs is almost always a configuration issue — the system is not attempting what you expect it to attempt.
# MailWizz diagnostic log locations: # Application logs: Backend → Misc → Application Logs # Delivery logs: Backend → Campaigns → [Campaign] → Delivery Logs # Bounce logs: Backend → Bounce Servers → [Server] → Logs # Server-side logs: # MailWizz application: /path/to/mailwizz/apps/common/runtime/application.log # PowerMTA delivery: /var/log/pmta/pmta.log # PowerMTA accounting: /var/log/pmta/accounting.csv
Performance Optimization for Production Scale
MailWizz performance at scale depends on three infrastructure layers: the web application server (PHP/nginx or Apache), the database (MySQL — query optimization is critical at high subscriber counts), and the delivery infrastructure (PowerMTA connection pool sizing). Performance problems in any of these layers manifest as slow campaign sends, delayed processing, or timeouts that appear unrelated to the specific configuration area being managed.
The most common performance constraint in production MailWizz environments is MySQL query efficiency. As subscriber lists grow beyond 500,000 records, unoptimized database queries for segmentation, bounce processing configuration, and campaign statistics become significant bottlenecks. Ensure that subscriber tables have appropriate indexes on email, status, date_added, and any custom field columns used for segmentation.
# MySQL optimization for large MailWizz installations # Check slow query log: SHOW VARIABLES LIKE 'slow_query_log%'; SET GLOBAL slow_query_log = 'ON'; SET GLOBAL long_query_time = 1; # Log queries over 1 second # Key indexes to verify exist: SHOW INDEX FROM mailwizz_lists_subscribers; # Should have indexes on: email, status, date_added, list_id # Add missing index if needed: ALTER TABLE mailwizz_lists_subscribers ADD INDEX idx_email_status (email, status); # Campaign sends table — index on campaign_id + subscriber_id: ALTER TABLE mailwizz_campaigns_tracking_opens ADD INDEX idx_campaign_sub (campaign_id, subscriber_id);
Security Considerations
MailWizz installations handling production sending volumes are valuable targets. Key security practices: use HTTPS for all MailWizz access (including tracking and unsubscribe links), restrict Backend access to authorized IP ranges via web server configuration, rotate API keys periodically and revoke unused keys, maintain regular database backups (automated, offsite), and ensure PHP and MailWizz are kept current with security patches.
The tracking domain (used for open and click tracking) requires special attention: it must have a valid SSL certificate (Let's Encrypt is acceptable), and its DNS records must point exclusively to your MailWizz server. A compromised tracking domain can redirect recipients to malicious sites or reveal subscriber click data to third parties.
Campaign Analytics Integration
Track this MailWizz configuration area through two complementary metric layers: MailWizz campaign statistics (open rate, click rate, bounce rate, unsubscribe rate) and PowerMTA accounting log data (ISP-specific deferral rate, bounce classification, queue depth). Gaps between the two layers reveal delivery problems invisible to MailWizz statistics alone — high MailWizz "sent" counts with elevated PowerMTA deferral rates indicate a queue buildup that campaign dashboards don't surface.
Review campaign metrics against your own historical baselines rather than industry benchmarks. Your list composition, acquisition source, and engagement history define what normal looks like for your environment. Use rolling 7-day and 30-day averages to distinguish trend changes from campaign-specific variance.
Implementation Checklist
Before deploying this configuration to production MailWizz, verify: delivery server connection test passes in Backend → Servers → Delivery Servers, cron jobs are running on the correct schedule, bounce server mailbox is accessible and IMAP credentials are valid, tracking domain has valid SSL and loads within 500ms, and PHP memory limit is set to at least 256MB.
After deploying, send a test campaign to a controlled list of seed addresses across Gmail, Outlook, and Yahoo. Verify Authentication-Results headers show dkim=pass and spf=pass in the received messages. Check that open and click tracking are registering correctly in MailWizz statistics. Confirm bounce processing is updating subscriber status within 15 minutes of a test bounce event.
For managed MailWizz environments operated by Cloud Server for Email, these verification steps are performed automatically after any configuration change. The managed service includes continuous monitoring of delivery server health, cron job execution, and tracking domain availability. Contact infrastructure@cloudserverforemail.com for information about managed MailWizz hosting.
MailWizz handles basic hygiene automatically (removing hard bounces, processing unsubscribes). Production deployments need additional automation: tag subscribers not opened in 90 days for re-engagement processing, run domain-level bounce analysis monthly, validate newly imported addresses before first send. Build these as scheduled scripts calling the MailWizz API integration rather than relying on manual operations.
Re-Engagement Campaign Design
Before suppressing inactive subscribers, run a structured re-engagement sequence: 3 messages over 3 weeks with clear value propositions and an explicit "stay subscribed" CTA. Suppress non-responders after the sequence. The re-engagement campaign itself should use your lowest-risk IP pool — the inactive segment is highest-risk for complaints.
Need managed MailWizz infrastructure? We operate fully managed MailWizz and PowerMTA environments for high-volume senders.
Cloud Server for Email provides fully managed MailWizz + PowerMTA environments on EU dedicated servers. Unlimited subscribers, daily monitoring, GDPR-compliant EU data residency.

