Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

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-Server richtig einstellen

Frage Entwicklung Datenbanken

Mitglied: Freaky-Boy

Freaky-Boy (Level 1) - Jetzt verbinden

30.06.2012 um 21:04 Uhr, 3887 Aufrufe, 5 Kommentare

Ich bin vor kurzen mit meinem Server umgezogen und habe mit dem neuen SQL-Server Probleme. Er ist meiner Meinung nach zu langsam.

Hallo Zusammen,

ich habe ein Browsergame programmiert, dieses jetzt auf einen Strato VServer gelegt und somit veröffentlicht. Allerding bin ich der Meinung, dass irgendetwas mit den Einstellungen des MySQL-Servers nicht stimmen kann. Vorher ging die Abarbeitung der Befehle wesentlich schneller.
Für diesen Befehl, der zwar von der Zeit her wirklich aufwendig ist, braucht mein MySQL-Server 50 Sekunden !!!
01.
<? 
02.
	$query = "UPDATE `pcs` SET `score` =  
03.
04.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`case` AND `market`.`TYPE_ID` = 1) + 
05.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`power` AND `market`.`TYPE_ID` = 2) + 
06.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`fan1` AND `market`.`TYPE_ID` = 7) + 
07.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`fan2` AND `market`.`TYPE_ID` = 7) + 
08.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`fan3` AND `market`.`TYPE_ID` = 7) + 
09.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`fan4` AND `market`.`TYPE_ID` = 7) + 
10.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`cooling` AND `market`.`TYPE_ID` = 7) + 
11.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`board` AND `market`.`TYPE_ID` = 3) + 
12.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`cpu` AND `market`.`TYPE_ID` = 5) + 
13.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`ram1` AND `market`.`TYPE_ID` = 4) + 
14.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`ram2` AND `market`.`TYPE_ID` = 4) + 
15.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`ram3` AND `market`.`TYPE_ID` = 4) + 
16.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`ram4` AND `market`.`TYPE_ID` = 4) + 
17.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`ram5` AND `market`.`TYPE_ID` = 4) + 
18.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`ram6` AND `market`.`TYPE_ID` = 4) + 
19.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`hdd1` AND `market`.`TYPE_ID` = 6) + 
20.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`hdd2` AND `market`.`TYPE_ID` = 6) + 
21.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`hdd3` AND `market`.`TYPE_ID` = 6) + 
22.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`hdd4` AND `market`.`TYPE_ID` = 6) + 
23.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`hdd5` AND `market`.`TYPE_ID` = 6) + 
24.
	(SELECT `price` FROM `market` WHERE `market`.`PART_ID` = `pcs`.`hdd6` AND `market`.`TYPE_ID` = 6) + 
25.
	(SELECT `price` FROM `os` WHERE `os`.`ID` = `pcs`.`system`) + 
26.
	(SELECT `cost` FROM `calculations` WHERE `calculations`.`level` = `pcs`.`OB` AND `calculations`.`PRG_ID` = 1) + 
27.
	(SELECT `cost` FROM `calculations` WHERE `calculations`.`level` = `pcs`.`BM` AND `calculations`.`PRG_ID` = 2) + 
28.
	(SELECT `cost` FROM `calculations` WHERE `calculations`.`level` = `pcs`.`FW` AND `calculations`.`PRG_ID` = 3) + 
29.
	(SELECT `cost` FROM `calculations` WHERE `calculations`.`level` = `pcs`.`AV` AND `calculations`.`PRG_ID` = 4) + 
30.
	(SELECT `cost` FROM `calculations` WHERE `calculations`.`level` = `pcs`.`HT` AND `calculations`.`PRG_ID` = 5) + 
31.
	(SELECT `cost` FROM `calculations` WHERE `calculations`.`level` = `pcs`.`AO` AND `calculations`.`PRG_ID` = 6) + 
32.
	(SELECT `cost` FROM `calculations` WHERE `calculations`.`level` = `pcs`.`DT` AND `calculations`.`PRG_ID` = 7) + 
