Linux ­Kurulu­m ve Y­onetim­i
  • Döküman Hakkında
  • Linux ve GNU'nun Geçmişi
    • CentOS, Debian ve FreeBSD Ana Sürümlerin Farkları
  • Temel Komutlar
    • Temel Terminal Komutları
    • Yardım Dosyaları
    • Dosya İzinleri, Yetkiler, Kullanıcılar ve Gruplar
    • Dosya Düzenleme Araçları
      • nano ve pico
      • vi
    • Sıkıştırılmış Dosyalar
  • Standart Girdi ve Çıktı
    • Standart Çıktı
    • Standart Girdi
    • UNIX Pipeline
    • Olmazsa Olmaz: stdio.h
    • Standart Hata ve File Descriptor
    • Forkbomb
    • Named Pipe
  • Gelişmiş Terminal Komutları
    • Tarih ve Saat Ayarlama
    • Sistem Yükünü İzleme
    • patch ve diff
    • xargs
    • awk ve sed
    • egrep ve Regular Expressions
    • rename
    • Imagemagick ve Görüntü Dosyaları
    • wget
    • Python ile Dosya Sunuculuğu
  • Temel Dağıtımlar
    • RHEL Tabanlı (CentOS, Rocky, Alma)
      • rpm Paketleri
      • DNF Paket Yöneticisi
      • Repo Ayarları
      • Network Ayarları
    • Debian
      • deb Paketleri
      • apt Paket Yöneticisi
      • Repo Ayarları
      • Network Ayarları
    • FreeBSD
      • Ports ve pkg Yönetimi
      • Güncelleme Teknikleri
      • Network Ayarları
    • Arch Linux
      • pacman ve AUR
      • Network Ayarları
    • Ortak Network Dosyaları
  • SSH
    • Uzak Sunucuya Bağlanma
    • sshd Sunucu Ayarları
    • Private ve Public Anahtarlar
    • Güvenli Dosya Aktarımı
    • sshfs
  • Kernel Boot
    • Sunucu Başlangıcına Genel Bakış
    • Çekirdeğin Yüklenmesi ve Boot Seçenekleri
    • Çekirdek Parametreleri
    • Bootloader Nedir?
  • User Space
    • Başlangıç: Init
    • Init Versiyonunu Belirlemek
    • System V
      • Servislerin Yönetimi
      • Çalışma Seviyeleri (Run Levels)
      • Örnek System V Servis Oluşturma
    • systemd
      • Servislerin Yönetimi
      • Birimler ve Birim Tipleri
      • Örnek systemd Servis Oluşturma
    • Acil Durumlar ve Tek Kullanıcı Modu
  • BASH Programlama
    • Döngüler ve Diğer Kontrol Yöntemleri
    • Menüler
  • Log Dosyaları
    • Log İnceleme ve Filtreleme
  • İnternet Servisleri
    • Bir sayfanın İnternetteki Serüveni
    • Nameserver Servisleri
    • Apache
    • PHP-FPM
    • FTP/FTPS/SFTP
      • vsftpd
      • ProFTPD
      • SFTP
      • Komut Satırından ftp Kullanımı
  • Zamanlanmış Görevler
    • crontab
    • at
  • Veritabanı
    • MySQL
      • MySQL Kurulumu
      • MySQL Servisini Çalıştırmak
      • Veritabanı ve Tablo oluşturmak
      • SQL Tablosuna Veri Eklemek
      • Temel SQL Sorgularına Giriş
        • Birinci bölüm
      • mysqldump ile yedekleme
      • Replikasyon teknikleri
      • Yedekleri içeri alma
    • PostgreSQL
      • PostgreSQL Kurulumu
      • Temel Yapılandırma
      • Temel Kullanım
    • MongoDB
      • MongoDB Kurulumu
      • Temel Yapılandırma
      • Temel Kullanım
    • Redis
      • Redis Kurulumu
      • Temel Yapılandırma
      • Temel Kullanım
  • Temel Network Yapılandırması
  • Gelişmiş Network Komutları
    • ip
    • ifconfig
    • route
    • ping
    • traceroute
    • dig
    • nslookup
    • netcat
    • nmap
    • tcpdump
    • Wireshark (Giriş)
    • Bantgenişliği Ölçümü
  • Güvenlik
    • Firewalld
    • IPTables
      • Temel İzinler
      • IP ve Port Engelleme
    • selinux
  • Disk Sistemleri
    • ext
    • zfs
    • lvm
  • RAID
    • RAID Biçimleri
    • Verinin Disklere Yayılması
    • Cache
    • Terimler ve Tavsiyeler
  • Örnek Kurulumlar ve Modern Yaklaşımlar
    • CentOS 7 Tam Sistem Kurulumu (Arşiv)
    • AlmaLinux ile Hosting Ortamı Kurulumu
    • Ubuntu ile Hosting Ortamı Kurulumu
    • Modern Hosting Yaklaşımları (PaaS, Coolify vb.)
  • Konteynerleştirme (Docker / Podman)
  • Yapılandırma Yönetimi (Ansible)
  • İzleme ve Uyarı (Prometheus / Grafana)
  • Nginx Web Sunucusu
  • Kubernetes (Giriş)
  • PCI-DSS ve Linux Sistemleri
  • İndeks
  • Kaynaklar
