一、 简单介绍

如果我们本章讨论的主机都是支持双栈的,即支持IPv4地址。也支持Ipv6地址。

我们本次讨论的点:client与server端使用的是不同类型的地址。由于同样类型的地址没什么可讲的。

二、 IPv4client与IPv6server

即。client使用IPv4地址套接字来通信,server端使用IPv6地址套接字通信。

原理:

0. 首先IPv6server主机保证既有IPv4地址,又有IPv6地址。

1. IPv4client通过getaddrinfo函数。找到server端的IPv4地址。然后进行连接。

2. 来自client的IPv4的SYN到达server端,server端内核就把这个IPv4的SYN,映射为IPv6的SYN(就是把IPv4的IP地址映射为IPv6的IP地址)。然后交给进程。所以server端accept、recvfrom的套接字地址都是IPv6的。

3. 然后server端进程进行响应ACK,进程发送一个IPv6的ACK到内核,内核查看目的地址。就知道这个IPv6的地址是经过映射过来的。

所以内核就是这个IPv6地址映射为IPv4地址发送出去。

4. 这样就正常通信了,即实际上还是通过IPv4包进行通信的。然而server和client进程都不知情的,这些工作由server内核完毕。

注意:假设IPv6server主机没有IPv4地址。则这种通信无法完毕。

三、 IPv6client与IPv4server

即,client使用IPv6地址套接字来通信。server端使用IPv4地址套接字通信。

原理:

0. 首先IPv4server主机中没有IPv6地址。

1. IPv6client通过getaddrinfo函数,且hints的结构中的标志为AI_V4MAPPED。则我们就能够通过getaddrinfo函数得到server主机的IPv4地址映射的IPv6地址。

2. 然后client使用这个IPv6地址调用connect,而内核检測出这个IPv6的地址是映射的,所以就会把这个IPv6地址转成IPv4地址。然后发送出去。

3. 这样IPv4server就得到了IPv4的SYN,然后响应IPv4的ACK。

4. client接收到这个IPv4的ACK后,内核就会把这个IPv4的ACK转为IPv6的ACK,从而进行通信。

5. 实际上还是通过IPv4的包进行通信的。server和client进程不知情。

由client内核完毕。

注意:假设此时IPv4server主机有IPv6地址。则虽然hints的结构中的标志为AI_V4MAPPED,可是getaddrinfo也返回原有的IPv6地址,这种话,两方无法完毕通信。这时我们能够通过在主机名上加-4。来规定仅仅查询A记录。

这样就能够通信了。

四、 错误的组合

上述的两种错误情况,都是由于内核无法将IPv6地址转为为IPv4地址,由于IPv6有128位,而IPv4地址仅仅有32位。

总结一下:即

即:

1. 显然假设两方都是单栈主机,也两方的协议必须同样。

2. IPv4双栈客户。无法与IPv6的单栈server通信。即上面的第1种错误情况。

3. Ipv6单栈客户。无法与Ipv4的双栈server通信。

4. IPv6双栈客户能否够与IPv4双栈客户通信取决于实现,即假设getaddrinfo获取的是IPv4映射的IPv6地址。则能够通信。

假设获取的是真正的IPv6地址,则无法通信。

5. 事实上问题就是在于实现了IPv6的主机上,尽量也要实现IPv4,这种话。我们能够看到。去除表的第二行和第而列,则表中的(无)就没有了。仅仅剩下(无*)。

五、 IPv6地址測试宏

有一些IPv6应用程序想要知道,某个IPv6地址究竟是IPv4映射过来的,还是本身就是IPv6地址。我们能够使用宏:

#include     <netinet/in.h>
int IN6_IS_ADDR_V4MAPPED(const structin6_addr* apt);

来进行检測。

六、 建议

尽量写一些与详细协议无关的函数。

尽量使用与详细协议无关的函数。

还有从上述的表中能够看出,我们在编写server时,在server主机支持双栈协议的情况下。把server的地址写成IPv6地址。这样能够接收不论什么协议的client。