33.
	(SELECT `cost` FROM `calculations` WHERE `calculations`.`level` = `pcs`.`CK` AND `calculations`.`PRG_ID` = 8) + 
34.
	(SELECT `cost` FROM `calculations` WHERE `calculations`.`level` = `pcs`.`SM` AND `calculations`.`PRG_ID` = 9) + 
35.
	(SELECT `cost` FROM `calculations` WHERE `calculations`.`level` = `pcs`.`DM` AND `calculations`.`PRG_ID` = 10) + 
36.
	(SELECT `cost` FROM `calculations` WHERE `calculations`.`level` = `pcs`.`SC` AND `calculations`.`PRG_ID` = 11) + 
37.
	(SELECT `cost` FROM `calculations` WHERE `calculations`.`level` = `pcs`.`RT` AND `calculations`.`PRG_ID` = 12) + 
38.
	(SELECT `cost` FROM `calculations` WHERE `calculations`.`level` = `pcs`.`BC` AND `calculations`.`PRG_ID` = 13) 
39.
	) / 1000 
40.
	WHERE `USER_ID` != 0;"; 
41.
	$response = $db->query($query); 
42.
?>
Auch wenn ich hier viele Einzelabfragen habe, ist eine Zeit von 50 Sekunden wohl sehr weit weg von der Realität.
Was mich an der ganzen Sache noch stutzig macht, ist dass mein Server kaum Arbeitsspeicher benutzt, dafür aber eine relativ hohe CPU-Auslastung aufweist. Der Rechner hat 4GB RAM die ich sicher auch gern nutzen möchte.
6c192e1b02235214a4f2d1d9420178be - Klicke auf das Bild, um es zu vergrößern

Leider kenne ich mich mit der Konfiguration eines MySQL-Servers nicht aus deswegen bin ich hier her gekommen.
Zudem ärgern mich die roten Einträge im phpmyadmin-Stutus:
01.
Slow_queries 73 
02.
Innodb_buffer_pool_reads 36 
03.
Handler_read_rnd 120,2 k 
04.
Handler_read_rnd_next 542,4 M 
05.
Created_tmp_disk_tables 24,5 k 
06.
Key_writes 30,2 k 
07.
Select_full_join 832 
08.
Sort_merge_passes 2 
09.
Opened_tables 5,9 k 
10.
Table_locks_waited 20,5 k 
Leider kann ich davon nichts verstehen und habe auch keine Ahnung ob eines davon der Grund ist warum meine Datenbank so langsam ist. Oder einfach nur eine Folge einer falschen Einstellung

Als letztes hätte ich dann noch die config-Datei vom MySQL-Server im Angebot. Ich vermute, mit meinem wenigen Wissen, dass darin der Fehler liegen könnte. Nur leider fehlt mir, wie schon erwähnt, das Wissen wie MySQL im Hintergrund funktioniert.
01.
02.
# The MySQL database server configuration file. 
03.
04.
# You can copy this to one of: 
05.
# - "/etc/mysql/my.cnf" to set global options, 
06.
# - "~/.my.cnf" to set user-specific options. 
07.
#  
08.
# One can use all long options that the program supports. 
09.
# Run program with --help to get a list of available options and with 
10.
# --print-defaults to see which it would actually understand and use. 
11.
12.
# For explanations see 
13.
# http://dev.mysql.com/doc/mysql/en/server-system-variables.html 
14.
 
15.
# This will be passed to all mysql clients 
16.
# It has been reported that passwords should be enclosed with ticks/quotes 
17.
# escpecially if they contain "#" chars... 
18.
# Remember to edit /etc/mysql/debian.cnf when changing the socket location. 
19.
[client] 
20.
port		= 3306 
21.
socket		= /var/run/mysqld/mysqld.sock 
22.
 
23.
# Here is entries for some specific programs 
24.
# The following values assume you have at least 32M ram 
25.
 
26.
# This was formally known as [safe_mysqld]. Both versions are currently parsed. 
27.
[mysqld_safe] 
28.
socket		= /var/run/mysqld/mysqld.sock 
29.
nice		= 0 
30.
 
