Special Report

บทความชุดนี้เป็นบทความเชิงเทคนิคอย่างง่าย เพื่อปูพื้นฐานทุกท่านให้เข้าใจถึงปัญหาที่โลกอินเทอร์เน็ตกำลังประสบ, ผลกระทบที่เราจะพบ, และการเปลี่ยนผ่านไปยังเทคโนโลยีใหม่ ถ้าใครยังไม่ได้อ่านตอนแรกแนะนำให้กลับไปอ่านก่อนครับ

รู้จักกับ NAT

ทุกวันนี้ถ้าใครสังเกตอาจจะพบว่าคอมพิวเตอร์ที่เราใช้งานอยู่มักได้หมายเลขไอพีคล้ายๆ กันไม่ว่าทำงานอยู่ที่ไหน โดยมักเป็นหมายเลข 192.168.xxx.xxx หรือ 10.xxx.xxx.xxx หมายเลขเหล่านี้เป็นหมายเลขที่ถูกกำหนดไว้ล่วงหน้าว่าหน่วยงานใดๆ สามารถใช้เป็นการภายในได้โดยไม่ต้องกำหนดหมายเลขล่วงหน้า แต่เนื่องจากหน่วยงานต่างๆ สามารถใช้หมายเลขเหล่านี้ซ้ำไปมาได้อย่างอิสระ การเชื่อมต่อระหว่างหน่วยงานงานจำเป็นต้องมีหมายเลขไอพีที่ได้รับการจัดสรร เพื่อให้เป็นหมายเลขอ้างอิงข้ามเครือข่ายอินเทอร์เน็ตได้

ในโลกอินเทอร์เน็ตนั้นนอกจากจะมีหมายเลขไอพีที่เปรียบเสมือนที่อยู่ของเราบนอินเทอร์เน็ตแล้ว เครื่องทุกเครื่องยังมีพอร์ตเพื่อแยกข้อมูลที่แอพพลิเคชั่นต่างๆ รับส่งออกจากกัน เปรียบเสมือนเราใส่ชื่อในการจ่าหน้าซองหมาย ที่แม้จะมีผู้รับหลายคนในที่อยู่เดียวกันก็ยังคงสามารถส่งข้อมูลไปถึงปลายทางได้ โดยแต่ละหมายเลขไอพีจะมีพอร์ตได้ถึง 65535 พอร์ต

ระบบ Network Address Translation หรือ NAT อาศัยจำนวนพอร์ตสำหรับแต่ละไอพีที่มีอยู่จำนวนมาก มาแจกจ่ายให้แต่ละไอพี ทำได้โลกภายนอกสามารถติดต่อกับเครื่องจำนวนมากในเครือข่ายได้โดยอาศัยหมายเลขไอพีเดียวกัน เปรียบเสมือนระบบไปรษณีย์ภายในคอนโด ที่หากเจ้าหน้าที่คอนโดสามารถจำได้ว่าใครอาศัยอยู่ในห้องไหนบ้าง คนภายนอกก็จะสามารถติดต่อกับคนที่อาศัยอยู่ในคอนโดนั้นได้โดยไม่ต้องระบุหมายเลขห้อง เพียงแค่ระบุชื่อให้ถูกต้องเจ้าหน้าที่ก็จะนำจดหมายไปส่งให้เอง

ผังการทำงาน NAT

ระบบ NAT มีข้อจำกัดสำคัญคือมันถูกออกแบบมาเพื่อให้เครื่องที่อยู่ภายในองค์กร เปิดการเชื่อมต่อไปยังเครื่องที่อยู่ภายนอก โดยเมื่อมีการขอเปิดการเชื่อมต่อครั้งแรก เราท์เตอร์ที่รองรับ NAT จะให้หมายเลขพอร์ตจากไอพีที่ได้รับการจัดสรรมา แล้วใช้หมายเลขไอพีและพอร์ตนั้นๆ แม้จะมีความพยายามในการแก้ปัญหาเพื่อให้หมายเลขไอพีภายในสามารถเปิดรับข้อมูลจากภายนอกโดยไม่ต้องเปิดการเชื่อมต่อไปก่อนได้บ้าง แต่ก็ไม่สมบูรณ์นัก โดยเฉพาะเมื่อเครื่องทั้งสองด้านเป็นเครื่องที่อยู่หลัง NAT ทั้งคู่