Unix网络编程学习笔记之第12章 IPv4与IPv6的互操作性的更多相关文章

  1. UNIX网络编程学习笔记:值-结果(value-result)参数

    前言 当把套接口地址结构传递给套接口函数时,总是通过指针来传递的,即传递的是一个指向结构的指针.结构的长度也作为参数来传递,其传递的方式取决于结构的传递方向:从进程到内核,还是从内核到进程. 1.从进 ...

  2. 转 网络编程学习笔记一:Socket编程

    题外话 前几天和朋友聊天,朋友问我怎么最近不写博客了,一个是因为最近在忙着公司使用的一些控件的开发,浏览器兼容性搞死人:但主要是因为这段时间一直在看html5的东西,看到web socket时觉得很有 ...

  3. UNIX网络编程--读书笔记

    会集中这段时间写UNIX网络编程这本书的读书笔记,准备读三本,这一系类的文章会不断更新,一直会持续一个月多,每篇的前半部分是书中讲述的内容,每篇文章的后半部分是自己的心得体会,文章中的红色内容是很重要 ...

  4. UNIX网络编程读书笔记:简介

    认知套接口编程接口 理解原始套接口(raw socket)的概念   值得注意的是,客户和服务器是典型的用户进程,而TCP和IP协议则通常是系统内核协议栈的一部分. 上图中在TCP和UDP之间留有间隙 ...

  5. UNP总结 Chapter 12~14 IPv4与IPv6的互操作性、守护进程和inet超级服务器、高级I/O函数

    一.IPv4与IPv6的互操作性 1.IPv4客户与IPv6服务器 拥有双重协议栈的主机的一个基本特性就是:其上运行的IPv6服务器既能应付IPv4客户,又能应付IPv6客户.这是通过使用IPv4映射 ...

  6. 网络编程学习笔记:Socket编程

    文的主要内容如下: 1.网络中进程之间如何通信? 2.Socket是什么? 3.socket的基本操作 3.1.socket()函数 3.2.bind()函数 3.3.listen().connect ...

  7. 网络编程学习笔记一:Socket编程

    “一切皆Socket!” 话虽些许夸张,但是事实也是,现在的网络编程几乎都是用的socket. ——有感于实际编程和开源项目研究. 我们深谙信息交流的价值,那网络中进程之间如何通信,如我们每天打开浏览 ...

  8. JAVA TCP网络编程学习笔记

    一.JAVA网络编程概述 网络应用程序,就是在已实现网络互联的不同计算机上运行的应用程序,这些程序之间可以相互交换数据.JAVA是优秀的网络编程语言,Java网络编程的类库位于java.net包中.J ...

  9. Java Socket网络编程学习笔记(一)

    0.前言 其实大概半年前就已经看过网络编程Socket的知识了(传统IO),但是因为长时间的不使用导致忘的一干二净,最近正好准备校招,又重新看了网络编程这一章, 是传统IO(BIO)相关的内容,故在此 ...

随机推荐

  1. Codeforces 672D Robin Hood(二分好题)

    D. Robin Hood time limit per test 1 second memory limit per test 256 megabytes input standard input ...

  2. [AT2699]Flip and Rectangles

    题目大意:有一个$n\times m$的$01$矩阵,可以把任意行或列反转,问最大的全为一的子矩阵的面积 题解:有一个结论:若一个子矩形$S$中的任意一个$2\times 2$的子矩形都含有偶数个$1 ...

  3. SPOJ 1825 Free Tour | 终极之树分治

    求树上最长路径使得经过的拥挤节点个数不超过K //欢迎访问这个博客!http://www.cnblogs.com/luyouqi233/p/8036828.html #include<cstdi ...

  4. swipe display: none后再显示,加载内容后,滑动失效问题

    只需要添加这两个属性即可: observer:true,//修改swiper自己或子元素时,自动初始化swiper observeParents:true//修改swiper的父元素时,自动初始化sw ...

  5. jquerydom对象和字符串之间的转换

    字符串转jquery对象:var tmp = $('<div>dd</div>').attr('id','bbq'); //用$符包裹起来即可 jquery对象转字符串: tm ...

  6. 百度之星初赛(A)——T6

    度度熊的01世界 Problem Description 度度熊是一个喜欢计算机的孩子,在计算机的世界中,所有事物实际上都只由0和1组成. 现在给你一个n*m的图像,你需要分辨他究竟是0,还是1,或者 ...

  7. 小知识:SPI四种模式区别【转】

    转自:http://home.eeworld.com.cn/my/space-uid-80086-blogid-119198.html spi四种模式SPI的相位(CPHA)和极性(CPOL)分别可以 ...

  8. Linux单机安转Spark

    安装Spark需要先安装jdk及安装Scala. 1. 创建目录 > mkdir  /opt/spark > cd  /opt/spark 2. 解压缩.创建软连接 > tar  z ...

  9. 第一章:1-10、试在下列条件下比较电路交换和分组交换。要传送的报文共x(bit),从源站到目的站共经过k段链路,每段链路的传播时延为d(s),数据率为C(bit/s)。在电路交换时电路的建立时间为s(s)。在分组交换时分组长度为p(bit),且各结点的排队等待时间可忽略不计。问在怎样的条件下,分组交换的时延比电路交换的要小?

    <计算机网络>谢希仁著第四版课后习题答案答:对电路交换,当t=s时,链路建立: 当t=s+x/C,发送完最后一bit:                 当t=s+x/C+kd,所有的信息到 ...

  10. CentOS下yum安装

    centos最小化安装不会装yum,以下是安装方法:(所有操作均在ROOT用户下,系统版本是centos7) 一.删除原有YUM # rpm -aq|grep yum|xargs rpm -e --n ...