Android 3G/4G流量上网原理简析

手机一般会提供两种上网方式:Wifi或者3G/4G上网,Wifi上网其实就是利用网卡通过以太网上网;3G/4G则是通过基带,利用蜂窝网络进行上网,之前已经简单的阐述了Wifi上网跟3G上网的区别,本文主要简述Android 3G/4G上网的流程及原理。

  • 无线上网硬件模型
  • 3G/4G上网协议ppp
  • 3G/4G上网流程-ppp如何建立
  • socket如何通过基带模块发送数据、接收数据

Android流量数据上网概述(硬件平台及环境)

手机一般有两块网卡,只是不同时使用,Wifi的那种以太网卡,还有就是3G/4G的无线Modem型网卡(基带模块),3G/4G上网用的是蜂窝网络,信号以电磁波的形式在空气中进行传播,发送到距离最近的基站,基站通过交换机转发到覆盖目标设备的基站,并通知目标设备,回传结果,这种上网模式在链路层,用的一般是PPP(Point-to-Point Protocol)协议,而其上网媒介用的则是无线通信专用的无线基带通信模块:

手机4G上网模型.png

Android流量数据上网采用的协议-PPP(Point-to-Point Protocol)

同以太网不同,移动端上网的方式是通过蜂窝网络进行上网,两者最大的区别是在链路层,Android 3G/4G无线上网的网络协议模型如下:

Android 无线流量上网模型.jpg

在数据链路层,PPP(Point-to-Point Protocol)协议提供了一种标准点对点的传输方式,为各种主机、网桥和路由器通信提供通用连接方案。PPP协议主要包括以下三个部分:

  • 令数据帧封装格式:基于HDLC(High Level Data Control,高层数据控制链路)标准,为串行数据链路上传输的数据包定义封装格式。
  • 链路控制协议LCP(Link Control Protocol):用于封装格式选项的自动协商、链路的建立和终止、探测链路错误和配置错误。
  • 认证协议,最常用的包括口令验证协议PAP(Password Authentication Protocol)和挑战握手验证协议CHAP(Challenge-Handshake Authentication Protocol)。
  • 网络控制协议NCP(Network Control Protocol):PPP协议针对每一种网络层协议都有相应的网络控制协议,并通过它们完成点对点通信时网络层参数的配置,如IP地址、DNS的动态协商。

其中上面的大部分都是在建立数据链路的时候用的,数据链路建立后,其实主要用关心的是令数据帧封装,PPP协议下的令数据帧封装格式如下图:

PPP协议数据帧格式

由于PPP协议是点对点的,不需要太多信息,因此这里是没有48位MAC地址概念的,因此,PPP也就无所谓 ARP(地址解析协议)和RARP(逆地址解析协议),这两个是某些网络接口(如以太网和令牌环网)使用的特殊协议。

Android流量数据上网的实现

在Android系统中,应用访问网络时,会首先查看数据上网链路是否已经建立建立,如果已经建立,则直接使用已建立的网络接口进行通信,如果还未建立,则需要首先建立数据通路。PPP拨号上网配置十分复杂,需要一系列的协商、验证,为了开发方便,Linux对PPP数据链路的建立过程进行抽象,实现了pppd拨号应用程序,专门用于管理PPP数据链路的建立与关闭。不过,pppd其实只是负责建立数据链路,建立之后,数据上网不会依赖pppd服务,打个比方就是:pppd只负责修路,不负责运货,在整个手机无线通信中,pppd地位如下图:

image.png

pppd是一个后台服务进程(daemon),实现了所有鉴权、压缩/解压和加密/解密等扩展功能的控制协议,负责把要发送的数据包传递给PPP协议处理模块,设置PPP协议的参数,用来建立/关闭连接。

PPP数据链路建立流程

Android系统如果想要利用PPP协议进行数据通信,必须首先按照PPP协议建立数据通信链路。基带模块正确加载之后会映射多个ttyUSB设备文件,有的ttyUSB用于AT命令发送,有的用作数据通信,底层通过串口多路复用机制,实现了USB串口的多路复用。在使用ttyUSB建立数据链路的时候,首先通过发送AT命令,打开无线上网模块,随后利用pppd拨号程序建立数据链路。拨号链接过程遵循PPP通信协议,手机同蜂窝网络基站双方动态协商,配置链路参数、IP地址等,拨号成功后,Android系统会为基带模块映射一个虚拟网络接口名字可能是ppp0,或者rmnetxxx等,之后,Android系统便可利用该接口进行网络通信了,该接口的使用方式同wlan0类似,IP层对链路层完全无感知。

