Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

MySQL Datenbank unter Windows optimieren

Frage Entwicklung Datenbanken

Mitglied: 63783

63783 (Level 1)

22.04.2008, aktualisiert 16.07.2008, 6961 Aufrufe, 2 Kommentare

Hallo!

Ich bin seit einiger Zeit schon im Internet auf der Suche nach Informationen zur Optimierung von MySQL-Servern auf Windows-Plattformen.
Ich finde allerdings immer nur Hinweise auf z.B. die Benchmark-Suite unter Linux oder eben den Beispiel-Konfigs wie huge usw.

Was ich bräuchte wäre eine Art HowTo oder Tutorial wo allgemein verständlich erklärt wird, was die einzelnen Konfigurationseinträge bewirken, damit ich die Konfiguration besser auf die jeweilige Datenbankstruktur unserer Kunden anpassen kann.

Szenario ist: Meine Firma vertreibt eine CRM-ERP-Lösung für kleine und mittlere Unternehmen. Im Hintergrund werkelt eine MySQL-Datenbank. Die Datenbanken unserer Kunden sind für MySQL-Verhältnisse eher klein (so im Schnitt 600MB-2GB verteilt auf etwa 140 Tabellen). Als Engine benutzen wir MyISAM. Allerdings ist die Grösse der einzelnen Tabellen von Kunde zu Kunde sehr unterschiedlich. Unsere Kunden haben zumeist kleinere Server mit 1, 2 oder 4gb RAM und Dual-Core Prozessoren.

Mit den einzelnen Beispiel-Konfigs erzielt man ja schon einigermassen passable Ergebnisse, aber ich hätte halt gern etwas mehr Kontrolle über die Einstellungen ohne gleich diverse Schulungen besuchen zu müssen.

Preisfrage: Kennt einer Links zu verständlichen Tutorials, HowTo's o.ä. oder wäre jemand so nett mir allgemein ein paar Tips geben?
Ideal wäre auch wenn es eine Möglichkeit gäbe Benchmarks der Datenbank unter Windows durchzuführen...

Danke für eure Mühe schon mal vorne weg :D
Mitglied: Nailara
15.07.2008 um 23:00 Uhr
Hi,

Links habe ich leider auch nicht - vielleicht helfen ein paar allgemeine Anmerkungen:

