openvpn工作流程
来源:互联网 发布:游戏优化差会怎样 编辑:程序博客网 时间:2024/05/18 01:27
http://linux.net527.cn/Linuxwendang/xitongguanliyuan/40764.html
openvpn原理如下:
1 openvpn驱动部分实现了网卡处理和字符设备。网卡处理网络数据,字符设备完成与应用层的数据交互。
2 使用openvpn必须修改路由表
工作过程
发送数据:
1 应用程序发送网络数据
2 网络数据根据修改后的路由表把数据路由到虚拟网卡
3 虚拟网卡把数据放到数据队列中
4 字符设备从数据队列中取数据,然后送给应用层
5 应用层把数据转发给物理网卡
6 物理网卡发送数据
接收过程:
1 物理网卡接受到数据,并传到应用空间
2 应用守护程序通过字符设备,把数据传给驱动网卡
3 数据通过虚拟网卡重新进入网络堆栈
4 网络堆栈把数据传给上层真实的应用程序。
基本上所有的VPN都是这么实现的:
1. 更改路由表,通过应用程序调用API函数更改和添加路由表。将数据包都先发送到虚拟网卡。
2. 虚拟网卡得到数据包,先判断该数据包是什么类型的数据包。因为本身是一个物理的虚拟网卡,它必须去处理ARP
,DHCP等一些数据包,用于欺骗上层网络,否则该网卡将不能工作,这一点比IMD的驱动要麻烦一些。
3. 虚拟网卡判断得到的数据包是普通的Tcp和Udp数据包后,将该数据包压入一个堆栈。该堆栈是一个和应用程序(通
常这个应用程序被称为守护程序)共享的内存块。然后驱动Set一个Event。上层应用程序Wait这个Event。并从这个堆栈
中取得这个数据包。
4. 上层应用程序得到这个数据包后,修改修改这个数据包的内容,然后建立一个Socket把该数据包重新封装成TCP或
者UDP包后从物理网卡发送到Vpn的服务器上,由服务器再进行处理。转发到最终的目的IP。
假设我们要打开一个IE,那么数据包的路线如下所示。
ie-vnic-vpn client-tcp/udp-vpn网关-route-web服务器
接收的时候正好相反。
- openvpn工作流程
- OpenVPN的工作原理
- OpenVPN的工作原理
- OpenVPN的工作原理
- OpenVPN的工作原理
- windows上搭建openVPN简明流程
- Android系统下安装openVPN流程
- OpenVpn 的俩中工作模式
- 工作流程
- 工作流程
- 工作流程
- 工作流程
- 工作流程
- OpenVPN
- OpenVPN
- openVPN
- openVPN
- OpenVpn
- 配置Apache Flex SDK 4.9.0(包括:手动方式和自动方式)
- 二叉树性质
- 对话框部分的收缩和扩展
- AWS推数据仓库服务Redshift 价格仅是Teradata IBM Oracle的十分之一
- java实现Bitmap算法
- openvpn工作流程
- 最短路
- gralloc
- 实时的hadoop--storm
- 关于 URI URL
- 一个人的旅行
- 在写一个FPGA的串口通讯问题
- Linux主要shell命令详解
- 创建树