31.
[mysqld] 
32.
33.
# * Basic Settings 
34.
35.
 
36.
37.
# * IMPORTANT 
38.
#   If you make changes to these settings and your system uses apparmor, you may 
39.
#   also need to also adjust /etc/apparmor.d/usr.sbin.mysqld. 
40.
41.
 
42.
user		= mysql 
43.
socket		= /var/run/mysqld/mysqld.sock 
44.
port		= 3306 
45.
basedir		= /usr 
46.
datadir		= /var/lib/mysql 
47.
tmpdir		= /tmp 
48.
skip-external-locking 
49.
50.
# Instead of skip-networking the default is now to listen only on 
51.
# localhost which is more compatible and is not less secure. 
52.
bind-address		= 127.0.0.1 
53.
54.
# * Fine Tuning 
55.
56.
key_buffer		= 16M 
57.
max_allowed_packet	= 16M 
58.
thread_stack		= 256K 
59.
thread_cache_size       = 32 
60.
# This replaces the startup script and checks MyISAM tables if needed 
61.
# the first time they are touched 
62.
myisam-recover         = BACKUP 
63.
#max_connections        = 100 
64.
table_cache            = 512 
65.
#thread_concurrency     = 10 
66.
67.
# * Query Cache Configuration 
68.
69.
query_cache_limit	= 5M 
70.
query_cache_size        = 32M 
71.
72.
# * Logging and Replication 
73.
74.
# Both location gets rotated by the cronjob. 
75.
# Be aware that this log type is a performance killer. 
76.
# As of 5.1 you can enable the log at runtime! 
77.
#general_log_file        = /var/log/mysql/mysql.log 
78.
#general_log             = 1 
79.
 
80.
log_error                = /var/log/mysql/error.log 
81.
 
82.
# Here you can see queries with especially long duration 
83.
#log_slow_queries	= /var/log/mysql/mysql-slow.log 
84.
#long_query_time = 2 
85.
#log-queries-not-using-indexes 
86.
87.
# The following can be used as easy to replay backup logs or for replication. 
88.
# note: if you are setting up a replication slave, see README.Debian about 
89.
#       other settings you may need to change. 
90.
#server-id		= 1 
91.
#log_bin			= /var/log/mysql/mysql-bin.log 
92.
expire_logs_days	= 10 
93.
max_binlog_size         = 100M 
94.
#binlog_do_db		= include_database_name 
95.
#binlog_ignore_db	= include_database_name 
96.
97.
# * InnoDB 
98.
99.
# InnoDB is enabled by default with a 10MB datafile in /var/lib/mysql/. 
100.
# Read the manual for more InnoDB related options. There are many! 
101.
102.
# * Security Features 
103.
104.
# Read the manual, too, if you want chroot! 
105.
# chroot = /var/lib/mysql/ 
106.
107.
# For generating SSL certificates I recommend the OpenSSL GUI "tinyca". 
108.
109.
# ssl-ca=/etc/mysql/cacert.pem 
110.
# ssl-cert=/etc/mysql/server-cert.pem 
111.
# ssl-key=/etc/mysql/server-key.pem 
112.
 
113.
 
114.
 
115.
[mysqldump] 
116.
quick 
117.
quote-names 
118.
max_allowed_packet	= 16M 
119.
 
120.
[mysql] 
121.
#no-auto-rehash	# faster start of mysql but no tab completition 
122.
 
123.
[isamchk] 
124.
key_buffer		= 16M 
125.
 
126.
127.
# * IMPORTANT: Additional settings that can override those from this file! 
128.
#   The files must end with '.cnf', otherwise they'll be ignored. 
129.
130.
!includedir /etc/mysql/conf.d/
Ich würde mich sehr freuen, wenn mir jehmand mit dem Problem helfen kann. Wenn irgendwelche Daten fehlen, werde ich die natürlich nachliefern.

