1 29 March, 2002 The Computer Communications Course
BSD UNIX transport API: The Socket Interface
2 29 March, 2002 The Computer Communications Course
The Client-Server Programming Paradigm
- most networking applications can be divided into two pieces:
most networking applications can be divided into two pieces: client client and and server server
✁✄✂✆☎ ✝ ✞✠✟☛✡☞✝ ✌✎✍✏✌✏✍✏✑✒☎ ☎ ✓✎✌✕✔✗✖✙✘✚✡☛✛✚☎ ✝ ✜☛✞✒✢✤✣✗✘ ✖✙✥✚✞✙✌☛✌✙✦✕✥✚✖✙✧★✧✩✍✙✟✕✝ ✥☛✑✗✡ ✞✕✌✎✪✫✝ ✡☛✔☞✖✒✟✚✞✬✌☛✞✒✘✚✜✚✞✒✘ ✑✗✡✩✑☞✡✗✝ ✧✫✞✭✦✮✌✙✝ ✧★✣✙☎ ✞✒✘★✢✕✞✙✌✙✝ ✯✒✟ ✁✭✰✆✞✠✘ ✜✚✞✠✘✩✍✏✌✏✍✏✑✒☎ ☎ ✓✬✘✚✍✙✟✚✌✲✱✏✖✙✘ ✞✒✜✚✞✒✘✗✦✕✥✚✖✙✧★✧✩✍✙✟✕✝ ✥☛✑✗✡ ✞✕✌✎✪✫✝ ✡☛✔✳✧✩✍✙☎ ✡✗✝ ✣✒☎ ✞✤✥✕☎ ✝ ✞✠✟☛✡ ✌✲✑✗✡ ✑✙✟✚✓✬✯✒✝ ✜✚✞✄✟✲✧✫✖✙✧✫✞✄✟☛✡✗✦✗✢✙✞✕✌✙✝ ✯✙✟☞✝ ✌✎✥☛✖✙✧★✣✙☎ ✞✙✴ ✰✆✞✒✘✚✜✚✞✒✘✵✪✆✑✒✝ ✡ ✌✲✱✏✖✙✘★✘ ✞✙✶✗✍✏✞✕✌✏✡ ✌✲✱✕✘ ✖✙✧✵✥✕☎ ✝ ✞✠✟☛✡✚✌★✑✒✟✏✢☞✌☛✞✠✘✚✜✚✞✕✌✎✡☛✔✗✞✠✧✲✷ ✸✒✹✠✺✏✻★✼ ✻✗✽ ✾ ✻✕✽❀✿ ❁☛❂❃✻✙❄ ❅ ✺✏✻✕✽❆✺☛❁☛❂✚❇✒❈ ✻✎✽ ✻☛❉☛❊ ✻✗✼ ❅ ✼✩❄ ❅ ✻✕✽ ❁✚❅☛❄ ✾ ✻✙❈ ❋✕● ❍ ✽❀✿ ❍ ❂☛✿ ❊☛✽ ✽ ✻✏❂ ❅☛❈ ❋✲■ ❏✚❋★✼ ❑✚❁✚▲✄❂✏❄ ❂ ▼✲✿ ✺✕❄ ❈ ❇✲❑✏✽ ❍ ✿ ✻✗✼ ✼ ✻✏✼❃◆ ✂✆☎ ✝ ✞✠✟☛✡✩✑✏✌✕❖☛✌★✑✎✌☛✞✠✘ ✜✚✞✠✘✩✡ ✖✳✢✕✖✎✌✏✖✙✧✫✞✬✪✆✖✙✘✏❖★✑✒✟✏✢✬✌☛✞✠✟✏✢◗P✗✑✙✥✗❖✲✡☛✔✕✞✤✘ ✞✕✌✏✍✒☎ ✡ ✌✕✷request response Server Client
3 29 March, 2002 The Computer Communications Course
UNIX I/O Paradigm and Network I/O
- ❘❃❙✩❚✙❯
- ✟✚✞✙✡☛✪✆✖✙✘☛❖☞✥✚✖✙✧★✧✩✍✙✟✕✝
- ✰✆✞✙✜✚✞✠✘
- ❴
4 29 March, 2002 The Computer Communications Course
Specifying A Protocol Interface
❬ ✞✕✌✙✝ ✯✙✟✚✞✠✘ ✌✲✑✗✡☞❵✙✞✒✘✏❖✚✞✭☎ ✞✕✓☞✪✆✑✒✟☛✡ ✞✒✢✳✡ ✖☞✑✕✥✗✥✚✖✙✧★✧✫✖✙✢✕✑✕✡ ✞✳✧✩✍✒☎ ✡✗✝ ✣✒☎ ✞✬✌☛✞✙✡✩✖✗✱ ❬ ✞✕✌✙✝ ✯✙✟✚✞✠✘ ✌✲✑✗✡☞❵✙✞✒✘✏❖✚✞✭☎ ✞✕✓☞✪✆✑✒✟☛✡ ✞✒✢✳✡ ✖☞✑✕✥✗✥✚✖✙✧★✧✫✖✙✢✕✑✕✡ ✞✳✧✩✍✒☎ ✡✗✝ ✣✒☎ ✞✬✌☛✞✙✡✩✖✗✱ ✥✚✖✙✧★✧✩✍✙✟✕✝ ✥✚✑✗✡✗✝ ✖✒✟✎✣✗✘ ✖✕✡ ✖✙✥☛✖✠☎ ✌✕✷ ✥✚✖✙✧★✧✩✍✙✟✕✝ ✥✚✑✗✡✗✝ ✖✒✟✎✣✗✘ ✖✕✡ ✖✙✥☛✖✠☎ ✌✕✷ ❨❆✔✕✞✕✓✬✣✕✘ ✖✕✜✕✝ ✢✙✞✒✢✳✯✏✞✠✟✚✞✠✘ ✑✠☎ ✝ ✡ ✓✎✱✏✑✕✘✎P✗✞✕✓✗✖✒✟✏✢✤❨✆✂✄❩✏❛ ❚ ❩✙❱ ❨❆✔✕✞✕✓✬✣✕✘ ✖✕✜✕✝ ✢✙✞✒✢✳✯✏✞✠✟✚✞✠✘ ✑✠☎ ✝ ✡ ✓✎✱✏✑✕✘✎P✗✞✕✓✗✖✒✟✏✢✤❨✆✂✄❩✏❛ ❚ ❩✙❱ ❲ ❲ ✧✩✍✒☎ ✡✗✝ ✣✒☎ ✞ ✧✩✍✒☎ ✡✗✝ ✣✒☎ ✞ ❜✠❝☛❞✆❡ ❞✙❢✚❞✙❣✄❤ ✐✏❥✎❦ ❣ ❦ ❧✗♠ ❜✠❝☛❞✆❡ ❞✙❢✚❞✙❣✄❤ ✐✏❥✎❦ ❣ ❦ ❧✗♠ ❲ ❲ ✧✩✍✒☎ ✡✗✝ ✣✒☎ ✞ ✧✩✍✒☎ ✡✗✝ ✣✒☎ ✞ ❡ ♥✏❜✠❧✏♠☞❞✠❤❆♠✗❧✙❝✠♦ ❦ ❢✚❧ ❡ ♥✏❜✠❧✏♠☞❞✠❤❆♠✗❧✙❝✠♦ ❦ ❢✚❧ ❲ ❲ ✧✩✍✒☎ ✡✗✝ ✣✒☎ ✞ ✧✩✍✒☎ ✡✗✝ ✣✒☎ ✞ ✐✕♣✠♣✕❝☛❧✏♠☛♠✙❦ q rs❤ ✐✏❥✎❦ ❣ ❦ ❧✗♠ ✐✕♣✠♣✕❝☛❧✏♠☛♠✙❦ q rs❤ ✐✏❥✎❦ ❣ ❦ ❧✗♠5 29 March, 2002 The Computer Communications Course
The Socket Abstraction
- ❨❆✔✕✞☞✌✏✖✙✥✗❖☛✞✙✡☞✝
- t
- ✰✫✝
- ✈
6 29 March, 2002 The Computer Communications Course
System Data Structures for Sockets
family: PF_INET
service: SOCK_STREAM
Local IP: Remote IP: Local port: Remote port: 0: 1: 2: 3: 4:
To the system file table