Der Wechsel von SQLite zu PostgreSQL verlangsamt die Testausführungsgeschwindigkeit erheblich – oft verdoppelt sich die Laufzeit.
Erzielen Sie eine vergleichbare Testleistung zwischen PostgreSQL und SQLite, ohne den Anwendungscode zu ändern. Die ideale Lösung besteht darin, die Verbindungseinstellungen zu optimieren.
1. Feinabstimmung des PostgreSQL-Servers
fsync=off
und full_page_writes=off
werden die Wiederherstellung nach einem Absturz und Datenintegritätsprüfungen deaktiviert, was zu schnelleren Schreibvorgängen führt. Dies sollte nur in kontrollierten Testumgebungen erfolgen.
shared_buffers
, um mehr Speicher für das Caching bereitzustellen und so die Festplatten-E/A zu reduzieren.work_mem
an, um mehr Speicher für Sortierungen und andere In-Memory-Vorgänge bereitzustellen.2. Optimierung des Host-Betriebssystems
3. Abfrage- und Workload-Optimierung
TRUNCATE
für schnelleres Löschen von Tabellen, besonders vorteilhaft beim häufigen Abschneiden vieler kleiner Tabellen.DELETE
die Leistung zu verbessern, aber vermeiden Sie eine Überindizierung.4. Hardware-Verbesserungen
Diese Optimierungstechniken können die Leistung von PostgreSQL beim Testen erheblich verbessern. Auch wenn das alleinige Anpassen der Verbindungseinstellungen möglicherweise nicht vollständig zur Geschwindigkeit von SQLite passt, führt eine Kombination dieser Strategien zu einer erheblichen Leistungssteigerung Ihrer Swift-Tests.
Das obige ist der detaillierte Inhalt vonWie kann ich PostgreSQL für Swift-Tests optimieren, um es an die Geschwindigkeit von SQLite anzupassen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!