Giriş
TCP three-way Handshake şöyledir. TCP'yi kapatırken four-way termination uygulanır.
Eğer iki paket gönderseydik yani şöyle olsaydı
TCP three-way Handshake şöyledir. TCP'yi kapatırken four-way termination uygulanır.
Client ------SYN-----> Server
Client <---ACK/SYN---- Server
Client ------ACK-----> Server
3 tane paket göndermenin amacı her iki tarafın da birbirlerinin Sequence Number değerlerini bilmeleridir. Bu da 3 tane paket göndermekle olur.Alice ---> Bob SYNchronize with my Initial Sequence Number of X
Alice <--- Bob I received your syn, I ACKnowledge that I am ready for [X+1]
Alice <--- Bob SYNchronize with my Initial Sequence Number of Y
Alice ---> Bob I received your syn, I ACKnowledge that I am ready for [Y+1]
Dolayısıyla yukarıdaki 3 paket şöyle de okunabilir.Alice ---> Bob SYN
Alice <--- Bob ACK SYN
Alice ---> Bob ACK
Neden 2 Paket Yetmiyor ?Eğer iki paket gönderseydik yani şöyle olsaydı
Client ------SYN-----> Server
Client <-----ACK------ Server
Sadece server client'in Sequence Numarasını bilecekti. Server ACK almadığı için Client'ın kendi Sequence Numarasını bilip bilmediğinden emin olamayacaktı.SYN Flood Saldırısı
İstemci sadece SYN paketini gönderir. Kaynak adres olarak rastgele bir değer kullanılır. Açıklaması şöyle.
A client opens a TCP connection by sending a SYN packet to a server. The server replies with a single SYN+ACK, and the client responds again with an ACK. Because of natural network latency, the server may wait a short time after sending SYN+ACK to the specified source address for an ACK reply, and this behavior is what a SYN flood exploits. Because the source address was spoofed, the reply will never come. If the server is waiting on enough fake connections that will never be completed, it will become unable to open any new connections, legitimate or not. This condition is called denial of service.Handshake Sonrası İstemcinin Gönderdiği İlk Veri
SYN flood attacks do not require the attacker receive a reply from the victim, so there is no need for the attacker to use its real source address. Spoofing the source address both improves anonymity by making it harder to track down the attacker, as well as making it more difficult for the victim to filter traffic based on IP. After all, if each packet used the same source address (whether spoofed or not), any decent firewall would quickly begin blocking all SYN packets from that address and the attack would fail.
Şöyle olabilir. İlginç bir şekilde istemci ACK için kullandığı bilgiyi 4. satırdaki veri paketi için de kullanabilir.
#1 SN 0 -----> SERVER:80 -- SYN
#2 <----- SERVER:80 SN 0, AN 1 -- SYN ACK
#3 SN 1 AN 1 -----> SERVER:80 -- ACK
#4 SN 1 AN 1 -----> SERVER:80 -- PSH ACK(HTTP GET)
KodlamaTCP Alanları10.0.0.1:1234 - 192.168.1.1:80
10.0.0.2:5678 - 192.168.1.1:80
Şimdi TCP zarfındaki bu alanlara bakalım.
1. Sequence Number
Sequence Number ve Acknowledgement Number rastgele sayılardan başlarlar. Sequence ve Acknowledgement numaraları duplication ve reordering problemlerini çözmeye yararlar. Aynı sequence sayısına sahip iki paket gelirse, sonradan gelen dikkate alınmaz.
2. RST (Reset) Flag
Karşı tarafa bağlantının kapalı olduğunu belirtmek için gönderilir. Açıklaması şöyle
The RST is in response to receiving something on a connection that no longer exists. The connection was closed by FIN, and it was acknowledged, so the connection no longer exists, and then something was received on the closed connection, so a RST was sent.3. SYN Flag
Bağlantı kurarken, bağlantıyı başlatan taraf gönderir. Bağlantı kabul edilmezse karşı taraf RST (reset) gönderir.
4. Maximum Segment Size (MSS)
MSS iki taraf arasındaki bağlantıda, bir IP paketine sığdırılabilecek en büyük TCP paketi anlamına gelir. MSS sadece TCP'de vardır. UDP'de yoktur. Açıklaması şöyle.
.. and then there's TCP MSS, which helps in case of TCP, but of course not with UDP nor ICMP.
Using the MSS field in the TCP header (only in the SYN and SYN-ACK packets of the initial 3-way handshake), hosts can signal to their peers how large a TCP payload is acceptable to receive.
TCP MSS negotiation can be a blessing, but also a nuisance, as it helps to hide MTU problems until something with large UDP packets comes along and fails at the "all hosts on the common L2 segment need to use the same MTU" criterium
Her iki taraf ta MSS değerini Bildirir ve Küçük Olanı Kullanılır
Açıklaması şöyle
both hosts announce the MSS independently in the SYN and the SYN/ACK packets and the smaller of the two is chosen for all segments exchanged during the entire duration of the connection.
Otomatik MSS Hesaplama
Dynamic Path MTU Discovery özelliği etkinse, IP seviyesinde en büyük MTU değeri biliniyor demektir. MSS bu MTU değeri kullanılarak hesaplanır.
Örnek
Örneğin Maximum Transmission Unit 1500 byte kabul edilirse, 20 byte IP ve 20 byte TCP zarflaması çıkarılırsa MSS 1460 byte olur.
Örneğin Maximum Transmission Unit 1500 byte kabul edilirse, 20 byte IP ve 20 byte TCP zarflaması çıkarılırsa MSS 1460 byte olur.
MSS = 1500 - 20 - 20
MSS = 1460 bytes of TCP data
Kendi arayüzlerimizin MTU değerlerini öğrenmek için şöyle yaparız
MSS Değerini Kodla Atamak
Şöyle yaparız
int mss = 1200; // Desired MSS value// Set MSS for the socketif (setsockopt(sockfd, IPPROTO_TCP, TCP_MAXSEG, &mss, sizeof(mss)) < 0) {perror("Setting MSS failed");close(sockfd);return 1;}
Kodla Atanırsa MSS Her Zaman MTU'da Küçük Olmalı
Açıklaması şöyle. MSS değeri MTU'dan küçük olmalı. Eğer MTU'dan büyük TCP paketleri kullanılırsak çok fazla fragmentation olur ve verim düşer.TCP itself uses the MSS to determine the segment size, which should fit the MTU, but I have seen people do stupid things like set the MSS to much larger than the MTU (thinking it will increase the speed, but the effect is the opposite). That forces IP to create fragments prior to sending.
MSS Olarak 1460
Açıklaması şöyle. 1460 eskidendi artık bu değer 1448 oldu
The value 1460 was only common in the late 20th century because Ethernet was common, Ethernet frames have a standard 1500 byte payload capacity (which becomes the IP MTU), and IP and TCP headers were both 20 bytes long in those days. However, around the turn of the 21st century, networks had gotten fast enough that TCP needed to add the 12-byte TCP Timestamp option to protect against wrapped TCP sequence numbers, so typical TCP headers are 32 bytes long now, resulting in a typical 1448 byte TCP MSS on a standard 1500 byte MTU Ethernet network.
Diğer MSS Değerleri
Açıklaması şöyle
On networks with higher path MTUs than 1500 (example: data center networks that use nonstandard 6k or 9k jumbo Ethernet frames), the MSS will be larger. On networks with lower path MTUs than 1500 (example: PPPoE, common on DSL, has 8 additional bytes of overhead for an MTU of 1492), the MSS will be lower.
En Büyük MSS Değeri
Açıklaması şöyle. IP zarfındaki alanını alabileceği en büyük değer 65,535.
The Total Length field in the IP header is 16 bit and thus an IP packet (and therefore TCP packet) can not be larger than 65535 bytes. The TCP payload is actually even smaller since you have to subtract the TCP header from maximum packet size of the IP packet.
IP zarfındaki bu değer kullanılan TCP zarfına göre biraz daha küçülüp
65,495 - 40 byte daha küçük
veya
65,483 - 52 byte daha küçük olabiliyor. Açıklaması şöyle
IPv4's max datagram size (the largest MTU it can fill up) is 2^16 bytes (i.e. 64KiB or 65535 bytes). So the max TCP MSS by today's standards is 65,483 bytes with TCP timestamps on, or 65,495 with them disabled.
El sıkışma esnasında veri taşınmaz. Amaç sadece session açmaktır.
SYN ve FIN bayrakları aynı anda kaldırılamaz. Hem bağlantıyı açmak hem de kapatmak istiyorum anlamına gelir.
şeklinde bir şey görüyorsak birisi bağlandıktan sonra bağlantıyı kapatmış anlamına gelir. Portlarımızı tarayan bir program olabilir.
(A to B)SYN
(B to A)ACK+SYN
(A to B) ACK (Ungraceful connection closure)
Hiç yorum yok:
Yorum Gönder