ผลกระทบหลังจาก IPv4 หมดโลก

ทุกวันนี้เมื่อเราเชื่อมต่อเข้ากับผู้ให้บริการอินเทอร์เน็ต เรามักได้รับหมายเลขไอพีเป็นหมายเลขไอพีที่ได้รับการจัดสรรมา (บางคนเรียกว่า "ไอพีจริง") แต่เนื่องจากหมายเลขไอพีเหล่านี้หมดลง ผู้ให้บริการไม่สามารถขอจัดสรรหมายเลขไอพีเหลา่นี้เพิ่มเติมได้ ขณะที่หน่วยงานหลายแห่งต้องการเปิดให้บริการที่ต้องรับการเชื่อมต่อจากทุกคนได้ (เช่นเว็บเซิร์ฟเวอร์ของ Blognone) ทำให้บริการเหล่านี้ต้องการหมายเลขไอพีที่ได้รับการจัดสรร ค่าขอหมายเลขจะเพิ่มขึ้นตามลำดับเวลา ขณะที่การเติบโตของผู้ใช้อินเทอร์เน็ตตามบ้านเพิ่มขึ้นอย่างต่อเนื่อง ผู้ให้บริการอินเทอร์เน็ตจะไม่มีทางเลือกอื่นนอกจากหยุดให้หมายเลขไอพีที่ได้รับการจัดสรรมานี้กับผู้ใช้ตามบ้าน แล้วให้หมายเลขไอพีภายในที่เชื่อมต่อ

ทุกวันนี้เองหน่วยงานที่เคยได้รับหมายเลขไอพีจำนวนมากและเคยคิดว่ามากเกินพอ เช่น ม. เกษตรศาสตร์ที่ได้รับมาถึง 65535 หมายเลขนั้นก็เริ่มประสบปัญหาหมายเลขไอพีไม่พอ และต้องจ่ายหมายเลขไอพีภายในให้กับผู้ใช้งานบางส่วน

การใช้งานอินเทอร์เน็ต "ทั่วๆ ไป" ที่เราใช้งานกันเช่นเข้าเว็บ หรือเช็คอีเมลนั้นจะสามารถใช้งานต่อไปได้อีกยาวนานอย่างไร้ปัญหา แต่การใช้ไอพีภายในเป็นวงกว้างนั้นทำให้หลายครั้งที่เราเชื่อมต่อผ่านเราท์เตอร์ จะกลายเป็นเรากำลังอยู่ภายใต้หมายเลขไอพีภายในซ้อนกันหลายชั้น

แม้การทำ NAT ซ้อนกันหลายชั้นไม่สร้างปัญหาการเชื่อมต่อเข้ากับบริการที่มีหมายเลขไอพีที่ได้รับจัดสรรมาแต่อย่างใด โดยอาจจะมีปัญหาเรื่องความเร็วไปบ้าง แต่อุปกรณ์เครือข่ายรุ่นใหม่ๆ ก็ประมวลผล NAT ได้เร็วขึ้นมาก แต่ปัญหาที่สำคัญคือการเชื่อมต่อตรงระหว่างเครื่องต่างๆ ในอินเทอร์เน็ต โดยเครื่องที่อยู่ภายใต้ระบบ NAT ที่ซับซ้อนมีโอกาสจะมีปัญหาไม่สามารถเชื่อมต่อถึงกันโดยตรงได้สูงมาก โดยงานวิจัยในหมวดการส่งข้อมูลถึงกันโดยตรงหรือ NAT Transversal ยังเป็นหัวข้อที่มีการวิจัยอย่างต่อเนื่องจนถึงปัจจุบัน โดยมีมาตรฐานบางอันได้รับความนิยมขึ้นมาบ้างเช่น UPnP ที่เราท์เตอร์ตามบ้านมักรองรับเป็นอย่างดี แต่ก็ไม่มีการรับรองใดๆ ว่ามันจะทำงานได้ในเครือข่ายที่มีการทำ NAT ซ้อนกันไปมาหลายชั้น