Vielen Dank und freundliche Grüße
Freaky-Boy
Mitglied: maretz
30.06.2012 um 21:44 Uhr
Ich uerde mal dein sqlstatement optimieren.... Es kann nicht das optimum sein das statement (z.b. Unterer bereich) 13 mal nur mit einem geaenderten parameter auszufuehren... Da darfst nochmal druebergucken....
Bitte warten ..
Mitglied: dog
01.07.2012, aktualisiert um 02:22 Uhr
Es gibt ein Script was dir automatisch Optimierungen anbietet:

http://mysqltuner.pl/mysqltuner.pl

4GB RAM auf einem vServer heißen auch gar nichts.
Das ist der Maximalwert, wirklich relevant ist nur was in deinem Vertrag garantiert ist.
Bitte warten ..
Mitglied: Freaky-Boy
01.07.2012 um 17:58 Uhr
Der hier aufgezeigt Befehl ist nur ein Beispiel und in dem Fall das krasseste Beispiel.
Eine normale Abfrage mit einem einfachen Join dauert auch schon 0,2 Sekunden. Das ist mir zu lang. Da bin ich anderes gewohnt.

01.
 >>  MySQLTuner 1.2.0 - Major Hayden <major@mhtx.net> 
02.
 >>  Bug reports, feature requests, and downloads at http://mysqltuner.com/ 
03.
 >>  Run with '--help' for additional options and output filtering 
04.
 
05.
-------- General Statistics -------------------------------------------------- 
06.
[--] Skipped version check for MySQLTuner script 
07.
[OK] Currently running supported MySQL version 5.1.63-0ubuntu0.10.04.1 
08.
[!!] Switch to 64-bit OS - MySQL cannot currently use all of your RAM 
09.
 
10.
-------- Storage Engine Statistics ------------------------------------------- 
11.
[--] Status: +Archive -BDB -Federated +InnoDB -ISAM -NDBCluster 
12.
[--] Data in MyISAM tables: 3M (Tables: 475) 
13.
[--] Data in InnoDB tables: 320K (Tables: 20) 
14.
[!!] Total fragmented tables: 82 
15.
 
16.
-------- Security Recommendations  ------------------------------------------- 
17.
[OK] All database users have passwords assigned 
18.
 
19.
-------- Performance Metrics ------------------------------------------------- 
20.
[--] Up for: 2d 6h 1m 38s (1M q [10.065 qps], 136K conn, TX: 710M, RX: 538M) 
21.
[--] Reads / Writes: 50% / 50% 
22.
[--] Total buffers: 74.0M global + 2.7M per thread (151 max threads) 
23.
[OK] Maximum possible memory usage: 489.2M (11% of installed RAM) 
24.
[OK] Slow queries: 0% (115/1M) 
25.
[OK] Highest usage of available connections: 31% (48/151) 
26.
[OK] Key buffer size / total MyISAM indexes: 16.0M/2.1M 
27.
[OK] Key buffer hit rate: 100.0% (48M cached / 939 reads) 
28.
[OK] Query cache efficiency: 40.9% (363K cached / 889K selects) 
29.
[OK] Query cache prunes per day: 0 
30.
[OK] Sorts requiring temporary tables: 0% (2 temp sorts / 215K sorts) 
31.
[!!] Joins performed without indexes: 1239 
32.
[OK] Temporary tables created on disk: 20% (27K on disk / 133K total) 
33.
[OK] Thread cache hit rate: 99% (51 created / 136K connections) 
34.
[!!] Table cache hit rate: 6% (512 open / 8K opened) 
35.
[OK] Open file limit used: 47% (558/1K) 
36.
[OK] Table locks acquired immediately: 99% (3M immediate / 3M locks) 
37.
[OK] InnoDB data size / buffer pool: 320.0K/8.0M 
38.
 
39.
-------- Recommendations ----------------------------------------------------- 
40.
General recommendations: 
41.
    Run OPTIMIZE TABLE to defragment tables for better performance 
42.
    Enable the slow query log to troubleshoot bad queries 
43.
    Adjust your join queries to always utilize indexes 
44.
    Increase table_cache gradually to avoid file descriptor limits 
