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
  • Temel Kullanım
  • Yaygın Kullanılan Seçenekler
  • Yedekleri Sıkıştırma
  • Yedekleri Geri Yükleme
  1. Veritabanı
  2. MySQL

mysqldump ile yedekleme

mysqldump, MySQL ve MariaDB veritabanlarının mantıksal yedeklerini (logical backup) almak için kullanılan standart bir komut satırı aracıdır. Oluşturduğu yedek dosyası, veritabanını ve/veya tabloları yeniden oluşturmak için gerekli SQL ifadelerini (CREATE DATABASE, CREATE TABLE, INSERT INTO vb.) içeren bir metin dosyasıdır.

Bu yöntem, fiziksel yedeklemeye (veritabanı dosyalarını doğrudan kopyalama) göre genellikle daha esnektir (farklı sürümler veya mimariler arasında taşınabilir), ancak büyük veritabanları için yedekleme ve geri yükleme işlemi daha uzun sürebilir.

Temel Kullanım

mysqldump komutu genellikle şu formatta kullanılır:mysqldump [seçenekler] <veritabanı_adı> [tablo_adları...] > yedek_dosyasi.sql

  • Tek Bir Veritabanını Yedekleme:

    mysqldump -u <kullanıcı> -p <veritabanı_adı> > yedek.sql

    Komut, belirtilen kullanıcının şifresini soracaktır. <veritabanı_adı> yerine yedeklenecek veritabanının adını yazın. Çıktı (yedek.sql dosyası) tüm CREATE TABLE ve INSERT INTO ifadelerini içerecektir.

  • Birden Fazla Veritabanını Yedekleme:--databases seçeneği ile birden fazla veritabanı belirtilebilir. Bu seçenek kullanıldığında, yedek dosyası CREATE DATABASE IF NOT EXISTS ve USE <veritabanı_adı> ifadelerini de içerir.

    mysqldump -u <kullanıcı> -p --databases <db1_adı> <db2_adı> > coklu_yedek.sql
  • Tüm Veritabanlarını Yedekleme: Sunucudaki tüm veritabanlarını yedeklemek için --all-databases seçeneği kullanılır.

    mysqldump -u root -p --all-databases > tum_yedekler.sql

    Bu komut genellikle root veya tüm veritabanlarına erişim yetkisi olan bir kullanıcı ile çalıştırılır.

  • Sadece Belirli Tabloları Yedekleme: Veritabanı adından sonra boşlukla ayırarak sadece belirli tablo adları yazılabilir:

    mysqldump -u <kullanıcı> -p <veritabanı_adı> tablo1 tablo3 > tablolar_yedek.sql

Yaygın Kullanılan Seçenekler

  • -u <kullanıcı>, -p: Veritabanına bağlanmak için kullanıcı adı ve şifre istemi. Şifreyi doğrudan komut satırında -p<şifre> şeklinde (boşluksuz) yazmak mümkündür ancak güvenlik açısından önerilmez (komut geçmişinde görünebilir).

  • --host=<host_adı>, --port=<port_no>: Eğer veritabanı sunucusu yerel makinede değilse veya standart portu (3306) kullanmıyorsa bağlantı bilgilerini belirtir.

  • --result-file=<dosya_adı>: Çıktıyı > yönlendirmesi yerine doğrudan belirtilen dosyaya yazar.

  • --single-transaction: (InnoDB tabloları için önerilir) Yedekleme işlemi başlamadan önce bir veritabanı anlık görüntüsü (snapshot) oluşturur ve tüm yedeklemeyi bu anlık görüntü üzerinden tek bir işlem (transaction) içinde yapar. Bu, yedekleme sırasında tabloların kilitlenmesini engeller ve tutarlı bir yedek alınmasını sağlar. MyISAM gibi transactional olmayan tablolar için etkisi yoktur. --lock-tables ile birlikte kullanılmamalıdır.

  • --quick (-q): Büyük tablolar için önerilir. mysqldump'ın tüm tablo içeriğini belleğe almasını engeller, bunun yerine satır satır okuyup yazar.

  • --routines (-R): Saklı yordamları (stored procedures) ve fonksiyonları (functions) yedek dosyasına dahil eder.

  • --triggers: Tablolara ait tetikleyicileri (triggers) yedek dosyasına dahil eder. (Genellikle varsayılan olarak dahildir).

  • --events (-E): Zamanlanmış olayları (scheduled events) yedek dosyasına dahil eder.

  • --no-data (-d): Sadece veritabanı ve tablo yapılarını (schema) yedekler, verileri (INSERT ifadelerini) dahil etmez. Boş bir veritabanı yapısı oluşturmak için kullanışlıdır.

  • --databases: Yedeklenen veritabanları için CREATE DATABASE ifadelerini ekler. Birden fazla veritabanı yedeklerken kullanışlıdır.

  • --all-databases: Tüm veritabanları için CREATE DATABASE ifadelerini ekler.

  • --add-drop-database: --all-databases veya --databases ile kullanıldığında, CREATE DATABASE ifadesinden önce DROP DATABASE IF EXISTS ifadesini ekler. Geri yüklerken mevcut veritabanının silinmesini sağlar (dikkatli kullanılmalıdır!).

  • --add-drop-table: Her CREATE TABLE ifadesinden önce DROP TABLE IF EXISTS ifadesini ekler. Geri yüklerken mevcut tabloların silinmesini sağlar.

Yedekleri Sıkıştırma

mysqldump çıktısı genellikle büyük olabilen bir metin dosyasıdır. Disk alanı kazanmak için çıktıyı doğrudan gzip, zstd gibi bir sıkıştırma aracına pipe ile göndermek yaygın bir pratiktir:

# gzip ile sıkıştırma
mysqldump -u root -p --single-transaction --all-databases | gzip > tum_yedekler.sql.gz

# zstd ile sıkıştırma (daha modern ve hızlı)
mysqldump -u root -p --single-transaction --all-databases | zstd > tum_yedekler.sql.zst

Yedekleri Geri Yükleme

mysqldump, MySQL/MariaDB veritabanlarını yedeklemek için esnek ve güçlü bir araçtır. Özellikle --single-transaction gibi seçenekler, canlı sistemlerde tutarlı yedekler almak için önemlidir.

PreviousBirinci bölümNextReplikasyon teknikleri

Last updated 1 month ago

mysqldump ile alınan .sql (veya sıkıştırılmış) dosyaları geri yüklemek için mysql (veya mariadb) komut satırı istemcisi kullanılır. Bu işlem bölümünde anlatılmaktadır.

Yedekleri İçeri Alma