Powered by GitBook
On this page
  • Geri Yükleme Yöntemleri
  • Sıkıştırılmış Yedekleri Geri Yükleme
  • Dikkat Edilmesi Gerekenler
  1. Veritabanı
  2. MySQL

Yedekleri içeri alma

mysqldump ile oluşturulan mantıksal yedek dosyaları (.sql), içerdikleri SQL komutlarının mysql (veya mariadb) komut satırı istemcisi aracılığıyla çalıştırılmasıyla geri yüklenir.

Geri Yükleme Yöntemleri

1. Komut Satırı Yönlendirmesi (<) (Önerilen)

Bu en yaygın ve genellikle en verimli yöntemdir. Yedek dosyası, mysql istemcisinin standart girdisine yönlendirilir.

  • Tek Bir Veritabanını Geri Yükleme: Geri yükleme yapmadan önce hedef veritabanının genellikle mevcut olması gerekir (eğer yedek dosyası CREATE DATABASE ifadesini içermiyorsa).

    # Önce hedef veritabanını oluştur (varsa bu adım atlanabilir)
    mysql -u root -p -e "CREATE DATABASE IF NOT EXISTS <hedef_veritabani_adı> CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;"
    
    # Yedek dosyasını içeri aktar
    mysql -u <kullanıcı> -p <hedef_veritabani_adı> < yedek.sql 

    Komutlar sizden ilgili kullanıcının şifresini isteyecektir.

  • Tüm Veritabanlarını Geri Yükleme: Eğer yedek dosyası --all-databases veya --databases seçeneği ile oluşturulmuşsa ve CREATE DATABASE ifadelerini içeriyorsa, komut satırında veritabanı adı belirtilmez:

    mysql -u root -p < tum_yedekler.sql

2. SOURCE Komutu (MySQL/MariaDB Kabuğu İçinden)

mysql veya mariadb kabuğu içindeyken SOURCE komutu ile bir .sql dosyası çalıştırılabilir. Özellikle interaktif oturumlarda veya daha küçük dosyalar için kullanışlıdır.

# MySQL/MariaDB kabuğuna bağlan
mysql -u <kullanıcı> -p

# Gerekirse hedef veritabanını oluştur ve seç
mysql> CREATE DATABASE IF NOT EXISTS <hedef_veritabani_adı>;
mysql> USE <hedef_veritabani_adı>;

# SOURCE komutu ile yedek dosyasını çalıştır (tam dosya yolu gerekir)
mysql> SOURCE /tam/dosya/yolu/yedek.sql; 

# Kabuktan çık
mysql> quit;

Sıkıştırılmış Yedekleri Geri Yükleme

Eğer yedek dosyası gzip veya zstd gibi bir araçla sıkıştırılmışsa, dosyayı önce açıp sonra mysql'e yönlendirmek yerine, açma işlemini ve geri yüklemeyi tek bir komutla birleştirebilirsiniz:

  • gzip (.gz):

    gunzip < yedek.sql.gz | mysql -u <kullanıcı> -p <hedef_veritabani_adı>
    # veya zcat kullanın:
    # zcat yedek.sql.gz | mysql -u <kullanıcı> -p <hedef_veritabani_adı>
  • zstd (.zst):

    zstdcat yedek.sql.zst | mysql -u <kullanıcı> -p <hedef_veritabani_adı>

Dikkat Edilmesi Gerekenler

  • Veri Üzerine Yazma: Eğer hedef veritabanı veya tablolar zaten mevcutsa ve yedek dosyası DROP DATABASE veya DROP TABLE ifadelerini içeriyorsa (genellikle --add-drop-database veya --add-drop-table seçenekleriyle oluşturulmuşsa), geri yükleme işlemi mevcut verilerin silinmesine neden olur. Geri yükleme yapmadan önce neyin üzerine yazılacağından emin olun!

  • Karakter Seti: Yedek dosyasının ve hedef veritabanının karakter setlerinin uyumlu olması önemlidir, aksi takdirde özellikle Türkçe karakterlerde sorunlar yaşanabilir. mysqldump ve mysql istemcisinde --default-character-set=utf8mb4 gibi seçenekler kullanılabilir.

  • Büyük Dosyalar: Çok büyük yedek dosyalarını geri yüklemek uzun sürebilir. mysql istemcisinin zaman aşımına uğramaması veya ağ bağlantısının kopmaması önemlidir. Gerekirse screen veya tmux gibi araçlar içinde çalıştırmak faydalı olabilir.

  • Yetkiler: Geri yükleme işlemini yapan kullanıcının hedef veritabanı üzerinde gerekli yetkilere (CREATE, INSERT, DROP vb.) sahip olması gerekir. Genellikle root veya yetkilendirilmiş özel bir kullanıcı kullanılır.

Yedekleme ve geri yükleme işlemleri, veritabanı yönetiminin kritik parçalarıdır ve düzenli olarak test edilmelidir.

PreviousReplikasyon teknikleriNextPostgreSQL

Last updated 1 month ago