reklama - zainteresowany?

Wysoko wydajne MySQL. Sprawdzone strategie dzia - Helion

Wysoko wydajne MySQL. Sprawdzone strategie dzia
Autor: Silvia Botros, Jeremy Tinley
Tytuł oryginału: High Performance MySQL: Proven Strategies for Operating at Scale, 4th Edition
ISBN: 978-83-283-9294-6
okładka: mi
Księgarnia: Helion

Książka będzie dostępna od lipca 2022

Spis treści

Wysoko wydajne MySQL. Sprawdzone strategie działania na dużą skalę. Wydanie IV -- spis treści

Przedmowa

Wprowadzenie

Rozdział 1. Architektura MySQL

  • Architektura logiczna MySQL
    • ZarzÄ…dzanie poÅ‚Ä…czeniami i bezpieczeÅ„stwo
    • Optymalizacja i wykonywanie zapytaÅ„
  • Kontrola wspóÅ‚bieżnoÅ›ci
    • Blokady odczytu (zapisu)
    • ZasiÄ™g dziaÅ‚ania blokad
  • Transakcje
    • Poziomy izolacji
    • Zakleszczenia
    • Rejestrowanie zdarzeÅ„ transakcji
    • Transakcje w MySQL
  • Mechanizm Multiversion Concurrency Control
  • Replikacja
  • Struktura plików danych
  • Silnik InnoDB
    • ObsÅ‚uga dokumentu JSON
    • Zmiany w sÅ‚owniku danych
    • Niepodzielne operacje typu DDL
  • Podsumowanie

Rozdział 2. Monitorowanie w świecie inżynierii niezawodności

  • WpÅ‚yw inżynierii niezawodnoÅ›ci na zespoÅ‚y administratorów baz danych
  • Definiowanie celów poziomu usÅ‚ugi
    • Co spowoduje zadowolenie klientów?
  • Co należy mierzyć?
    • Definiowanie SLI i SLO
    • RozwiÄ…zania w zakresie monitorowania
    • Monitorowanie dostÄ™pnoÅ›ci
    • Monitorowanie opóźnienia zapytania
    • Monitorowanie pod kÄ…tem bÅ‚Ä™dów
    • Monitorowanie proaktywne
  • Pomiar dÅ‚ugoterminowej wydajnoÅ›ci dziaÅ‚ania
    • Poznanie rytmu pracy firmy
    • Efektywne Å›ledzenie wskaźników
    • Stosowanie narzÄ™dzi monitorowania do analizy wydajnoÅ›ci dziaÅ‚ania
    • Stosowanie SLO do przygotowania architektury danych
  • Podsumowanie

Rozdział 3. Funkcjonalność Performance Schema

  • Wprowadzenie do Performance Schema
    • Elementy instrumentu
    • Organizacja konsumenta
    • Wykorzystanie zasobów
    • Ograniczenia
    • Schemat sys
    • Poznajemy wÄ…tki
  • Konfiguracja
    • WÅ‚Ä…czanie i wyÅ‚Ä…czanie Performance Schema
    • WÅ‚Ä…czanie i wyÅ‚Ä…czanie instrumentacji
    • WÅ‚Ä…czanie i wyÅ‚Ä…czanie konsumentów
    • Dostrajanie monitorowania okreÅ›lonych obiektów
    • Dostrajanie monitorowania wÄ…tków
    • Dostosowywanie wielkoÅ›ci pamiÄ™ci dla Performance Schema
    • WartoÅ›ci domyÅ›lne
  • Stosowanie Performance Schema
    • Analizowanie zapytaÅ„ SQL
    • Analiza wydajnoÅ›ci dziaÅ‚ania operacji odczytu i zapisu
    • Analiza blokad metadanych
    • Analiza poziomu użycia pamiÄ™ci
    • Analiza zmiennych
    • Analiza najczęściej wystÄ™pujÄ…cych bÅ‚Ä™dów
    • Analiza samej funkcjonalnoÅ›ci Performance Schema
  • Podsumowanie