ปัญหาสำคัญของการไม่สามารถส่งข้อมูลถึงกันโดยตรงได้เช่นนี้ จะสร้างปัญหาให้กับแอพพลิเคชั่นบางประเภทเช่น VoIP ที่ปรกติแล้วเซิร์ฟเวอร์ทำหน้าที่เพียง "นัดหมาย" คู่สายสองข้างให้เชื่อมต่อกัน แต่หลังจากนั้นทั้งสองข้างจะส่งข้อมูลถึงกันโดยตรง บริการเช่น Skype นั้นอาศัยผู้ใช้ระบบของ Skype เองที่มีหมายเลขไอพีที่ได้รับการจัดสรรมา ให้ทำตัวเป็น Super Node เพื่อส่งข้อมูลให้กับผู้ใช้คนอื่นๆ ของ Skype ที่อยู่ในเครือข่ายหลัง NAT แต่เมื่อเครือข่ายจำนวนมากเริ่มเป็น NAT มาขึ้นเรื่อยๆ เครื่องที่จะทำหน้าที่ Super Node นั้นก็จะหาได้ยากขึ้นเรื่อยๆ เพิ่มค่าใช้จ่ายให้กับบริษัทเช่น Skype ที่จะต้องหาเครื่องมาวางเพื่อทำหน้าที่ส่งต่อข้อมูลโดยตรง

บริการอีกอย่างหนึ่งที่มีปัญหาคือ BitTorrent ที่ต้องการการเชื่อมต่อโดยตรงระหว่างเครื่องในเครือข่าย โดย BitTorrent นั้นอาศัยการ "ประกาศ" ที่อยู่และหมายเลขพอร์ตสำหรับรับการเชื่อมต่อจากเครื่องอื่นๆ ในเครือข่าย หากคอมพิวเตอร์ในเครือข่ายไม่สามารถกำหนดพอร์ตเพื่อรอการเชื่อมต่อขาเข้าได้แล้ว การสร้างเครือข่ายเพื่อแชร์ไฟล์ระหว่างกันก็จะทำไม่ได้

ตอนต่อไป ผมจะพูดถึง IPv6 ปัญหาระหว่างการเปลี่ยนผ่าน และฟีเจอร์ที่เราจะได้รับ

Hiring! บริษัทที่น่าสนใจ

CP AXTRA Public Company Limited - Lotus's company cover
CP AXTRA Public Company Limited - Lotus's
CP AXTRA Lotus's is revolutionizing the retail industry as a Retail Tech company.
Token X company cover
Token X
Blockchain, ICO, Tokenization, Digital Assets, and Financial Service
Carmen Software company cover
Carmen Software
Hotel Financial Solutions
Next Innovation (Thailand) Co., Ltd. company cover
Next Innovation (Thailand) Co., Ltd.
We are web design with consulting & engineering services driven the future stronger and flexibility.
United Information Highway Co., Ltd. company cover
United Information Highway Co., Ltd.
UIH is Thailand’s leading Digital Infrastructure and Solution Provider for Business
KKP Dime company cover
KKP Dime
KKP Dime บริษัทในเครือเกียรตินาคินภัทร
Kiatnakin Phatra Financial Group company cover
Kiatnakin Phatra Financial Group
Financial Service
Fastwork Technologies company cover
Fastwork Technologies
Fastwork.co เว็บไซต์ที่รวบรวม ฟรีแลนซ์ มืออาชีพจากหลากหลายสายงานไว้ในที่เดียวกัน
Thoughtworks Thailand company cover
Thoughtworks Thailand
Thoughtworks เป็นบริษัทที่ปรึกษาด้านเทคโนโยลีระดับโลกที่คว้า Great Place to Work 3 ปีซ้อน
Iron Software company cover
Iron Software
Iron Software is an American company providing a suite of .NET libraries by engineer for engineers.
CLEVERSE company cover
CLEVERSE
Cleverse is a Venture Builder. Our team builds several tech companies.
Nipa Cloud company cover
Nipa Cloud
#1 OpenStack cloud provider in Thailand with our own data center and software platform.
CDG GROUP company cover
CDG GROUP
Provider of IT solutions to public, state, and private sectors in Thailand for over 56 years
Bangmod Enterprise company cover
Bangmod Enterprise
The leader in Cloud Server and Hosting in Thailand.
CIMB THAI Bank company cover
CIMB THAI Bank
MOVING FORWARD WITH YOU - CIMB is the leading ASEAN Bank
Bangkok Bank company cover
Bangkok Bank
Bangkok Bank is one of Southeast Asia's largest regional banks, a market leader in business banking
Gofive company cover
Gofive
“We create world-class software experience”
KBTG - KASIKORN Business-Technology Group company cover
KBTG - KASIKORN Business-Technology Group
KBTG - "The Technology Company for Digital Business Innovation"
Siam Commercial Bank Public Company Limited company cover
Siam Commercial Bank Public Company Limited
"Let's start a brighter career future together"
Icon Framework co.,Ltd. company cover
Icon Framework co.,Ltd.
Global Standard Platform for Real Estate แพลตฟอร์มสำหรับธุรกิจอสังหาริมทรัพย์ครบวงจร มาตรฐานระดับโลก
REFINITIV company cover
REFINITIV
The Financial and Risk business of Thomson Reuters is now Refinitiv
H LAB company cover
H LAB
Re-engineering healthcare systems through intelligent platforms and system design.
LTMH TECH company cover
LTMH TECH
LTMH TECH มุ่งเน้นการพัฒนาผลิตภัณฑ์ที่สามารถช่วยพันธมิตรของเราให้บรรลุเป้าหมาย
Seven Peaks company cover
Seven Peaks
We Drive Digital Transformation
Wisesight (Thailand) Co., Ltd. company cover
Wisesight (Thailand) Co., Ltd.
The Best Choice For Handling Social Media · High Expertise in Social Data · Most Advanced and Secure
MOLOG Tech company cover
MOLOG Tech
We are Modern Logistic Platform, Specialize in WMS, OMS and TMS.
Data Wow Co.,Ltd company cover
Data Wow Co.,Ltd
We enable our clients to realize increased productivity by solving their most complex issues by Data
LINE Company Thailand company cover
LINE Company Thailand
LINE, the world's hottest mobile messaging platform, offers free text and voice messaging + Call
LINE MAN Wongnai company cover
LINE MAN Wongnai
Join our journey to becoming No.1 food platform in Thailand

"เดือดร้อนกันถ้วนหน้า" นะครับผมว่า ฮ่าๆ

ถ้ามัน NAT กันหลายชั้น มันจะมีปัญหากับพวก VPN อย่าง PPTP หรือเปล่าหว่า
เหมือนว่า VPN ค่อนข้างมีปัญหากับ NAT

ทั้ง PPTP, L2TP ต้องการ อุปกรณ์ NAT ที่ support protocol ดังกล่าวโดยเฉพาะถึงจะใช้ได้หลาย session พร้อมกัน ครับ ไม่งั้นสามารถใช้ได้แค่ 1 session ถ้าเกิน มันจะเอ๋อ

jane Sat, 02/05/2011 - 05:47

application ที่ต้องการสื่อสารแบบ peer to peer ใหม่ๆ บนมือถือจะเกิดขึ้นอีกมากมาย

ขอแสดงความคิดเห็น เกี่ยวกับการเปรียบเทียบ กับ เลขที่ห้องของคอนโด

ผมไม่รู้ว่าที่อื่นเป็นแบบไหนแต่น่าจะเป็นแบบเดียวกัน แต่คอนโดมีบ้านเลขที่ ที่เหมือนบ้านทั่วไป
ที่ตู้ไปรษณีย์คอนโดผมก็เป็น บ้านเลขที่ ซึ่งถ้าเทียบกับสารบบ บ้านเลขที่ของประเทศไทย กับระบบ
ip คอนโดผมก็น่าจะเรียกได้ว่า มี ip จริง

