manpageของnetstat
มีคำอธิบายสั้น ๆ ของแต่ละรัฐ:
ESTABLISHED
The socket has an established connection.
SYN_SENT
The socket is actively attempting to establish a connection.
SYN_RECV
A connection request has been received from the network.
FIN_WAIT1
The socket is closed, and the connection is shutting down.
FIN_WAIT2
Connection is closed, and the socket is waiting for a shutdown
from the remote end.
TIME_WAIT
The socket is waiting after close to handle packets still in the
network.
CLOSE The socket is not being used.
CLOSE_WAIT
The remote end has shut down, waiting for the socket to close.
LAST_ACK
The remote end has shut down, and the socket is closed. Waiting
for acknowledgement.
LISTEN The socket is listening for incoming connections. Such sockets
are not included in the output unless you specify the
--listening (-l) or --all (-a) option.
CLOSING
Both sockets are shut down but we still don't have all our data
sent.
UNKNOWN
The state of the socket is unknown.
คุณสามารถใช้แผนภาพการเปลี่ยนแปลงรัฐ (ตัวอย่างที่นี่ , ที่นี่และที่นี่ ) เพื่อให้ความรู้สึกที่ดีขึ้นของสหรัฐฯ
พิจารณาสองโปรแกรมที่พยายามเชื่อมต่อซ็อกเก็ต (เรียกใช้a
และb
) ทั้งตั้งค่าซ็อกเก็ตและเปลี่ยนเป็นLISTEN
สถานะ จากนั้นหนึ่งโปรแกรม (พูดa
) พยายามเชื่อมต่อกับอีกโปรแกรมหนึ่ง( b
) a
ส่งคำขอและเข้าสู่SYN_SENT
รัฐและb
ได้รับคำขอและเข้าสู่SYN_RECV
รัฐ เมื่อb
รับทราบคำขอพวกเขาจะเข้าสู่ESTABLISHED
รัฐและทำธุรกิจของพวกเขา ตอนนี้มีสองสิ่งที่สามารถเกิดขึ้นได้:
a
FIN_WAIT1
มีความประสงค์ที่จะปิดการเชื่อมต่อและเข้าสู่ b
ได้รับFIN
การร้องขอส่งACK
(แล้วa
เข้าFIN_WAIT2
) เข้ามาCLOSE_WAIT
บอกว่ามันกำลังจะปิดลงและเข้าสู่a
LAST_ACK
เมื่อa
ยอมรับนี้ (และเข้าTIME_WAIT
) เข้าสู่b
รอนิดเพื่อดูว่า anythings ที่เหลือจากนั้นจะเข้าสู่CLOSE
a
CLOSE
a
และb
เสร็จสิ้นธุรกิจและตัดสินใจที่จะปิดการเชื่อมต่อ (ปิดพร้อมกัน) เมื่อa
อยู่ในFIN_WAIT
และแทนที่จะได้รับACK
จากb
มันได้รับFIN
(ตามb
ความปรารถนาที่จะปิดมันเช่นกัน) เข้าสู่a
CLOSING
แต่ยังมีข้อความที่จะส่ง ( ACK
ที่a
ควรจะได้รับสำหรับต้นฉบับFIN
) และเมื่อสิ่งนี้ACK
มาถึงa
เข้าสู่TIME_WAIT
ตามปกติ