Rozdział 4. Optymalizacja systemu operacyjnego i osprzętu

  • Co ogranicza wydajność MySQL?
  • W jaki sposób wybrać procesor dla MySQL?
  • Zrównoważenie pamiÄ™ci i zasobów dyskowych
    • Buforowanie, odczyt i zapis
    • Jaki zestaw roboczy jest odpowiedni dla Ciebie?
  • NapÄ™d SSD
    • Ogólne omówienie pamiÄ™ci flash
    • Mechanizm usuwania nieużytków
  • Optymalizacja wydajnoÅ›ci macierzy RAID
    • Awaria macierzy RAID, odzyskiwanie danych i monitoring
    • Konfiguracja macierzy RAID i buforowanie
  • Konfiguracja sieciowa
  • Wybór systemu plików
    • Wybór zarzÄ…dcy kolejki dyskowej
    • PrzestrzeÅ„ wymiany
    • Stan systemu operacyjnego
    • Inne użyteczne narzÄ™dzia
  • Podsumowanie

Rozdział 5. Optymalizacja konfiguracji serwera

  • Podstawy konfiguracji MySQL
    • SkÅ‚adnia, zasiÄ™g oraz dynamizm
    • TrwaÅ‚e zmienne systemowe
    • Efekt uboczny ustawiania zmiennych
    • Planowanie zmiany zmiennej
  • Czego nie należy robić?
  • Tworzenie pliku konfiguracyjnego MySQL
    • Konfiguracja minimalna
    • Analizowanie zmiennych stanu serwera MySQL
  • Konfiguracja poziomu użycia pamiÄ™ci
    • Ilość pamiÄ™ci używanej przez każde poÅ‚Ä…czenie
    • Rezerwacja pamiÄ™ci dla systemu operacyjnego
    • Pula buforów InnoDB
    • Bufor wÄ…tków
  • Dostrajanie zachowania operacji I/O w MySQL
    • Dziennik zdarzeÅ„ transakcji InnoDB
    • Bufor dziennika zdarzeÅ„
    • PrzestrzeÅ„ tabel InnoDB
    • Dostosowywanie innych opcji I/O
  • Dostosowywanie wspóÅ‚bieżnoÅ›ci MySQL
  • Ustawienia dotyczÄ…ce bezpieczeÅ„stwa
  • Zaawansowane ustawienia InnoDB
  • Podsumowanie

Rozdział 6. Projektowanie schematu i zarządzanie nim

  • Wybór optymalnego rodzaju danych
    • Liczby caÅ‚kowite
    • Liczby rzeczywiste
    • CiÄ…gi tekstowe
    • Rodzaje danych dla daty i godziny
    • Bitowe rodzaje danych
    • Dane JSON
    • Wybór identyfikatorów
    • Dane specjalnego rodzaju
  • Kwestie, które trzeba wziąć pod uwagÄ™ podczas projektowania schematu w MySQL
    • Zbyt wiele kolumn
    • Zbyt wiele zÅ‚Ä…czeÅ„
    • Wszechobecne wartoÅ›ci typu ENUM
    • Typ ENUM w przebraniu
    • Wartość NULL
  • ZarzÄ…dzanie schematem
    • ZarzÄ…dzanie schematem jako część platformy przechowywania danych
  • Podsumowanie

Rozdział 7. Indeksowanie zapewniające wysoką wydajność

  • Podstawy indeksowania
    • Rodzaje indeksów
    • Zalety indeksów
  • Strategie indeksowania w celu osiÄ…gniÄ™cia maksymalnej wydajnoÅ›ci
    • Prefiks indeksu oraz selektywność indeksu
    • Indeksy wielokolumnowe
    • Wybór odpowiedniej kolejnoÅ›ci kolumn
    • Indeksy klastrowane
    • Indeksy pokrywajÄ…ce
    • Skanowanie indeksu w celu przeprowadzenia sortowania
    • Indeksy zbÄ™dne i powielone
    • Indeksy nieużywane
  • ObsÅ‚uga indeksu oraz tabeli
    • Wyszukiwanie i naprawa uszkodzeÅ„ tabeli
    • Uaktualnianie danych statystycznych indeksu
    • Ograniczanie wielkoÅ›ci indeksu i fragmentacji danych
  • Podsumowanie