แต่ที่สังเกตคือ คอนโดผม จะใช้ เลขทับ แยกย่อยลงไปจากเลขที่ เช่น ห้อง 88/51 กับ 88/52
เป็นห้องอยู่ถัดๆกัน (ซึ่งจะมองว่า หลังทับเทียบเป็นเลข port ก็พอได้ แต่ระบบนี้น่าจะใช้กับ
บ้านทั่วไปอื่นๆ ได้ด้วยในระบบบ้านเลขที่ของไทย )

กรณีนี้ถ้าเป็นหอพักอาจจะชัดเจนกว่า

ความเห็นอื่น ๆ ครับ

ในมุมมองผู้พัฒนาโปรแกรม การมี NAT ทำให้ผู้พัฒนาโปรแกรมมีความยุ่งยากมากขึ้นและถือเป็น
"ของจริง" สำหรับการทำ network application ที่ต้องจำเป็นในการ กระจายไปสู้ผู้ใช้ รายย่อย
อย่างแท้จริง
สมัยผมเรียนที่มหาวิทยาลัย (นานมาแล้วไม่รุ้ตอนนี้สอนหรือยัง) หรือแม้แต่หนังสือที่สอนกันทั่วไปต่าง ๆ network programming ที่เรียนมักจะเป็นแบบที่ใช้ ip เอาเข้าจริงถ้าจำเป็นต้องเขียน application ติดต่อกันระหว่างเครื่อง
หลัง NAT เรื่องมันก็ไม่ง่ายเหมือนที่ได้เรียนมา

ชักจะอยากรู้มุมมองของผู้เชี่ยวชาญ ด้าน network ว่าอนาคต โอกาสที่เครื่องจะได้ใช้ ip จริง จะมีมากกว่าเดิมไหม
( ip จริงกันเป็นปกติ )

โหลดอะได้ครับ กรณีเป็น Leacher อะนะ
แต่ถ้าเราเป็น Seeder จะปล่อยไฟล์ให้คนอื่นลำบากครับ เพราะคนอื่นเริ่มการเชื่อมต่อเข้ามาหาเราไม่ได้
ไม่เหมือนกรณีที่เราเป็นคนโหลดไฟล์ที่เราต้องเริ่มเชื่อมต่อไปหาคนอื่นก่อน

กรณีนี้ยังไม่พูดถึงพวก uPnP นะครับ

ยังได้อยู่ แต่ต้อง FW port ไงครับ
uPnP มันเหมือนระบบ auto fw port ให้เฉยๆ

อย่างเกมส์บางๆ เกมส์ เวลาไปวางระบบร้าน net ผมยังต้องตั้ง scripts fw port
ไล่ ไป 7001 - 7099 สำหรับแต่หละเครื่องไว้เลยน่ะ

..

การใช้ uPnP นี่ต้องระวังนะครับ เพราะกิน cpu router สูงพอสมควร อาจทำให้ไม่เสถียรการเปิดอาจทำให้รองรับจำนวนเครื่องได้น้อยลงด้วย และยังไม่รวมเรื่อง security ต่างๆ อีก

saknarak Sun, 02/06/2011 - 23:28

การอธิบาย NAT ผมชอบเปรียบเทียบกับเบอร์โทรภายใน กับเบอร์โทรจริง

ทุกองค์กรมีโทรตู้สาขา ที่สามารถกำหนดหมายเลขภายในอย่างไรก็ได้ ไปซ้ำกับองค์กรอื่นก็ได้
เวลาคนใน โทรออกไปเบอร์ข้างนอก คนข้างนอกจะเห็นเป็นเบอร์จริง ไม่ใช่เบอร์ภายใน
จึงไม่สามารถโทรกลับได้ คือโทรกลับก็ไม่รู้เบอร์ต่อภายใน

