Linux sistemlerinde ağ güvenliği sağlamak ve trafik kontrolü yapmak için kullanılan güçlü bir araç olan iptables, özellikle sistem yöneticileri ve güvenlik uzmanları için vazgeçilmezdir. Bu yazıda, iptables’ın ne olduğunu, nasıl kullanıldığını ve hangi amaçlar için tercih edildiğini ayrıntılı olarak ele alacağız.

iptables Nedir?

iptables, Linux çekirdeği tarafından sağlanan bir paket filtreleme ve NAT (Ağ Adresi Çevirisi) mekanizmasıdır. Ağ trafiğini kontrol etmek ve güvenlik duvarı kuralları oluşturmak için kullanılan bir araçtır. iptables, kullanıcıların ağ paketlerini analiz etmesine, yönlendirmesine ve gerektiğinde engellemesine olanak tanır.

iptables’ın Kullanım Amacı

iptables, ağ güvenliği sağlamak, trafiği yönlendirmek ve sisteminize gelen ve giden ağ trafiğini kontrol etmek için kullanılır. İşte iptables’ın yaygın kullanım amaçları:

Güvenlik Duvarı Oluşturma

iptables, ağ trafiğini izlemek ve belirli trafiği engellemek veya izin vermek için kullanılır. Bu sayede, yetkisiz erişimleri engelleyerek sistem güvenliğini artırabilirsiniz.

NAT ve Port Yönlendirme

Ağ Adresi Çevirisi (NAT) yaparak, iç ağdaki cihazların internet erişimini sağlamak ve port yönlendirme ile belirli hizmetlere erişimi kolaylaştırmak için iptables kullanılabilir.

Trafik Şekillendirme

Ağ trafiğini belirli kurallara göre şekillendirmek ve yönetmek için iptables kullanılabilir. Bu, ağ trafiğini optimize etmek ve bant genişliğini daha verimli kullanmak için önemli bir araçtır.

Temel Yapı

Bir iptables kuralı genellikle şu temel yapıyı izler:


iptables [OPTIONS] [CHAIN] [CONDITIONS] [TARGET]

OPTIONS: İşlem türünü belirtir (-A, -D, -I, vb.).CHAIN: Hangi zincirin etkileneceğini belirtir (INPUT, OUTPUT, FORWARD, vb.).CONDITIONS: Eşleşme kriterlerini belirtir (-p, -s, --dport, vb.).TARGET: Paketin son işlemi belirlenir (-j ile, örneğin ACCEPT, DROP).

iptables Kurulumu


sudo apt-get install iptables  # Debian/Ubuntu için
sudo yum install iptables      # CentOS/RedHat için

Temel Komutlar

Kurallar Listeleme: Mevcut iptables kurallarını görmek için aşağıdaki komutu kullanabilirsiniz:


sudo iptables -L

Kurallar Ayrıntılı Listeleme: Mevcut iptables kurallarını görmek için aşağıdaki komutu kullanabilirsiniz:


iptables -n -L -v

Tüm Kuralları Silme: Tüm kuralları veya belirtilen zincirdeki kuralları temizler.


iptables -F

Kural Silme: Mevcut bir kuralı silmek için kural numarasını belirleyip aşağıdaki komutu kullanabilirsiniz:


sudo iptables -D INPUT 1

Örnek : 22 Portundan gelen istekleri engellerken, 80 portuna gelen istekleri kabul eder.


sudo iptables -A INPUT -p tcp --dport 22 -j DROP
sudo iptables -A INPUT -p tcp --dport 80 -j ACCEPT

Temel iptables Parametreleri

1. -A (Append)

  • Amaç: Belirtilen zincire (chain) yeni bir kural ekler.

iptables -A INPUT -p tcp --dport 80 -j ACCEPT

Açıklama: Bu komut, INPUT zincirine bir kural ekleyerek, 80 numaralı porta gelen TCP paketlerine izin verir.

2. -D (Delete)

  • Amaç: Belirtilen zincirden bir kuralı siler.

iptables -D INPUT 1

Açıklama: INPUT zincirinden 1 numaralı kuralı siler. Kural numarası iptables -L --line-numbers komutu ile öğrenilebilir.

3. -I (Insert)

  • Amaç: Zincire belirli bir konumda kural ekler.

iptables -I INPUT 1 -p tcp --dport 22 -j DROP

Açıklama: INPUT zincirindeki 1 numaralı kuralı, 80 numaralı porta gelen TCP paketlerine izin veren bir kural ile değiştirir.

4. -p (Protocol)

  • Amaç: Hangi protokolün kullanılacağını belirtir (örneğin, TCP, UDP, ICMP).

iptables -A INPUT -p tcp

Açıklama: TCP protokolüne ait paketler üzerinde işlem yapar.

5. -s (Source)

  • Amaç: Kaynak IP adresini belirtir.

iptables -A INPUT -s 192.168.1.100

Açıklama: 192.168.1.100 IP adresinden gelen paketleri hedef alır.

Kategori: