1, TCP协议通信:

现在有两台电脑A和B。在

假设A的地址为 192.168.0.100

假设B的地址为 192.168.0.102

A想给B发送一个字符串Hello,  如果A,B之间采用TCP协议,那么B收到Hello的过程是怎样的呢?

首先建立连接(3次握手成功之后,A和B的链接才算成功),然后A在给B发送数据。

如果A,B不在一个局域网内,A,B通信就需要打洞了。

假设A通过路由器S1上网。B通过路由器S2上网。

S1的外网IP:114.66.5.211          本地IP:192.168.0.1

S2的外网IP:14.153.27.47          本地IP:192.168.1.1

A的本地地址:192.168.0.100

B的本地地址:192.168.1.102

先暂时不说A和B的通信。我们来说一下A访问www.baidu.com

发送的源地址就是192.168.0.100  ,目标地址就是61.135.169.105(www.baidu.com经过DNS解析之后的地址)。

由于A的网内没有这个61.135.169.105地址,所以会把数据发给默认网关。这里的默认网关地址就是192.168.0.1(路由器S1的本地地址)

路由器S1拿到数据之后,会做什么事情呢?

他会做NAT映射,然后把之前的源地址192.168.0.100换成外网IP:114.66.5.211.

它是怎么映射的呢?

他会把192.168.0.1:22124转换成一个外网端口号。假设转换的端口号为1481。

22124为A电脑从哪个端口发出去的。1481为路由器计算出来的值,具体计算方法不需要知道,只需要知道这个值在NAT表中,是唯一的。

如下表:

那么发给百度服务器的内容是 源IP为114.66.5.211:1481  目标IP为61.135.169.105:8080。 百度收到请求后,把源IP换成目标IP发送数据。

最终数据会传到路由器S1. 传到路由器之后,它开始根据端口号查NAT表。如果这个端口号在表中存在,那么就把src的值取出,并把数据中的目标地址

替换为src的值。这样A就收到了百度服务器的数据。

根据这个思路,可以得出,A,B要想通信,路由器S1必须知道,B在路由器S2中的映射。同样的,路由器S2必须知道A在S1中的映射。

平常做法是需要借助一台服务器T,A和B都去访问服务器T,那么T会得到A和B在各自路由器中的映射,然后把B在路由器S2中的映射发给S1。

把A在路由器S1中的映射发给S2.这样A和B就可以直接通信了。

简单说一下 TCP打洞和UDP打洞的更多相关文章

  1. TCP打洞和UDP打洞的区别 (转)

    为什么网上讲到的P2P打洞基本上都是基于UDP协议的打洞?难道TCP不可能打洞?还是TCP打洞难于实现?     假设现在有内网客户端A和内网客户端B,有公网服务端S.     如果A和B想要进行UD ...

  2. TCP打洞与UDP打洞的差别

    为什么网上讲到的P2P打洞基本上都是基于UDP协议的打洞?难道TCP不可能打洞?还是TCP打洞难于实现?     如果如今有内网clientA和内网clientB.有公网服务端S.     如果A和B ...

  3. TCP打洞和UDP打洞的区别 (相互直接访问)

    为什么网上讲到的P2P打洞基本上都是基于UDP协议的打洞?难道TCP不可能打洞?还是TCP打洞难于实现?     假设现在有内网客户端A和内网客户端B,有公网服务端S.     如果A和B想要进行UD ...

  4. Kcptun 是一个非常简单和快速的,基于KCP 协议的UDP 隧道,它可以将TCP 流转换为KCP+UDP 流

    本博客曾经发布了通过 Finalspeed 加速 Shadowsocks 的教程,大家普遍反映能达到一个非常不错的速度.Finalspeed 虽好,就是内存占用稍高,不适合服务器内存本来就小的用户:而 ...

  5. Python实现简单的udp打洞(P2P)

    UDP穿越NAT的具体设计 首先,Client A登录服务器,NAT 1为这次的Session分配了一个端口60000,那么Server S收到的Client A的地址是200.0.0.132:600 ...

  6. UDP打洞、P2P组网方式研究

    catalogue . NAT概念 . P2P概念 . UDP打洞 . P2P DEMO . ZeroNet P2P 1. NAT概念 在STUN协议中,根据内部终端的地址(LocalIP:Local ...

  7. udp打洞( NAT traversal )的方法介绍

    http://www.cnblogs.com/whyandinside/archive/2010/12/08/1900492.html http://www.gzsec.com/oldversion/ ...

  8. Udp打洞原理和源代码。

    所谓udp打洞就是指客户端A通过udp协议向服务器发送数据包,服务器收到后,获取数据包,并且 可获取客户端A地址和端口号.同样在客户端B发送给服务器udp数据包后,服务器同样在收到B发送过来 的数据包 ...

  9. NAT穿透(UDP打洞)

    1.NAT(Network Address Translator)介绍 NAT有两大类,基本NAT和NAPT. 1.1.基本NAT 静态NAT:一个公网IP对应一个内部IP,一对一转换 动态NAT:N ...

随机推荐

  1. eclipse自动创建项目出错Cannot change version of project facet Dynamic Web Module to 2.3.

    Cannot change version of project facet Dynamic Web Module to 2.3. step1:修改properties step2:修改web.xml ...

  2. Recovery启动流程(1)--- 应用层到开机进入recovery详解

    转载请注明来源:cuixiaolei的技术博客 进入recovery有两种方式,一种是通过组合键进入recovery,另一种是上层应用设置中执行安装/重置/清除缓存等操作进行recovery.这篇文档 ...

  3. SPOJ:The Next Palindrome(贪心&思维)

    A positive integer is called a palindrome if its representation in the decimal system is the same wh ...

  4. MemCache在Windows下环境的搭建及启动

    sc create "memcached-11212" start= auto binPath= "D:\memcached_en32or64\x64\memcached ...

  5. UVa 1363 Joseph's Problem (数论)

    题意:给定 n,k,求 while(i <=n) k % i的和. 析:很明显是一个数论题,写几个样例你会发现规律,假设 p = k / i.那么k  mod i = k - p*i,如果 k ...

  6. CodeForces 721A One-dimensional Japanese Crossword (水题)

    题意:给定一行字符串,让你输出字符‘B'连续出现的次数. 析:直接扫一下就OK了. 代码如下: #pragma comment(linker, "/STACK:1024000000,1024 ...

  7. Linux 常用命令十一 ps

    一.ps命令 Linux中的ps命令是Process Status的缩写. ps命令用来列出系统中当前运行的那些进程.ps命令列出的是当前那些进程的快照,就是执行ps命令的那个时刻的那些进程,如果想要 ...

  8. bzoj 3110 [Zjoi2013]K大数查询【树套树||整体二分】

    树套树: 约等于是个暴力了.以区间线段树的方式开一棵权值线段树,在权值线段树的每一个点上以动态开点的方式开一棵区间线段树. 结果非常惨烈(时限20s) #include<iostream> ...

  9. 洛谷 P4011 孤岛营救问题【bfs】

    注意: 一个点可能有多把钥匙,所以把每个点有钥匙的情况状压一下 两个点之间有障碍的情况只给出了单向,存的时候记得存一下反向 b[i][j]表示当前点拥有钥匙的状态,g[x1][y1][x2][y2]表 ...

  10. spoj 371 Boxes【最小费用最大流】

    对于ai==0连接(i,t,1,0),对于ai>1(s,i,ai-1,0),然后对以相邻的两个点(i,j)连接(i,j,inf,1),注意这里是一个环的形式,所以1和n+1相连 #include ...