Heim >Datenbank >MySQL-Tutorial >So beheben Sie Produktionsfehler, die durch MySQL-Update-SQL verursacht werden
Einerseits: Auf der Clusterverwaltungsseite, die der Cloud-Datenbank PolarDB in der Alibaba Cloud-Konsole entspricht, wurde in der Ein-Klick-Diagnosesitzungsverwaltung im Diagnose- und Optimierungsmodul Folgendes festgestellt Die Ausführung eines bestimmten SQL-Updates dauerte sehr lange stieg weiter an und einige Vorgänge wirkten sich negativ auf die Nutzung durch die Kunden aus.
GeschäftshintergrundDa der Geschäftsablauf im Geschäftsbetrieb relativ komplex ist und der Austausch reiner Technologie nicht im Mittelpunkt der Diskussion steht, werden Analogien verwendet, um die Gründe für das Auftreten des Problems besser zu verstehen Wird zum Teilen des Komplexes verwendet. Die Geschäftsanalogie lautet wie folgt: Es gibt drei Tabellen in der Datenbank, die erste Tabelle ist
t_grandfather (Nachkommentabelle), DDL Wie folgt: CREATE TABLE `t_grandfather ` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`count` int(11) NOT NULL DEFAULT 0 COMMENT '子孙后代数量',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='老爷表';
CREATE TABLE `t_father ` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`grandfather_id` int(11) NOT NULL COMMENT '老爷表id',
PRIMARY KEY (`id`),
KEY `idx_grandfather_id` (`grandfather_id`),
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='老爸表';
CREATE TABLE `t_grandson` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`grandfather_id` int(11) NOT NULL COMMENT '老爷表id',
PRIMARY KEY (`id`),
KEY `idx_grandfather_id` (`grandfather_id`),
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='孙子表';
Die Geschäftslogikbeziehung zwischen den drei Tabellen besteht darin, dass zuerst die Mastertabelle generiert wird und der Master dann viele Frauen (Geschäft) nimmt und weiterhin Babys bekommt Wenn das Baby geboren wird, wird gleichzeitig eine Papa-Tabelle erstellt. Die Anzahl = Anzahl + 1 der Master-Tabelle wird aktualisiert, um anzuzeigen, dass ein neuer Nachwuchs hinzugefügt wurde. Die zuvor geborenen Babys werden auch Frauen haben, und ihre Frauen werden auch Babys haben. Für den Meister bedeutet dies, dass er einen Enkel hat (was neue Geschäftsdaten generiert). Nachdem er einen Enkel bekommen hat, muss er auch die Anzahl aktualisieren +1 der Master-Tabelle, was bedeutet, dass ein neuer Nachkomme hinzugefügt wurde usw. Es gibt keine Nachkommen (Geschäftsdaten werden kontinuierlich generiert). Wie in der folgenden Abbildung gezeigt: Die Logik von
t_father
undt_grandson gibt, aktualisieren Sie
t_grandfather. Dieses logische Design stellt kein großes Problem dar, aber angesichts der großen Datenmenge in der Enkeltabelle wird hier ein sehr ernstes Leistungsproblem auftreten. Das Folgende ist ein Teil des aus dem Unternehmen extrahierten Pseudocodes: /**
* 处理 father 的业务
*/
public void doFatherBusiness (){
//do fatherBusiness baba .... 此处省
// 插入 t_father 表
if (fatherMapper.inster(father)){
//update t_grandfather set count=count+1 where id= #{grandfatherId}
grandfatherMapper.updateCount(father.getGrandfatherId ()) ;
}
}
/**
* 处理 grandson 的业务
*/
public void doGrandsonBusiness (){
//do grandson baba .... 此处省略
// 插入 t_grandson 表
if(grandsonMapper.inster(grandson)){
//update t_grandfather set count=count+1 where id= #{grandfatherId}
grandfatherMapper.updateCount(grandson.getGrandfatherId());
}
}
Wenn mehrere Unternehmen (Threads) jeweils die obige Methode aufrufen, führt dies zu einem enormen Druck auf den Aktualisierungsvorgang der Tabelle t_grandfather, insbesondere wenn dieselbe ID aktualisiert wird . Der Wettbewerb um Sperren innerhalb des MySQL-Servers ist sehr groß. Die endgültige Leistung stimmt mit der obigen Hintergrundbeschreibung überein. Lösung
1. Vorübergehende Lösung:
2 Langfristige Lösung: Ändern Sie einerseits das oben genannte Geschäft Logik und Einfügen der Tabellen t_grandson und t_father, Aktualisieren des Zählfelds der Tabelle t_grandfather, andererseits werden alle auf andere Methoden umgestellt;
Das obige ist der detaillierte Inhalt vonSo beheben Sie Produktionsfehler, die durch MySQL-Update-SQL verursacht werden. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!