Monthly Archive for Dezember, 2009

Heiligabend bei MTB-News.de

Für den reibungslosen Betrieb von Seiten wie MTB-News.de ist es wichtig, dass man die Server und Dienste permanent überwacht und bei Auffälligkeiten schnell reagieren kann. Es gibt verschiedene Arten, Server und Dienste zu überwachen: zum einen es ist z. B. möglich, in regelmäßigen Zeitabständen zu prüfen, ob der Server per Netzwerk erreichbar ist (ping) oder ob der Webserver noch arbeitet. Eine andere Art der Überwachung ist das langfristige Aufzeichnen bestimmer Parameter, etwa der CPU-Auslastung. So kann man in einem Diagramm sehen, wie sehr ein Server über den Tag verteilt zu tun hat. Man kann sich das auch über längere Zeiträume ansehen, etwas über ein ganzes Jahr.

Ein Parameter, den wir auch so überwachen ist die Anzahl der User, welche zu einem Zeitpunkt bei MTB-News.de aktiv sind. In diesem Diagramm kann man manchmal echt nette Sachen sehen, zum Beispiel den Verlauf eines Länderspiels der deutschen Mannschaft bei der vergangenen Europameisterschaft.

Heiligabend ist auch so ein besonderer Tag:

Man sieht wunderbar, wie die Userzahl am späten Nachmittag förmlich wegbricht (weil die Leute sich ihre Geschenke geben lassen nehme ich an…) und sich erst am späten Abend noch mal ein wenig “erholt”. Man sieht den Unterschied zu den vergangenen Tagen sehr deutlich, wenn man sich das Diagramm der gesamten letzten Woche anschaut – der Knick am Nachmittag ist an keinem anderen Tag außer Heiligabend existent:

So, und nun feiert schön weiter :)

Nach dem Serverumzug

Am Freitag war es – mal wieder – soweit: wir haben einen Teil von MTB-News.de (News, Forum, Bikemarkt und ein paar kleinere Sachen) auf neue Server umgezogen.

Die vorherigen Server haben gut anderthalb Jahre ihren Dienst getan, arbeiteten zuletzt aber immer öfter an ihren Leistungsgrenzen.

Die Teile von MTB-News.de, welche wir jetzt von neuen Maschinen ausliefern lassen, liefen zuvor auf vier Servern (drei Webserver, ein Datenbankserver – naja, eigentlich waren es fünf – es gibt immer noch einen Datenbank-Slave-Server). Es handelte sich um Maschinen mit Athlon 64 X2 Dual-Core-Prozessoren mit jeweils acht Gigabyte RAM und zwei zu einem RAID 1 konfigurierten SATA-II-Platten.

Es verhielt sich zuletzt so, dass die Webserver an den CPU-Limits arbeiteten und der Master-Datenbankserver am Limit der Festplatten (ihm fehlte etwas RAM, was eine erhöhte Festplattenaktivität zur Folge hatte). Viel Spielraum für Optimierungen am Software-Setup hatten wir auch nicht mehr, so dass wir den Entschluss fassten, alles auf aktuellere Hardware umzuziehen.

Wir haben die neuen Server so ausgewählt, dass sie an den jeweilige Problemstellen der alten Maschinen merkliche Verbesserungen erhielten. Als Webserver haben wir nun anstatt drei Maschinen mit jeweils zwei CPU-Cores zwei Maschinen mit jeweils acht Cores (aktuelle Xeon-Prozessoren). Der Datenbankserver hat jetzt zum Einen doppelt so viel RAM (16 Gigabyte) und zum Anderen ein RAID 5 aus drei SAS-Festplatten mit 15.000 U/min und schafft merklich mehr I/O-Operationen pro Sekunde. Die Benchmarks, die wir vorab gefahren haben, versprachen einen anständigen Leistungsschub für MTB-News.de. Nach dem Umzug haben wir es auch von einigen Leuten gehört (und natürlich auch selbst bemerkt …), dass das Forum nun merklich schneller läuft als vorher.

Den Umzug auf neue Hardware am Freitag haben wir gleich genutzt, um dem Softwarestack der Server einigen Änderungen zu unterziehen. Seit Beginn haben wir bei MTB-News.de auf den Apache-Webserver mit mod_php gesetzt. Diese Konstellation hat allerdings einige Nachteile, insbesondere auf Seiten mit viel Last.

Wir haben den Apache auf den neuen Servern jetzt gar nicht mehr installiert, sondern setzen auf nginx – einem kleinen, gut konfigurierbaren und doch sehr effizienten und schnellen Webserver. PHP ist über die FastCGI-Schnittstelle angebunden.

Den MySQL-Datenbankserver haben wir bei der Gelegenheit auch gleich von Version 5.0 auf Version 5.1 migriert – auch hier bieten sich einige Vorteile gegenüber der Vorgängerversion.

Viele Teile von MTB-News.de (Fotoalbum, Videos, Trainingsverwaltung, Tourguide, Winterpokal, you name it …) laufen unabhängig vom Forum auf ganz anderen Servern und wurden beim Serverumzug gar nicht angefasst. Insgesamt gibt es zur Zeit sieben Maschinen, welche für die Auslieferung der Seiten von MTB-News.de zuständig sind.

Soweit mal ein paar technische Einblicke hinter die Kulissen. Wenn sich Fragen auftun – die Kommentare sind offen :)

Wir hoffen, dass wir mit der aktuellen Hardware gut über die nächste Saison kommen – mal schauen, wann das nächste Upgrade fällig wird.

MTB-News.de: Serverumzug

Wir ziehen Forum, News und Bikemarkt auf komplett neue Server um. Hier halten wir Euch auf dem laufenden.

@20:11 Das Forum haben wir gerade dicht gemacht und legen jetzt los
@20:30 Der Hinweis auf den Videobereich wurde wohl vermehrt angenommen – grade sind dort 200 Benutzer unterwegs
@20:31 Datenbanken werden auf den neuen Server kopiert
@20:36 Datenbanken werden importiert – nachdem das geschehen ist (dauert so ca. eine Stunde) wollen wir noch ein paar Änderungen an den Indexen der Datenbank vornehmen, das dauert auch noch mal eine knappe Stunde. Danach sollten wir langsam auf den neuen Server umschalten können
@21:10 Die Datenbanken sind auf dem neuen Server importiert. Jetzt führen wir ein paar Änderungen an Tabellen-Indexen durch …
@21:50 jetzt testen, ob alles geht
@22:10 Wir sind wieder da :) scheint alles geklappt zu haben. Jetzt noch kleinere Probleme beheben

11.12.2009 MTB-news.de – Wartungsarbeiten am Freitag abend

Um die Seiten in Zukunft noch schneller und zuverlässiger ausliefern zu können, ziehen wir MTB-News.de auf schnellere Hardware um.

Freitag abend (11. Dezember 2009) wird daher zwischen ca. 20 und 24 Uhr News, Forum und Bikemarkt gar nicht oder nur eingeschränkt zu erreichen sein.

Foto- und Videoalben, Tourguide, Trainingsverwaltung und Winterpokal sind während dieser Zeit bis auf kurze Pausen aber normal abrufbar.

Wir werden euch hier im Blog und auf Twitter @mtbnews auf dem Laufenden halten.