PPP数据链路的建立需要完成三个步骤,包括链路层配置、链路认证以及网络层配置,这个过程中,通信双方必须通过协商,确定数据包格式、IP地址等链路参数,才能正确建立PPP数据链路。在实际操作中,PPP数据链路的建立可分以下几个阶段:

  • (1) 链路不可用阶段(Link Dead Phase):PPP链路从这个阶段开始和结束,在该阶段,整条链路处于不可用状态,当通信双方检测到物理线路激活时,会从该阶段转入链路建立阶段。
  • (2) 链路建立阶段 (Link Establishment Phase):在此阶段,PPP链路将通过LCP进行协商,确定工作方式、认证方式、链路压缩等。如果LCP协商成功,则转入Opened状态,表示底层链路已经正确建立,如果链路协商失败,则会返回到第一阶段。链路建立成功后,如果配置了PPP认证,则会进入认证阶段,如果没有配置,则直接转入网络层协议阶段。
  • (3) 认证阶段 (Authentication Phase):在此阶段,PPP将进行用户认证工作,通过PAP或者CHAP验证用户名、密码等身份信息,如果认证失败,PPP链路进入链路终止阶段,拆除链路,如果认证成功则转入网络层协议阶段。
  • (4) 网络层协议阶段 (Network-Layer Protocol Phase);在此阶段,每种网络层协议会通过相应网络控制协议进行配置,本课题通过IPCP协商双方IP地址、DNS等,协商成功后,PPP链路便可基于TCP/IP发送或接收报文。
  • (5) 链路终止阶段 (Link Termination Phase):PPP能在任何时候终止链路,如认证失败、载波丢失等情况均会导致链路终止,PPP协议通过交换LCP报文来关闭链路,并通知网络层与物理层强制关闭链路,返回链路不可用阶段。链路建立流程如图3.19所示:

链路建立流程

通信链路建立后,pppd会创建一个网络接口(如ppp0),内核中的PPP协议模块也会登记该网络接口,对上层应用而言,该虚拟网络接口ppp0或者或者rmnetxxx,就是无线上网需要调用的接口,并且该接口创建之初就已经从3G网络获得了动态分配的IP地址,对上层应用而言可以看做一块真实的,并且已经激活的网卡设备,可以像使用以太网卡一样,进行TCP/IP网络通信,pppd服务建立链路的流程图:

pppd拨号建立链路示意图.jpg

数据的发送流程

应用程序通过socket发送TCP/IP数据包时候,内核通过IP地址和路由表找到对应的网络接口(ppp0或者rmnetxxx),然后调用ppp协议相应的实现函数,经PPP协议封装,发送数据,最终通过串口将数据发送到基带模块,并经射频模块将信息传输到附近的基站。

ppp数据发送流程.jpg

数据的接收流程

数据接收流程可以看做是发送的逆向,不过这里稍微有些区别,那就是接收方,在数据链路建立的时候,接收方是pppd拨号进程,建立之后,普通的上网数据,接收方就是一般的用户进程:

数据接收流程.jpg

总结

  • 手机上网走的是PPP协议
  • PPP协议没有MAC地址的概念
  • pppd主要用来铺路(建立链路),不负责运货
  • 链路建立后,对IP层而言,数据通信流程同以太网没有区别

作者:看书的小蜗牛 Android 3G/4G流量上网原理简析

仅供参考,欢迎指正

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

编辑于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏我和未来有约会

Silverlight第三方控件专题

这里我收集整理了目前网上silverlight第三方控件的专题,若果有所遗漏请告知我一下。 名称 简介 截图 telerik 商 RadC...

4095
来自专栏一个爱瞎折腾的程序猿

sqlserver使用存储过程跟踪SQL

USE [master] GO /****** Object: StoredProcedure [dbo].[sp_perfworkload_trace_s...

2210
来自专栏魂祭心

原 canvas绘制clock

4304
来自专栏张善友的专栏

LINQ via C# 系列文章

LINQ via C# Recently I am giving a series of talk on LINQ. the name “LINQ via C...

2675
来自专栏张善友的专栏

Miguel de Icaza 细说 Mix 07大会上的Silverlight和DLR

Mono之父Miguel de Icaza 详细报道微软Mix 07大会上的Silverlight和DLR ,上面还谈到了Mono and Silverligh...

2757
来自专栏我和未来有约会

Kit 3D 更新

Kit3D is a 3D graphics engine written for Microsoft Silverlight. Kit3D was inita...

2636
来自专栏大内老A

The .NET of Tomorrow

Ed Charbeneau(http://developer.telerik.com/featured/the-net-of-tomorrow/) Exciti...

32810
来自专栏pangguoming

Spring Boot集成JasperReports生成PDF文档

由于工作需要,要实现后端根据模板动态填充数据生成PDF文档,通过技术选型,使用Ireport5.6来设计模板,结合JasperReports5.6工具库来调用渲...

1.3K7
来自专栏跟着阿笨一起玩NET

c#实现打印功能

2952
来自专栏ASP.NETCore

ASP.NET Core 整合Autofac和Castle实现自动AOP拦截

除了ASP.NETCore自带的IOC容器外,我们还可以使用其他成熟的DI框架,如Autofac,StructureMap等(笔者只用过Unity,Ninjec...

694

扫码关注云+社区