Rozdział 8. Optymalizacja wydajności zapytań

  • Dlaczego zapytania sÄ… powolne?
  • Podstawy powolnych zapytaÅ„: optymalizacja dostÄ™pu do danych
    • Czy zapytanie bazy danych obejmuje dane, które sÄ… niepotrzebne?
    • Czy MySQL analizuje zbyt dużą ilość danych?
  • Sposoby restrukturyzacji zapytaÅ„
    • Zapytanie skomplikowane kontra wiele mniejszych
    • PodziaÅ‚ zapytania
    • PodziaÅ‚ zÅ‚Ä…czeÅ„
  • Podstawy wykonywania zapytaÅ„
    • ProtokóÅ‚ klient-serwer MySQL
    • Stany zapytania
    • Proces optymalizacji zapytania
    • Silnik wykonywania zapytaÅ„
    • Zwrot klientowi wyników zapytania
  • Ograniczenia optymalizatora zapytaÅ„ MySQL
    • Ograniczenia klauzuli UNION
    • Szerzenie równoÅ›ci
    • Wykonywanie równolegÅ‚e
    • Równoczesne wykonywanie poleceÅ„ SELECT i UPDATE w tej samej tabeli
  • Optymalizacja okreÅ›lonego rodzaju zapytaÅ„
    • Optymalizacja zapytaÅ„ COUNT()
    • Optymalizacja zapytaÅ„ typu JOIN
    • Optymalizacja zapytaÅ„ typu GROUP BY WITH ROLLUP
    • Optymalizacja zapytaÅ„ typu LIMIT i OFFSET
    • Optymalizacja za pomocÄ… opcji SQL_CALC_FOUND_ROWS
    • Optymalizacja klauzuli UNION
  • Podsumowanie

Rozdział 9. Replikacja

  • Ogólny opis replikacji
    • W jaki sposób dziaÅ‚a replikacja?
  • SzczegóÅ‚y kryjÄ…ce siÄ™ za replikacjÄ…
    • Wybór formatu replikacji
    • Globalny identyfikator transakcji
    • Zapewnienie replikacji odpornoÅ›ci na awarie
    • Replikacja opóźniona
    • Replikacja wielowÄ…tkowa
    • Replikacja póÅ‚synchroniczna
    • Filtry replikacji
  • Poprawne dziaÅ‚anie replikacji pomimo awarii
    • Promocja planowana
    • Promocja nieplanowana
    • Kompromisy zwiÄ…zane z promocjÄ…
  • Topologie replikacji
    • Aktywny-pasywny
    • Aktywny-pula odczytu
    • Odradzane topologie
    • Ring
  • Administracja replikacjÄ… i jej obsÅ‚uga
    • Monitorowanie replikacji
    • Pomiar opóźnienia replikacji
    • OkreÅ›lanie, czy serwer repliki zachowuje spójność z serwerem źródÅ‚a
  • Problemy zwiÄ…zane z replikacjÄ… i sposoby ich rozwiÄ…zywania
    • Uszkodzenie binarnego dziennika zdarzeÅ„ w źródle
    • Nieunikalne identyfikatory serwerów
    • Niezdefiniowane identyfikatory serwerów
    • BrakujÄ…ce tabele tymczasowe
    • Niereplikowanie wszystkich uaktualnieÅ„
    • Ogromne opóźnienie replikacji
    • Zbyt duże pakiety w serwerze źródÅ‚a
    • Brak miejsca na dysku
    • Ograniczenia replikacji
  • Podsumowanie

