VDS kullananların önemli bir bölümü, komut satırının sağladığı tam kontrol, açık kaynağın esnekliği ve düşük maliyet avantajları nedeniyle Ubuntu, Debian, CentOS veya AlmaLinux gibi Linux dağıtımlarını seçiyor. Sunucu teknolojilerindeki temel ayrımları merak edenler için, bu konuyu “VDS mi VPS mi? İki Sunucu Modeli Arasındaki Farklar” yazımızda ayrıntılı şekilde ele almıştık.
Linux tabanlı bir VDS tercih edildiğinde, günlük işler yalnızca kontrol panelleriyle sınırlı kalmaz; çoğu yönetim adımı doğrudan terminal üzerinden yürütülür. Disk denetimleri, servis yönetimi, yedekleme süreçleri ve güvenlik ayarları gibi pek çok işlem birkaç satır komutla hızlı ve etkili biçimde kontrol altına alınabilir.
VDS Yönetiminde Linux Komutları
Linux dağıtımları, VDS ve dedicated sunucuların bel kemiğini oluşturur. Bunun iki temel nedeni vardır.
Kaynak verimliliği: Linux’un hafif yapısı, aynı donanımda daha fazla servisin güvenle çalışmasına olanak tanır.
Kontrol ve esneklik: Komut satırı araçları sayesinde sisteme ayrıntılı müdahale yapılabilir; bu da web barındırma, veritabanı yönetimi ve uygulama dağıtımında ciddi avantaj sağlar.
Bu nedenle Linux tabanlı bir VDS kullanıyorsanız, yalnızca işletim sistemini kurmak yeterli değildir. fsck, tar, chmod, systemctl ve rsync gibi komutlar günlük işlerin omurgası haline gelir.
“fsck” – Disk Kontrolü
Sunucularda en kritik bileşenlerden biri disk yapısıdır. Diskte oluşan bozulmalar veya hatalar, uygulamaların çökmesine ya da veri kaybına yol açabilir. Bu riskleri azaltmak için Linux sistemlerinde fsck aracı kullanılır. Fsck, dosya sistemini tarar, hataları tespit eder ve gerektiğinde onarım yapar.
fsck -fy /dev/sda1
Bu komutu çalıştırılarak ilgili disk bölümü otomatik biçimde denetlenir ve hatalar düzeltilir. Bu işlem, özellikle VDS yöneticileri için veri bütünlüğünü korumada kritik bir rol oynar.

| Parametre | Açıklama |
|---|---|
| -A | /etc/fstab dosyasında listelenen tüm dosya sistemlerini kontrol eder |
| -C | Kontrol sürecinde ilerleme çubuğu gösterir |
| -l | Disk bölümü üzerinde başka programların işlem yapmasını engellemek için cihazı kilitler |
| -M | Bağlı (mounted) olan dosya sistemlerini kontrol etmez |
| -N | Yapılacak işlemleri sadece gösterir, herhangi bir değişiklik yapmaz |
| -P | Root dahil tüm dosya sistemlerini paralel olarak kontrol eder |
| -R | Kök dosya sistemini hariç tutar (özellikle -A ile birlikte kullanılır) |
| -r | Kontrol edilen her cihaz için istatistik bilgisi sağlar |
| -T | Başlık bilgisini göstermeden çalışır |
| -t | Kontrol edilecek dosya sistemi türlerini belirtir (ör. ext4, xfs) |
| -V | Yapılan işlemleri ayrıntılı olarak açıklar |
“tar” Komutu ile Dizin Yedekleme
Sunucularda verilerin düzenli yedeklenmesi, sistem sürekliliği ve veri güvenliği açısından kritik öneme sahiptir. Linux ortamında bu iş için en çok kullanılan ve güvenilir araçlardan biri tar komutudur. Birden fazla dosya veya dizini tek bir arşiv dosyası içinde toplayarak saklama ve taşımayı kolaylaştırır.
Bir dizini arşivlemek için şu komut kullanılabilir
tar -cvf backup.tar /home
Bu komut, /home dizinindeki tüm dosyaları backup.tar isimli arşive dönüştürür. Daha sonra bu arşivi açmak için
tar -xvf backup.tar
komutu kullanılır. VDS ortamında alınan bu tür yedekler hem lokal saklama hem de farklı sunuculara aktarma için idealdir. Daha büyük ölçekli projelerde ise tar genellikle rsync veya bulut tabanlı yedekleme çözümleriyle birlikte kullanılarak desteklenir.

