Dunning — der Prozess, mit dem fehlgeschlagene Zahlungen wieder eingezogen werden — ist die unscheinbarste und zugleich rentabelste Disziplin im SaaS-Billing. Jede gescheiterte Kreditkartenbelastung, die Sie zurückholen, ist Umsatz, den Sie bereits gewonnen hatten und nur an ein technisches Detail zu verlieren drohten. In unserem Portfolio macht unfreiwilliger Churn regelmässig einen zweistelligen Prozentanteil aller Abo-Verluste aus. Ein guter Dunning-Prozess holt den Grossteil davon zurück — ohne eine einzige neue Kundenakquise.
Warum Zahlungen scheitern
Die häufigsten Ursachen sind banal: abgelaufene Karten, überschrittene Limits, von der Bank abgelehnte Transaktionen (oft fälschlich als Betrugsverdacht), gesperrte oder neu ausgestellte Karten. In keinem dieser Fälle wollte der Kunde kündigen. Genau das macht den unfreiwilligen Churn so dankbar: Die Zahlungsbereitschaft ist da, es fehlt nur die erfolgreiche Belastung. Wer das versteht, behandelt eine fehlgeschlagene Zahlung nicht als Kündigung, sondern als Aufgabe.
Die drei Säulen eines Dunning-Prozesses
Erstens: intelligente Wiederholungsversuche (Smart Retries). Statt stur am selben Tag erneut zu belasten, verteilen Sie die Versuche über mehrere Tage und Tageszeiten. Stripe bietet mit den Smart Retries eine ML-gestützte Logik, die den Zeitpunkt mit der höchsten Erfolgswahrscheinlichkeit wählt. Konfigurieren Sie ein Wiederholungsfenster von etwa zwei bis drei Wochen mit drei bis vier Versuchen.
Zweitens: eine E-Mail-Sequenz, die den Kunden einbindet. Die Retry-Logik allein reicht nicht, wenn die Karte tatsächlich abgelaufen ist — dann muss der Kunde handeln. Eine bewährte Sequenz: eine freundliche erste Mail beim ersten Fehlschlag mit direktem Link zum Aktualisieren der Zahlungsdaten, eine sachliche Erinnerung nach einigen Tagen, und eine letzte Mail vor der Aussetzung des Zugangs mit klarer Frist. Halten Sie den Ton hilfsbereit, nicht drohend — der Kunde ist kein säumiger Schuldner, sondern jemand mit einer abgelaufenen Karte.
Drittens: Prävention durch Kartenablauf-Warnungen. Stripe kennt das Ablaufdatum der hinterlegten Karte. Senden Sie proaktiv eine Erinnerung, bevor die Karte abläuft, und nutzen Sie wo möglich den Card Account Updater, der erneuerte Kartendaten automatisch von den Netzwerken bezieht. Eine verhinderte fehlgeschlagene Zahlung ist besser als eine zurückgeholte.
Die technische Umsetzung
Der Dunning-Prozess hängt an zuverlässig verarbeiteten Webhooks. Die entscheidenden Ereignisse sind invoice.payment_failed (Auslöser der Sequenz), invoice.payment_succeeded (Erfolg, Sequenz beenden), customer.subscription.updated und customer.subscription.deleted (Statuswechsel). Behandeln Sie Webhooks idempotent — dasselbe Ereignis kann mehrfach eintreffen, und Ihre Logik darf eine E-Mail nicht doppelt versenden. Speichern Sie verarbeitete Event-IDs und verwerfen Sie Duplikate. Definieren Sie ausserdem klar, was bei endgültigem Fehlschlag passiert: Wird das Abo gekündigt oder in einen eingeschränkten Read-only-Zustand versetzt? Ein sanfter Zustand erhält die Daten des Kunden und damit die Chance auf Rückkehr.
Messen, was wirkt
Verfolgen Sie die Recovery Rate — den Anteil der fehlgeschlagenen Zahlungen, die Sie innerhalb des Dunning-Fensters einziehen. Ein gut eingestellter Prozess holt erfahrungsgemäss einen Grossteil der unfreiwilligen Ausfälle zurück. Beobachten Sie zusätzlich, an welcher Stufe der Sequenz die meisten Rückgewinnungen passieren; das sagt Ihnen, ob Sie eher an der Retry-Logik oder an den E-Mails feilen müssen.
Fazit
Dunning ist die seltene Massnahme, bei der ein überschaubarer technischer Aufwand direkt messbaren Umsatz schützt. Bauen Sie die drei Säulen — Smart Retries, hilfsbereite E-Mail-Sequenz, Ablaufprävention — auf einem idempotenten Webhook-Fundament auf, definieren Sie den Endzustand bewusst und messen Sie die Recovery Rate. Bevor Sie das nächste Akquise-Experiment starten, prüfen Sie, wie viel Umsatz Ihr Dunning gerade ungenutzt verliert. In den meisten Fällen liegt dort der schnellste Return.
DACH-spezifische Zahlungsaspekte
Im DACH-Raum lohnt ein Blick auf die Zahlungsmethoden jenseits der Kreditkarte. SEPA-Lastschrift ist verbreitet und hat ein anderes Fehlerprofil als Karten: Rücklastschriften kommen verzögert und erfordern eine andere Behandlung als eine sofort abgelehnte Kartenzahlung. Stripe bildet beides ab, aber Ihre Dunning-Logik muss die unterschiedlichen Zeithorizonte berücksichtigen — eine SEPA-Rücklastschrift kann Tage nach der vermeintlich erfolgreichen Zahlung eintreffen. In der Schweiz spielt zusätzlich die QR-Rechnung eine Rolle, vor allem im B2B, wo Rechnungskauf auf Ziel verbreiteter ist als bei Self-Service-Produkten.
Berücksichtigen Sie auch die Mehrwertsteuer-Mechanik: Eine zurückgeholte Zahlung muss steuerlich sauber abgebildet sein, und Gutschriften oder Stornierungen müssen mit der ursprünglichen Rechnung konsistent bleiben. Wer hier schludert, erzeugt im Jahresabschluss Aufwand, der den Dunning-Gewinn wieder auffrisst. Halten Sie Rechnungsnummern, Gutschriften und Wiederholungsbelastungen lückenlos nachvollziehbar.
Ein abschliessender organisatorischer Punkt: Definieren Sie, wer im Team auf eskalierte Dunning-Fälle schaut. Bei Self-Service-Produkten genügt meist die automatisierte Sequenz, aber für grössere Konten lohnt sich ein menschlicher Touch — eine persönliche E-Mail bei einem wertvollen Kunden, dessen Zahlung scheitert, rettet ein Vielfaches dessen, was sie kostet. Automatisieren Sie die Masse, personalisieren Sie die Ausnahmen.
Gestalten Sie schliesslich den Endzustand mit Bedacht. Statt ein Abo bei endgültigem Fehlschlag hart zu kündigen und alle Daten zu sperren, bewährt sich ein abgestufter Übergang: zunächst eine Karenzphase mit vollem Zugang, dann ein eingeschränkter Read-only-Modus, der die Daten des Kunden erhält, und erst danach die Aussetzung. Dieser sanfte Pfad respektiert, dass die meisten Betroffenen bleiben wollten, und hält die Tür für eine reibungslose Rückkehr offen. Ein Kunde, dessen Daten noch vorhanden sind, reaktiviert sein Abo mit einem Klick; einer, dessen Konto gelöscht wurde, ist meist endgültig verloren.