เครื่องที่อยู่หลัง NAT จึงติดต่อโลกภายนอกได้ แต่โลกภายนอกติดต่อเครื่องที่อยู่หลัง NAT ไม่ได้ ถ้าไม่รู้เบอร์ต่อภายใน
การรู้เบอร์ต่อภายใน ก็เหมือนกับการทำ Port Forwarding ให้โลกภายนอกสามารถติดต่อเครื่องภายในได้โดยตรง
แต่ข้อจำกัดอยู่ที่เบอร์ต่อซ้ำกันไม่ได้ เช่น port 80 จองไว้ให้เครื่อง 1 แล้ว จะใช้ 80 สำหรับเครื่อง2 ไม่ได้อีก

พออ่านรู้เรื่องไหมครับ

nununu Tue, 02/08/2011 - 11:37

แล้วการใช้ NAT ซ้อนกันหลายๆครั้ง
มีผลทำให้ ping ในเกมออนไลน์สูงขึ้นด้วยไหมครับ?

เขียนมาเยอะๆเลยนะครับ ชอบอ่าน
เหมือนกับว่าที่เคยเรียนมาจะไม่มี(อาจจะมีแต่ไม่รู้ตัว)
หรือไม่ละเอียดและทันสมัยเท่านี้
ได้ทบทวนตัวเองไปด้วย อิอิ

Apple
public://topics-images/apple_webp.png
SCB10X
public://topics-images/347823389_774095087711602_515970870797767330_n_webp.png
Windows 11
public://topics-images/hero-bloom-logo.jpg
Doom
public://topics-images/doom_logo.png
Huawei
public://topics-images/huawei_standard_logo.svg_.png
Threads
public://topics-images/threads-app-logo.svg_.png
Google Keep
public://topics-images/google_keep_2020_logo.svg_.png
Fortnite
public://topics-images/fortnitelogo.svg_.png
Instagram
public://topics-images/instagram_logo_2022.svg_.png
SCB
public://topics-images/9crhwyxv_400x400.jpg
Microsoft
public://topics-images/microsoft_logo.svg_.png
Basecamp
public://topics-images/bwpepdi0_400x400.jpg
Tinder
public://topics-images/hwizi8ny_400x400.jpg
FTC
public://topics-images/seal_of_the_united_states_federal_trade_commission.svg_.png
Pinterest
public://topics-images/pinterest.png
Palantir
public://topics-images/-nzsuc6w_400x400.png
Gemini
public://topics-images/google_gemini_logo.svg__0.png
AIS Business
public://topics-images/logo-business-2021-1.png
PostgreSQL
public://topics-images/images.png
JetBrains
public://topics-images/icx8y2ta_400x400.png
Krungthai
public://topics-images/aam1jxs6_400x400.jpg
Palworld
public://topics-images/mccyhcqf_400x400.jpg
Bill Gates
public://topics-images/bill_gates-september_2024.jpg
VMware
public://topics-images/1nj4i1gp_400x400.jpg
Take-Two Interactive
public://topics-images/0khle7nh_400x400.jpg
OpenAI
public://topics-images/ztsar0jw_400x400.jpg
Thailand
public://topics-images/flag_of_thailand.svg_.png
NVIDIA
public://topics-images/srvczsfq_400x400.jpg
ServiceNow
public://topics-images/ytnrfphe_400x400.png
PS5
public://topics-images/playstation_5_logo_and_wordmark.svg_.png
Klarna
public://topics-images/urcllpjp_400x400.png
Google Play
public://topics-images/play.png
Drupal
public://topics-images/drupal.png
Virtua Fighter
public://topics-images/virtua_figther_2024_logo.png
Paradox Interactive
public://topics-images/paradox_interactive_logo.svg_.png
Europa Universalis
public://topics-images/europa-icon.png
Nintendo Switch 2
public://topics-images/mainvisual.png
Cloudflare
public://topics-images/cloudflare_logo.svg_.png
Samsung
public://topics-images/samsung.png
Google
public://topics-images/google_2015_logo.svg_.png
Uber
public://topics-images/uber.png
Microsoft 365
public://topics-images/m365.png
USA
public://topics-images/flag_of_the_united_states.svg_.png
GM
public://topics-images/0pe0po-z_400x400.jpg
Perplexity
public://topics-images/perplex.jpg
Xperia
public://topics-images/xperia.png
iOS 18
public://topics-images/ios-18-num-96x96_2x.png