| Parametre | Açıklama |
|---|---|
| -c | Yeni bir arşiv dosyası oluşturur |
| -x | Arşiv dosyasını açar |
| -f | Arşiv dosyasının adını belirtir |
| -v | İşlem sırasında ayrıntılı bilgi verir |
| -t | Arşivdeki dosyaları listeler |
| -u | Yeni dosya veya dizini mevcut arşive ekler |
| -r | Arşiv içindeki dosya veya dizinleri günceller |
| -z | Gzip sıkıştırmasıyla arşiv oluşturur |
| -j | Bzip2 sıkıştırmasıyla arşiv oluşturur |
| -W | Arşiv dosyasını doğrular |
Dosya İzinleri için “chmod” Komutu Nasıl Kullanılır?
Linux tabanlı bir VDS’de yüzlerce dosya ve dizin bulunur ve bunların doğru izinlerle korunması güvenlik için kritiktir. Hatalı izinler saldırganların içeri sızmasına ya da zararlı yazılımların çalışmasına zemin hazırlayabilir.
Bu tür ihlaller yalnızca anlık veri kaybına yol açmaz, tüm sistemi hizmet veremez hale de getirebilir. Bu yüzden izin yönetimi hem güvenlik katmanının hem de felaket kurtarma planlarının temel bir parçasıdır.
Linux’ta izin modeli üç temel yetkiye dayanır. Okuma, yazma ve çalıştırma. Bu yetkiler farklı biçimlerde birleştirilerek çeşitli izin kombinasyonları ortaya çıkar.
chmod 755 dosya.sh
Komutu, dosya sahibine okuma, yazma ve çalıştırma izni verirken grup ve diğer kullanıcılara yalnızca okuma ve çalıştırma izni tanımlar. Buna karşılık chmod 777, herkesin dosya üzerinde tam yetkiye sahip olmasına yol açar.
İzin değerlerinin mantığını daha iyi anlamak için şu tabloya bakılabiliriz.
| Değer | Açıklama |
|---|---|
| 0 | Hiçbir izin yok |
| 1 | Yalnızca çalıştırma izni |
| 2 | Yalnızca yazma izni |
| 3 | Yazma + çalıştırma izni |
| 4 | Yalnızca okuma izni |
| 5 | Okuma + çalıştırma izni |
| 6 | Okuma + yazma izni |
| 7 | Okuma + yazma + çalıştırma izni |
Linux Servis Yönetimi için “Systemctl”
Linux tabanlı sistemlerde servislerin başlatılması, durdurulması ve durumlarının kontrol edilmesi için en sık kullanılan araç systemctl komutudur.
Örneğin bir servisi yeniden başlatmak için:
systemctl restart nginx
komutu çalıştırılır. Bir servisin mevcut durumunu öğrenmek içinse aşağıdaki komut kullanılır.
systemctl status mysql
Servis yönetimi için kullanılabilecek diğer temel komutlar ise şunlardır:
- Başlatma:
sudo systemctl start <servis-ismi> - Durdurma:
sudo systemctl stop <servis-ismi> - Yeniden başlatma:
sudo systemctl restart <servis-ismi> - Açılışta etkinleştirme:
sudo systemctl enable <servis-ismi> - Açılışta devre dışı bırakma:
sudo systemctl disable <servis-ismi>
Dosya Kopyalamak için “rsync” Komutu Kullanımı
Sunucular arası veri transferinde hız ve güvenilirlik çok önemlidir. İşte bu noktada rsync öne çıkar. Örneğin, bir VDS’ten başka bir yedekleme sunucusuna dosyaları kopyalamak için şu komut kullanılabilir:
rsync -avz /home [email protected]:/backup
Bu komut, /home dizinindeki tüm verileri şifreli bağlantı üzerinden hedef sunucuya senkronize eder. rsync’in en büyük avantajı ise yalnızca değişen dosyaları kopyalaması ve bu sayede zaman ile bant genişliği tasarrufu sağlamasıdır. VDS yöneticileri için düzenli yedekleme süreçlerinde rsync neredeyse vazgeçilmezdir.
Sık Sorulan Sorular
fsck çalıştırınca “device is busy” hatası nasıl düzelir?
Bu hata, kontrol etmek istediğiniz diskin hâlâ kullanımda olduğunu gösterir. Çözüm olarak sistemi tek kullanıcı modunda başlatabilir veya ilgili diski umount ederek sonra fsck çalıştırabilirsiniz.
tar -xvf ile arşiv açarken “permission denied” hatası çıkıyor, sebebi nedir?
Arşivi açmaya çalıştığınız dizinde yazma izniniz yoksa bu hata görülür. Çözüm için ya root kullanıcıya geçin (sudo su) ya da arşivi açmak istediğiniz dizinin izinlerini düzenleyin.
chmod 777 güvenli mi?
777 izinleri dosyayı herkesin okumasına, yazmasına ve çalıştırmasına izin verir. Bu, özellikle web uygulamalarında ciddi güvenlik riski doğurur. Bunun yerine en az yetki prensibiyle (ör. 755 veya 644) çalışın.
systemctl restart nginx çalışmıyor, “failed” nasıl düzeltilir?
Bu durumda genellikle konfigürasyon hataları vardır. Öncelikle nginx -t komutuyla yapılandırma dosyalarını test edin. Hata varsa düzeltmeden servis başlamaz.
rsync ile dosya kopyalarken “connection refused” hatası
Bu hata genellikle hedef sunucuda SSH servisinin çalışmadığını veya firewall’un bağlantıyı engellediğini gösterir. systemctl status ssh ile SSH servisini kontrol edin ve ilgili portun (22) açık olduğundan emin olun.
uptime değerindeki “load average” ne anlama gelir?
uptime çıktısında yer alan 1, 5 ve 15 dakikalık load average değerleri, CPU yoğunluğunu gösterir. Örneğin 2.0 değeri, çift çekirdekli bir sistemde %100 kullanım anlamına gelir.