Rozdział 10. Kopia zapasowa i odzyskiwanie

  • Dlaczego kopia zapasowa?
  • Definiowanie wymagaÅ„ procesu odzyskiwania
  • Projektowanie rozwiÄ…zania kopii zapasowej MySQL
    • Kopia zapasowa online czy offline?
    • Logiczna czy bezpoÅ›rednia kopia zapasowa?
    • Co należy umieszczać w kopii zapasowej?
    • Przyrostowa kopia zapasowa
    • Replikacja
  • ZarzÄ…dzanie kopiÄ… zapasowÄ… binarnych dzienników zdarzeÅ„ i jej tworzenie
  • NarzÄ™dzia do tworzenia kopii zapasowej i przywracania z niej danych
    • MySQL Enterprise Backup
    • Percona XtraBackup
    • mydumper
    • mysqldump
  • Tworzenie kopii zapasowej danych
    • Tworzenie logicznej kopii zapasowej
    • Migawka systemu plików
    • Percona XtraBackup
  • Odzyskiwanie z kopii zapasowej
    • Przywracanie logicznych kopii zapasowych
    • Przywracanie bezpoÅ›rednich plików z migawki
    • Przywracanie danych za pomocÄ… narzÄ™dzia Percona XtraBackup
    • Uruchomienie MySQL po przywróceniu bezpoÅ›rednich plików
  • Podsumowanie

Rozdział 11. Skalowalność MySQL

  • Czym jest skalowanie?
  • Obciążenie ograniczone operacjami odczytu kontra obciążenie ograniczone operacjami zapisu
    • Analiza obciążenia
    • Obciążenie ograniczone operacjami odczytu
    • Obciążenie ograniczone operacjami zapisu
  • Sharding funkcjonalny
  • Skalowanie obciążenia ograniczonego operacjami odczytu
    • ZarzÄ…dzanie konfiguracjÄ… dla pul operacji odczytu
    • Sprawdzanie stanu puli odczytu
    • Algorytmy równoważenia obciążenia
  • Kolejkowanie
  • Skalowanie zapisu za pomocÄ… shardingu
    • Wiele kluczy partycjonowania
    • Wykonywanie zapytaÅ„ miÄ™dzy serwerami
    • Vitess
    • ProxySQL
  • Podsumowanie

Rozdział 12. MySQL w chmurze

  • ZarzÄ…dzany serwer MySQL
    • Amazon Aurora dla MySQL
    • GCP Cloud SQL
  • MySQL w maszynie wirtualnej
    • Rodzaje maszyn wirtualnych w chmurze
    • Wybór odpowiedniego typu maszyny
    • Wybór odpowiedniego typu dysku
    • Wskazówki dodatkowe
  • Podsumowanie

Rozdział 13. Zgodność i MySQL

  • Co to jest zgodność?
    • Service Organization Controls Type 2
    • Ustawa Sarbanesa-Oxleya
    • Norma bezpieczeÅ„stwa Payment Card Industry Data Security Standard
    • Ustawa Health Insurance Portability and Accountability Act
    • Program FedRAMP
    • RozporzÄ…dzenie o ochronie danych osobowych
    • Schrems II
  • Przygotowanie do kontroli zapewnienia zgodnoÅ›ci
    • ZarzÄ…dzanie kluczami tajnymi użytkownika
    • RozdziaÅ‚ ról i danych
    • Åšledzenie zmian
    • Procedury tworzenia kopii zapasowej i przywracania danych
  • Podsumowanie

Dodatek A. Uaktualnianie MySQL

  • Dlaczego należy uaktualnić serwer MySQL?
  • Uaktualnienie cyklu życiowego
  • Testowanie uaktualnienia
    • Testowanie Å›rodowiska programistycznego
    • DokÅ‚adna kopia danych produkcyjnych
    • Replika
    • NarzÄ™dzia
  • Uaktualnienie na dużą skalÄ™
  • Podsumowanie

Dodatek B. MySQL w Kubernetesie

  • Przygotowanie zasobów za pomocÄ… Kubernetesa
    • Staranny wybór celu
    • Wybór pÅ‚aszczyzny kontrolnej
    • PozostaÅ‚e szczegóÅ‚y
  • Podsumowanie

Code, Publish & WebDesing by CATALIST.com.pl



(c) 2005-2025 CATALIST agencja interaktywna, znaki firmowe należą do wydawnictwa Helion S.A.