Snitch – เครื่องมือ ss/netstat ที่ใช้งานคุ้นมือกว่า
(github.com/karol-broda)- Snitch เป็น เครื่องมือตรวจสอบการเชื่อมต่อเครือข่ายที่มนุษย์อ่านได้ง่ายกว่า
ssหรือnetstatแบบเดิม โดยรองรับทั้งเทอร์มินัล UI (TUI) และตารางที่จัดรูปแบบอย่างสวยงาม - แสดงสถานะการเชื่อมต่อได้ทั้งแบบ หน้าจอโต้ตอบแบบเรียลไทม์ หรือ ตารางที่แสดงผลครั้งเดียวจบ พร้อมตัวกรองหลากหลาย เช่น TCP/UDP, listening, established
- มีฟีเจอร์ ส่งออก JSON·CSV, แปลชื่อ DNS/ชื่อบริการ, เฝ้าดูและยุติโปรเซส, และ อัปเดตอัตโนมัติ
- รองรับวิธีติดตั้งหลายแบบ เช่น Homebrew, Go, Nix, Arch Linux, Shell Script, Binary และมีความสามารถ ปลดคำเตือน Gatekeeper ของ macOS อัตโนมัติ
- เป็นเครื่องมือที่มีประโยชน์สำหรับนักพัฒนาและผู้ดูแลระบบในการ มอนิเตอร์การเชื่อมต่อเครือข่ายอย่างเข้าใจง่าย และนำไปใช้กับสคริปต์อัตโนมัติ
ภาพรวม
- Snitch เป็นเครื่องมือสำหรับ สำรวจการเชื่อมต่อเครือข่ายในรูปแบบที่มองเห็นได้ชัดเจน โดยออกแบบมาเป็นทางเลือกแทน
ssหรือnetstat - แสดงสถานะการเชื่อมต่อผ่าน อินเทอร์เฟซ TUI หรือ ผลลัพธ์แบบตารางที่จัดสไตล์
- ทำงานบน Linux และ macOS และอาจต้องใช้ สิทธิ์ root หรือสิทธิ์ CAP_NET_ADMIN
วิธีติดตั้ง
- Homebrew: ติดตั้งได้ด้วยคำสั่ง
brew install snitch - Go:
go install github.com/karol-broda/snitch@latest - Nix/NixOS:
nix-env -iA nixpkgs.snitchหรือเพิ่มเป็น flake input - Arch Linux (AUR) :
yay -S snitch-binหรือparu -S snitch-bin - Shell Script: ติดตั้งด้วยคำสั่ง
curl -sSL ... | shโดยพาธเริ่มต้นคือ~/.local/binหรือ/usr/local/bin- บน macOS สคริปต์ติดตั้งจะ ลบ quarantine attribute อัตโนมัติ
- ดาวน์โหลด Binary: มีเวอร์ชันสำหรับ Linux (.tar.gz, .deb, .rpm, .apk) และ macOS (.tar.gz) บน GitHub Releases
เริ่มต้นใช้งานอย่างรวดเร็ว
- รัน
snitchเพื่อเปิด TUI แบบโต้ตอบ snitch -lจะ แสดงเฉพาะ listening sockets, ส่วนsnitch lsจะ แสดงผลเป็นตารางแล้วจบการทำงานsnitch ls -t -eจะ แสดงเฉพาะเซสชัน TCP ที่ established, และsnitch ls -pจะ แสดงผลแบบเรียบง่ายที่พาร์สได้
คำสั่งหลัก
snitch/snitch top: แสดงรายการการเชื่อมต่อที่รีเฟรชแบบเรียลไทม์- ตัวเลือก:
-l(listening),-t(TCP),-e(established),-i(ช่วงเวลารีเฟรช) - ปุ่มลัด:
j/kเลื่อน,t/uสลับ TCP·UDP,Kยุติโปรเซส,/ค้นหา,qออก เป็นต้น
- ตัวเลือก:
snitch ls: แสดงตารางครั้งเดียว และถ้าความสูงเกินหน้าจอเทอร์มินัลจะใช้ pager อัตโนมัติ- รูปแบบผลลัพธ์: ตารางปกติ,
-o json,-o csv,-p(แบบเรียบง่าย),--no-headers(ไม่แสดงหัวตาราง)
- รูปแบบผลลัพธ์: ตารางปกติ,
snitch json: แสดงผลเป็น JSON เพื่อนำไปใช้ในสคริปต์ได้snitch watch: สตรีมเฟรม JSON ตามช่วงเวลาที่กำหนดsnitch upgrade: ตรวจสอบเวอร์ชันและอัปเดตอัตโนมัติ
ตัวกรองและตัวเลือกการแปลชื่อ
- แฟลกร่วม:
-t(TCP),-u(UDP),-l(listening),-e(established),-4(IPv4),-6(IPv6) - การแปลชื่อ DNS และชื่อบริการ:
- รองรับตัวเลือก
--resolve-addrs,--resolve-ports,--no-cache - ทำ DNS lookup แบบขนานและแคชผลไว้ โดยสามารถปิดแคชได้ด้วย
--no-cache
- รองรับตัวเลือก
- การกรองแบบละเอียด: ระบุชื่อโปรเซส พอร์ต สถานะ ฯลฯ ในรูปแบบ
key=value- ตัวอย่าง:
snitch ls proto=tcp state=listen,snitch ls proc=nginx
- ตัวอย่าง:
รูปแบบผลลัพธ์
- ผลลัพธ์ตารางปกติ: แสดงชื่อโปรเซส, PID, โปรโตคอล, สถานะ, ที่อยู่โลคัล·พอร์ต
- ผลลัพธ์แบบเรียบง่าย(-p) : ข้อความที่พาร์สได้
- ผลลัพธ์ JSON/CSV: เหมาะกับงานสคริปต์อัตโนมัติและการวิเคราะห์ล็อก
การตั้งค่าและตัวแปรสภาพแวดล้อม
- ไฟล์ตั้งค่า:
~/.config/snitch/snitch.toml- ตั้งค่า
numeric,dns_cache,theme(auto/dark/light/mono) ได้
- ตั้งค่า
- ตัวแปรสภาพแวดล้อม:
- รองรับ
SNITCH_THEME,SNITCH_RESOLVE,SNITCH_DNS_CACHE,SNITCH_NO_COLOR,SNITCH_CONFIGเป็นต้น
- รองรับ
ความต้องการของระบบ
- ต้องใช้สภาพแวดล้อม Linux หรือ macOS
- Linux: อ่านข้อมูลจาก
/proc/net/*และหากต้องการข้อมูลโปรเซสทั้งหมดจะต้องใช้สิทธิ์ root หรือCAP_NET_ADMIN - macOS: ใช้ system API และหากต้องการข้อมูลโปรเซสทั้งหมดต้องใช้
sudo
1 ความคิดเห็น
ความคิดเห็นจาก Hacker News
ในเอาต์พุตเริ่มต้น
ssแสดงข้อมูลที่ไม่ค่อยจำเป็นอย่างขนาดคิวรับส่ง แต่กลับไม่แสดงว่า socket นั้นเป็นของแอปพลิเคชันอะไรแถมยังละเว้น listening socket โดยค่าเริ่มต้น ทั้งที่นั่นคือสิ่งหลักที่คนใช้เครื่องมือแบบนี้อยากดู
เข้าใจว่าการเลือกค่าเริ่มต้นที่ดีเป็นเรื่องยาก แต่นี่แทบจะเป็นตัวอย่างของการเลือกผิดแทบทุกอย่าง
เมื่อเวลาผ่านไป ผู้ใช้และกรณีการใช้งานก็เปลี่ยนไป ดังนั้นค่าเริ่มต้นก็ควรเปลี่ยนตาม แต่เครื่องมือ Unix มักมีเอาต์พุตที่กลายเป็น API ไปแล้ว พอเปลี่ยนก็เกิด ปัญหา backward compatibility
ตัวอย่างเช่น
ps auxที่ตัดชื่อโปรเซสยาว ๆ เหลือราว 7 ตัวอักษรก็เป็นเพราะเหตุนี้บทความที่เกี่ยวข้อง: sh and the separation of data and representation
ssหรือlsofขึ้นมา ดูเหมือนพวกเขาจะยังไม่ค่อยเข้าใจ ปัญหาด้านการใช้งาน เหล่านี้fd,ag,rgก็เจอปัญหาคล้ายกันผมคิดว่า ความใช้งานได้อย่างเป็นธรรมชาติ สำคัญกว่าความเร็วหรือฟีเจอร์เสียอีก
netstat -utanกับss -utanดูเหมือนจะแสดงข้อมูลแทบจะเหมือนกันชื่อซ้ำกันแบบนี้ อาจจะใช้ชื่ออื่นจะดีกว่า
เว็บไซต์ทางการของ Little Snitch
Snitch เป็นแค่เครื่องมือที่ทำให้ข้อมูลจาก
ss/netstatดูง่ายขึ้นในเทอร์มินัลมีเครื่องมือชื่อคล้ายกันอยู่แล้วในสาย IT แต่ยังจะใช้ชื่อนี้อีกก็ไม่ค่อยเข้าใจ
ลิงก์เดโม
ไลบรารี GUI มักมีฟีเจอร์ต่าง ๆ สำหรับผู้ใช้ที่มีความบกพร่องทางสายตาและอื่น ๆ แต่ TUI อาจจะยังขาดในจุดนี้
ssแล้วเลยใช้งานได้ดีอยู่ เพียงแต่ไม่อยากเห็น ตัวเลขคิวรับส่งมันทำให้ความกว้างหน้าจอมากเกินไปจนแทบวางแบบแบ่งครึ่งแนวตั้งบนโน้ตบุ๊กไม่ได้
ผมคงไม่ติดตั้ง Snitch เพราะ
ssมีติดตั้งมาอยู่แล้วบนทุกเซิร์ฟเวอร์ และก็ไม่ต้องการ TUISnitch อาจจะเหมาะกับ การใช้งานส่วนตัวหรือบนเวิร์กสเตชัน แต่บนเซิร์ฟเวอร์
ssคือค่าเริ่มต้นssที่ติดตั้งมาอยู่แล้วได้เลยSnitch เหมาะกับเวิร์กสเตชันหรือการดีบักใน homelab มากกว่า
ตอนนี้ยังไม่แสดงคิวรับส่ง แต่ภายหลังมีแผนจะเพิ่ม compact mode หรือสวิตช์เปิดปิด
มีฟีเจอร์อะไรที่ผมอาจพลาดไปในวิดีโอเดโมหรือเปล่า?
ฟีเจอร์มอนิเตอร์ทราฟฟิกมีอยู่ในแผน แต่ยังไม่ได้ทำ
น่าแปลกที่ Go อนุญาต
module barenameด้วย สุดท้ายในโปรเจกต์ส่วนตัวก็มักต้องใช้ URL อยู่ดี และผมคิดว่ามันเป็น แพตเทิร์นที่ไม่ค่อยดีลิงก์คอมมิต
@latestก็น่าจะทำงานได้ปกติเช่น ถ้ามัลแวร์ถูกออกแบบให้รอช่วงเวลาหนึ่ง หรือสื่อสารกับ C&C เฉพาะตอนที่ผู้ใช้มีการใช้งานเครือข่ายอยู่ ก็น่าจะตรวจจับได้ยาก
/procตรง ๆเพราะ rootkit แบบ
LD_PRELOADสามารถปลอมผลลัพธ์ของฟังก์ชันใน libc เพื่อซ่อนกิจกรรมได้ssยังพอเชื่อถือได้มากกว่าเล็กน้อย และ Snitch เขียนด้วย Go จึงไม่ได้ใช้ libc ทำให้ อาจทนต่อ rootkit แบบ LD_PRELOAD ได้ดีกว่าอย่างไรก็ตาม เครื่องมือแบบนี้ ไม่ได้มีไว้ตรวจจับทราฟฟิกอันตราย แต่มีไว้สำหรับดีบักบนเครื่องโลคัล
เอกสารอ้างอิง: decloaker, บทความวิจัย arXiv, บทความวิจัย ACM, คำอธิบายโครงสร้าง proc
ผู้โจมตีที่ชำนาญยังไงก็สามารถแฝงตัวไปกับทราฟฟิกปกติได้อยู่ดี
แม้แต่เครื่องมือเครือข่ายที่ใช้รับมือผู้โจมตีจริง ๆ ก็ยังไม่สมบูรณ์แบบ (คำค้น: bro vantage point problem)
ตอนนี้ผมใช้ jnettop อยู่ แต่ไม่ชอบ UI เท่าไร