- Bei 2 GB Datenbank und 4 GB Ram im Server können fast alle Tabellen im RAM gehalten werden - gute Bedingungen und nicht "kleine Server". 32Bit-Windows hat den Nachteil, dass ein Prozess normal nur 2 GB Ram verwalten kann und max. 4 GB Ramnutzung insgesamt möglich sind - ausgenommen es wird PAE genutzt und das sehe ich bei MySQL nicht.
- Benutze für einen DB-Server mindestens 5 Platten und einen Raid-Controller, der Raid 0+1 kann. Die 0+1-Kombi bietet optimalen Datendurchsatz. Wenn der Controller auch noch mehrere Kanäle hat, dann sollten die Platten so angebunden werden, dass eine Platte des 0-Raids an einen Kanal und die andere Platte des 0-Raids an den anderen Kanal gebunden wird. Die 1-Raid-Konstruktion analog hierzu. Das gibt maximalen Datendurchsatz auf der Platte.
- Bei den Platten sind SAN-Türme i.d.R. noch performanter als interne SCSI-Raids - mit 2GBit/s FCAL ist ein Performancevorteil von 10-100 gegenüber SCSI möglich.
- Die Festplatten sollten zwar klein und zahlreich, aber schnell wie der Wind sein. 5 x 80 GB mit 15000 U/min sind besser als 2 x 250 GB mit 10000 U/Min. Es hat niemand behauptet, dass ein guter DB-Server billig ist .
- Wenn noch ein paar Euro über sind, wären noch mehr Platten hilfreich, damit Datenbankdateien und Indexdateien auf unterschiedlichen Raids liegen können. Denkbar wäre bei 5 Platten auch, zwei Mal eine Spiegelung zu fahren, ein Spiegel für die Datenbanken, ein Spiegel für die Indexdateien.
- Die Logdateien sollten auch noch separat auf eine Platte gelegt werden - beispielsweise auf die separate OS-Partition.
- Das Betriebssystem sollte separate Platten haben - auch wenn es denn dann noch ein paar Euronen mehr kostet .
- Transaktionssicherheit ist extrem wichtig, gerade bei CRM - deshalb sollten mal umfangreiche Tests wegen gleichzeitigem Zugriff gemacht werden und eine transaktionssichere Engine wie InnoDB genutzt werden.
- Zitat aus der Doku von MySQL: "InnoDB wurde für maximale Leistung bei der Verarbeitung großer Datenmengen ausgelegt. Es gibt wohl keine andere festplattengestützte Speicher-Engine für relationale Datenbanken, die so effizient mit der CPU umgeht." (http://dev.mysql.com/doc/refman/5.1/de/innodb-overview.html)
- Schaut euch die Indizierung der Tabellen genau an - je weniger gemische Indizes umso besser. Welche Indizies zu setzen sind, hängt deutlich von der Abfrage ab. Wichtige Ergebnisspalten sollten indiziert sein - hier helfen nur Analyse der Queries. Übrigens - es ist nicht Aufgabe des Admins, die Queries umzubauen oder Indizes zu setzen, das sollten schon die Entwickler tun. Hier wird die Performance "verballert", nicht durch einen zu klein dimensionierten Server.
- Schau die Speicherparameter der Indizes an und vergleiche die mit den tatsächlich auf der Platte liegenden Größen der Indexdateien. Nach Möglichkeit sollten die häufig genutzten Indizes im Ram liegen, also Nachschauen welche das sind und bei den my.cnf-Settings schauen, wie der Ram entsprechend angepaßt werden kann.
- Bei den anderen Parametern eine Aussage zu treffen ist schwer - das hängt von der Applikation ab. Wenn es allgemeingültige Superduperperformanceoptionen geben würde, dann würden die Entwickler von MySQL die in die my.cnf zur Verteilung mit einbauen und gut is. Machen sie aber nicht, weil es die nicht gibt - das ist immer von der Anwendung abhängig.
- Manchmal hilft es, auch einen einfachen zusätzlichen Index zu setzen und man bekommt - obwohl mehr Ram gebraucht wird - einen Performanceschub von Faktor 10-100. Das ist applikationsabhängig.

Joa - das würde mir gerade so einfallen.

Grüße Mathias
Bitte warten ..
Mitglied: 63783
16.07.2008 um 10:51 Uhr
Vielen Dank für die sehr ausführliche Antwort!
Bitte warten ..
Ähnliche Inhalte
PHP
Suchfeld mit Abfrage auf eine MySQL-Datenbank
gelöst Frage von SaschaRDPHP6 Kommentare

Hallo zusammen, ich steh mal wieder auf dem Schlauch. Bin dabei ein Suchfeld auf die Webseite zu bringen. Jedoch ...

Datenbanken
MySQL - Separate Config für Datenbanken
Frage von EinTypDatenbanken2 Kommentare

Hallo Community, ich habe einen MySQL-Server und habe mich letztens an einer Eigenschaft von InnoDB gestört: Das hochzählen der ...

PHP
PHP MySQL Abfrage aus Datenbank
Frage von Lost144PHP12 Kommentare

Hallo, Ich habe in einer Datenbank daten über VM's stehen. Angaben wie hostname,adresse, serverat usw. Wie kann ich in ...

Datenbanken
Login Probleme in mysql Datenbank
gelöst Frage von bigbootykillaDatenbanken2 Kommentare

Hi, ich habe hier eine Datenbank auf einer Ubuntu Kiste. Wenn ich mich versuche mit Code: einzuloggen bekomme ich ...

Neue Wissensbeiträge
Apple

IOS 11.2.1 stopft HomeKit-Remote-Lücke

Tipp von BassFishFox vor 8 StundenApple

Das Update für iPhone, iPad und Apple TV soll die Fernsteuerung von Smart-Home-Geräten wieder in vollem Umfang ermöglichen. Apple ...

Windows 10

Windows 10 v1709 EN murkst bei den Regionseinstellungen

Tipp von DerWoWusste vor 13 StundenWindows 10

Dieser kurze Tipp richtet sich an den kleinen Personenkreis, der Win10 v1709 EN-US frisch installiert und dabei die englische ...

Webbrowser

Kein Ton bei Firefox Quantum über RDP

Tipp von Moddry vor 13 StundenWebbrowser

Hallo Kollegen! Hatte das Problem, dass der neue Firefox bei mir auf der Kiste keinen Ton hat, wenn ich ...

Internet

EU-DSGVO: WHOIS soll weniger Informationen liefern

Information von sabines vor 1 TagInternet4 Kommentare

Wegen der europäische Datenschutzgrundverordnung stehen die Prozesse um die Registrierung von Domains auf dem Prüfstand. Sollte die Forderungen umgesetzt ...

Heiß diskutierte Inhalte
LAN, WAN, Wireless
Von rj11 auf rj45
Frage von jensgebkenLAN, WAN, Wireless19 Kommentare

Hallo Gemeinschaft, könnt ihr mir vielleicht bei der anfertigung eines Kabels helfen - habe ein rj 11 stecker und ...

Netzwerkmanagement
Firefox Profieles im Roaming
gelöst Frage von Hendrik2586Netzwerkmanagement17 Kommentare

Hallo liebe Leute. :) Ich hab da ein kleines Problem, welches anscheinend nicht unbekannt ist. Wir nutzen hier in ...

LAN, WAN, Wireless
Häufig Probleme beim Anmelden in WLAN
Frage von mabue88LAN, WAN, Wireless15 Kommentare

Hallo zusammen, in einem Netzwerk gibt es relativ häufig (1-2 mal pro Woche) Probleme mit der WLAN-Verbindung. Zunächst mal ...

Windows Server
Remotesteuerung der Sitzung (Kennung XX) fehlgeschlagen
gelöst Frage von Stefan91Windows Server14 Kommentare

Hallo Zusammen, seit kurzem bekomme ich oben genannte Fehlermeldung, wenn ich versuche eine Remotesitzung über den Taskmanager fernzusteuern (Rechtsklick ...