DCN - ไคลเอนต์เซิร์ฟเวอร์รุ่น
กระบวนการแอปพลิเคชันระยะไกลสองขั้นตอนสามารถสื่อสารได้โดยส่วนใหญ่เป็นแฟชั่นสองแบบ
Peer-to-peer: กระบวนการระยะไกลทั้งสองกำลังดำเนินการในระดับเดียวกันและแลกเปลี่ยนข้อมูลโดยใช้ทรัพยากรที่ใช้ร่วมกัน
Client-Server: กระบวนการระยะไกลหนึ่งทำหน้าที่เป็นไคลเอนต์และร้องขอทรัพยากรบางส่วนจากกระบวนการแอปพลิเคชันอื่นที่ทำหน้าที่เป็นเซิร์ฟเวอร์
ในรูปแบบไคลเอนต์เซิร์ฟเวอร์กระบวนการใด ๆ สามารถทำหน้าที่เป็นเซิร์ฟเวอร์หรือไคลเอนต์ ไม่ใช่ประเภทของเครื่องจักรขนาดของเครื่องหรือพลังในการประมวลผลที่ทำให้เป็นเซิร์ฟเวอร์ เป็นความสามารถในการให้บริการคำขอที่ทำให้เครื่องเป็นเซิร์ฟเวอร์
ระบบสามารถทำหน้าที่เป็นเซิร์ฟเวอร์และไคลเอนต์ได้พร้อมกัน นั่นคือกระบวนการหนึ่งทำหน้าที่เป็นเซิร์ฟเวอร์และอีกกระบวนการหนึ่งทำหน้าที่เป็นไคลเอนต์ สิ่งนี้อาจเกิดขึ้นได้เช่นกันที่ทั้งกระบวนการไคลเอ็นต์และเซิร์ฟเวอร์อยู่ในเครื่องเดียวกัน
การสื่อสาร
สองกระบวนการในรูปแบบไคลเอนต์เซิร์ฟเวอร์สามารถโต้ตอบได้หลายวิธี:
Sockets
การเรียกขั้นตอนระยะไกล (RPC)
ซ็อกเก็ต
ในกระบวนทัศน์นี้กระบวนการที่ทำหน้าที่เป็นเซิร์ฟเวอร์จะเปิดซ็อกเก็ตโดยใช้พอร์ตที่รู้จักกันดี (หรือที่ไคลเอนต์รู้จัก) และรอจนกว่าคำขอของไคลเอ็นต์จะมาถึง กระบวนการที่สองที่ทำหน้าที่เป็นไคลเอนต์จะเปิดซ็อกเก็ต แต่แทนที่จะรอคำขอที่เข้ามาไคลเอนต์จะประมวลผล 'คำขอก่อน'
เมื่อมีการร้องขอไปยังเซิร์ฟเวอร์จะมีการให้บริการ อาจเป็นการแบ่งปันข้อมูลหรือขอทรัพยากร
โทรขั้นตอนระยะไกล
นี่คือกลไกที่กระบวนการหนึ่งโต้ตอบกับอีกกระบวนการหนึ่งโดยการเรียกโพรซีเดอร์ กระบวนการหนึ่ง (ไคลเอนต์) เรียกขั้นตอนที่อยู่บนโฮสต์ระยะไกล กระบวนการบนโฮสต์ระยะไกลกล่าวว่าเป็นเซิร์ฟเวอร์ กระบวนการทั้งสองถูกจัดสรรต้นขั้ว การสื่อสารนี้เกิดขึ้นในลักษณะต่อไปนี้:
กระบวนการไคลเอนต์เรียกไคลเอนต์สตับ มันส่งผ่านพารามิเตอร์ทั้งหมดที่เกี่ยวข้องกับโปรแกรมภายในเครื่อง
จากนั้นพารามิเตอร์ทั้งหมดจะถูกบรรจุ (มาร์แชล) และมีการเรียกระบบเพื่อส่งไปยังอีกด้านหนึ่งของเครือข่าย
เคอร์เนลส่งข้อมูลผ่านเครือข่ายและอีกด้านหนึ่งรับข้อมูล
โฮสต์ระยะไกลจะส่งข้อมูลไปยังส่วนของเซิร์ฟเวอร์ที่ไม่มีการแยกส่วน
พารามิเตอร์จะถูกส่งไปยังโพรซีเดอร์จากนั้นโพรซีเดอร์จะถูกเรียกใช้งาน
ผลลัพธ์จะถูกส่งกลับไปยังไคลเอนต์ในลักษณะเดียวกัน