📙
Beej's Guide to Network Programming 简体中文版
  • 簡介
  • 联络译者
  • 译者鸣谢
  • 1. 前言
    • 1.1. 本书的读者
    • 1.2. 平台与编译器
    • 1.3. 官方网页与书本
    • 1.4. Solaris/SunOS 程序员要注意的事情
    • 1.5. Windows 程序员要注意的事情
    • 1.6. 来信原则
    • 1.7. 镜像站台(Mirroring)
    • 1.8. 译者该注意的
    • 1.9. 版权与出版(Copyright and Distribution)
  • 2. 何谓 Socket
    • 2.1. 两种 Internet Sockets
    • 2.2. 底层漫谈与网路理论
  • 3. IP address丶结构与数据转换
    • 3.1. IPv4 与 IPv6
      • 31.1. Sub network (子网)
      • 3.1.2. Port Number(连接埠号码)
    • 3.2. Byte Order(字节的顺序)
    • 3.3. 数据结构
    • 3.4. IP address,Part II
      • 3.4.1. Private Network
  • 4. 从 IPv4 移植为 IPv6
  • 5. System call 或 Bust
    • 5.1. getaddrinfo()-准备开始!
    • 5.2. socket()-取得 File Descriptor!
    • 5.3. bind()- 我在哪個 port?
    • 5.4. connect(),嘿!你好。
    • 5.5. listen()-有人会调用我吗?
    • 5.6. accept()-"谢谢你调用 port 3490"
    • 5.7. send() 与 recv()- 宝贝,跟我说说话!
    • 5.8. sendto() 与 recvfrom()- 用 DGRAM 风格跟我说说话
    • 5.9. close() 与 shutdown()-从我面前消失吧!
    • 5.10. getpeername()-你是谁?
    • 5.11. gethostname()-我是誰?
  • 06-Client-Server 基础
    • 6.1. 简易的 Stream Server
    • 6.2. 简易的 Stream Client
    • 6.3. Datagram Sockets
  • 07-高等技术
    • 7.1. Blocking(阻塞)
    • 7.2. select()-同步 I/O 多工
    • 7.3. 不完整传送的後续处理
    • 7.4. Serialization:如何封装数据
    • 7.5. 数据封装
    • 7.6. 广播数据包:Hello World!
  • 8. 常见的问题
  • 9. Man 使用手册
    • 9.1. accept()
    • 9.2. bind()
    • 9.3. connect()
    • close()
    • getaddrinfo(), freeaddrinfo(), gai_strerror()
    • gethostname()
    • gethostbyname(), gethostbyaddr()
    • getnameinfo()
    • getpeername()
    • errno
    • fcntl()
    • htons(), htonl(), ntohs(), ntohl()
    • inet_ntoa(), inet_aton(), inet_addr
    • inet_ntop(), inet_pton()
    • listen()
    • perror(), strerror()
    • poll()
    • recv(), recvfrom()
    • select()
    • setsockopt(), getsockopt()
    • send(), sendto()
    • shutdown()
    • socket()
    • struct sockaddr and pals
  • 10-参考文献
    • 10.1. 书籍
    • 10.2. 网站参考资料
    • 10.3. RFC
  • 11. 原着鸣谢
Powered by GitBook
On this page
Edit on GitHub
  1. 3. IP address丶结构与数据转换
  2. 3.4. IP address,Part II

3.4.1. Private Network

Previous3.4. IP address,Part IINext4. 从 IPv4 移植为 IPv6

Last updated 2 years ago

很多地方都有防火墙(firewall),由它们的保护将网路隐藏於世界的其它地方。而有时,防火墙会用所谓的网路地址转换(NAT,Network Address Translation)的方法,将"internal"(内部的)IP 地址转换为"external"(外部的)[世界上的每个人都知道的]IP address。

你又开始紧张了吗?"他又要扯到哪里去了?"

好啦,放轻松,去买瓶汽水[或酒精]饮料,因为身为一个初学者,你还可以不要理会 NAT,因为它所做的事情对你而言是透明的。不过我想在你开始对所见的网路数量开始感到困惑以前,谈谈防火墙身後的网路。

比如,我家有一个防火墙,我有两个 DSL 电信公司分配给我的 static IPv4 地址,而我家的网路有七部电脑要用。这有可能吗?两台电脑不能共用同一个 IP address 阿,不然数据就不知道该送去哪一台电脑了!

答案揭晓:它们不会共用同一个 IP address,它们是在一个配有两千四百万个 IP address 的 private network 上,全部都是我的。

好,都是我的,有这麽多地址可以让大家用来上网,而这里要讲的就是为什麽:

如果我登入到一台远端的电脑,它会说我从 192.0.2.33 登入,这是我的 ISP 提供给我的 public IP。不过若是我问我自己本地端节点的电脑,它的 IP address 是什麽时,他会说是 10.0.0.5。是谁转换 IP 的呢?答对了,就是防火墙!它做了 NAT!

10.x.x.x 是其中一个少数保留的网路,只能用在完全无法连上 Internet 的网路[disconnected network],或是在防火墙後的网路。你可以使用哪个 private network 编号的细节是记在 RFC 1918 [15]中,不过一般而言,你较常见的是 10.x.x.x 及 192.168.x.x,这里的 x 是指 0-255。较少见的是 172.y.x.x,这里的 y 范围在 16 与 31 之间。

在 NAT 防火墙後的网路可以不必用这些保留的网路,不过它们通常会用。

[真好玩!我的外部 IP 真的不是 192.0.2.33,192.0.2.x 网路保留用来虚构本教程要用的 "真实"IP address,就像本教程也是虚构的一样 Wowzers!]

IPv6 也很合理的会有 private network。它们最早的前缀是 fdxx:[或者未来可能是 fcXX:],如同 RFC 4193 [16]。NAT 与 IPv6 通常不会混用,然而[除非你在做 IPv6 到 IPv4 的 gateway,这就不在本教程的讨论范围内了],理论上,你会有很多地址可以使用,所以根本不再需要使用 NAT。不过,如果你想要在不会路由到外面的网路[封闭网路]上分配地址给你自己,就用 NAT 吧。

[15]

[16]

http://tools.ietf.org/html/rfc1918
http://tools.ietf.org/html/rfc4193