45.
Variables to adjust: 
46.
    join_buffer_size (> 128.0K, or always use indexes with joins) 
47.
    table_cache (> 512)
Das mit der automatischen Optimierung ist zwar schön aber bringt mir nicht wenn ich mit der Konfiguration nicht auskenne.
Zugesichert sind mir 2 GB.
Bitte warten ..
Mitglied: Biber
01.07.2012, aktualisiert um 19:17 Uhr
Moin Freaky-Boy,

was erwartest du denn, was wir auf Grund der paar Infos hier an tollen Tipps liefern können?
Die offensichtlichen und banalen Klemmer tauchen ja auch - nicht weiter überraschend - in dem Optimize-Ratgeber auf:
[!!] Joins performed without indexes: 1239
[!!] Table cache hit rate: 6% (512 open / 8K opened)

Beides sind ohnehin die ersten Dinge, an denen jeder geschraubt hätte:
  • unterstütze deine Join- und erst recht die FK-Beziehungen durch entsprechende Indizes
  • setz den table_cache hoch von 512 auf 2048

Kläre zusätzlich in deinem Datenmodell, ob die bedingungen
...WHERE `market`.`PART_ID` = `pcs`.`fan1` AND `market`.`TYPE_ID` = 7) +  
 
-- und -- 
..SELECT `cost` FROM `calculations` WHERE `calculations`.`level` = `pcs`.`DM` AND `calculations`.`PRG_ID` = 10)
...so redundant sind, wie zu befürchten ist.
Sprich: gibt es denn z.b einen real existierenden Fall, in dem calculations.level = pos.DM ist, aber calculations.PRG_ID nicht gleich 10 ?? Ich denke nein.

und selbst wenn, löse es wie von maretz angeregt, über einen Join auf ein SELECT sum(cost) as cost , level, PRG_ID from calculations group by level, PRG_ID und mach das WHERE (level = 'DM' AND PRG_ID = 10) or (level='XY' and PRG_ID=99..) in der WHERE-Clause am Ende.

Grüße
Biber
Bitte warten ..
Mitglied: maretz
02.07.2012 um 08:01 Uhr
Moin,

bevor du aber die ganze Konfig umwirfst wäre es besser deine Abfragen zu optimieren... Hast du z.B. bei den ganzen Formulierungen nur "Varchar" oder ähnliche Typen drin? Gibt es zwingende Gründe warum du keinen Index verwendest?

Ich würde mal sagen das deine cache-hit-rate soweit weg von gut und böse ist das es da definitiv noch optimierungspotential gibt.

Erst wenn du die Abfragen optimiert hast kann man sich die Konfig angucken. Vorher ist es Zeitverschwendung da was zu ändern. Ist ja schön wenn die Konfig (einmalig) verbessert wird - dafür aber 10 Abfragen pro Sekunde reinhageln die durch mangelnde Optimierung zuviel Zeit kosten... Einmal Sparen, Zehnmal verschwenden - hört sich das für dich optimal an?
Bitte warten ..
Neuester Wissensbeitrag
Ähnliche Inhalte
E-Mail
gelöst SPF richtig Einstellen (3)

Frage von MS6800 zum Thema E-Mail ...

Datenbanken
gelöst Wordpress findet MySQL Server nicht (27)

Frage von 118080 zum Thema Datenbanken ...

Heiß diskutierte Inhalte
Windows Userverwaltung
Ausgeschiedene Mitarbeiter im Unternehmen - was tun mit den AD Konten? (32)

Frage von patz223 zum Thema Windows Userverwaltung ...

LAN, WAN, Wireless
FritzBox, zwei Server, verschiedene Netze (21)

Frage von DavidGl zum Thema LAN, WAN, Wireless ...

Viren und Trojaner
Aufgepasst: Neue Ransomware Goldeneye verbreitet sich rasant (20)

Link von Penny.Cilin zum Thema Viren und Trojaner ...

Windows Netzwerk
Windows 10 RDP geht nicht (18)

Frage von Fiasko zum Thema Windows Netzwerk ...