笔记:WebRTC 网络技术理论与实战(二)

news2025/1/17 0:19:48
WebRTC技术笔记
笔记:WebRTC 网络技术理论与实战(一)

作者李俊才 (jcLee95):https://blog.csdn.net/qq_28550263
邮箱 :291148484@163.com
本文地址:https://blog.csdn.net/qq_28550263/article/details/131302130


【介绍】:本系列笔记总结WebRTC用到的相关技术理论及其实践。

上一节:《 笔记:WebRTC 网络技术理论与实战(一) | 下一节:《 笔记:WebRTC 网络技术理论与实战(三)

目 录


第二章:WebRTC 网络协议

1. 绘画 会话描述协议(SDP)

1.1 SDP 协议简介

SDPSession Description Protocol)是一种用于 描述和协商多媒体会话参数 的文本格式。它由一系列属性(attribute)组成,每个属性由一个 键值对 表示。属性之间用 换行符(CRLF)分隔。比如:

v=0
o=- 2890844526 2890842807 IN IP4 192.0.2.3
s=-
t=0 0
a=group:BUNDLE audio video
m=audio 49170 RTP/AVP 0
c=IN IP4 192.0.2.3
a=rtpmap:0 PCMU/8000
a=ptime:20
m=video 51372 RTP/AVP 99
c=IN IP4 192.0.2.3
a=rtpmap:99 VP8/90000
a=rtcp-fb:99 ccm fir
a=rtcp-fb:99 nack
a=rtcp-fb:99 nack pli

1.2 SDP 在 WebRTC 中的作用

在 WebRTC 中,SDP 用于在通信双方之间交换音视频编解码器、传输协议、IP 地址和端口等信息。SDP 交换通常通过信令服务器进行。当一个用户想要与另一个用户建立通信连接时,首先会创建一个 SDP offer,包含自己的媒体参数和能力。然后,通过信令服务器发送给对方。接收方收到 SDP offer 后,会根据自己的能力和需求创建一个 SDP answer,并通过信令服务器发送回去。双方根据对方的 SDP 进行协商和配置,最终建立起实时通信连接。

SDP 在 WebRTC 中的主要作用有:

  1. 音视频编解码器协商 :通过 SDP 交换,通信双方可以了解对方支持的音视频编解码器,从而选择一个双方都支持的编解码器进行通信。
  2. 传输协议协商 :通过 SDP 交换,通信双方可以了解对方支持的传输协议(如 RTP、RTCP、DTLS 等),从而选择一个双方都支持的传输协议进行通信。
  3. ICE 候选地址交换 :通过 SDP 交换,通信双方可以互相告知自己的 ICE 候选地址(包括本地地址、反射地址和中继地址),从而协助 ICE 连接建立。
  4. 媒体流信息交换 :通过 SDP 交换,通信双方可以了解对方的媒体流信息(如流 ID、轨道 ID 等),从而实现多路复用和媒体流控制。

通过 SDP 在 WebRTC 中的这些作用,通信双方可以协商出合适的音视频编解码器、传输协议和网络地址,从而实现高效、稳定的实时通信。

2. 交互式连接建立(ICE)

2.1 ICE 协议简介

交互式连接建立(ICE,Interactive Connectivity Establishment)是一种用于在复杂网络环境中建立点对点连接的技术。它可以帮助 WebRTC 穿透 NAT(网络地址转换)和防火墙,从而实现实时音视频通信。ICE 的核心原理是通过尝试多种可能的网络地址和端口组合,找到一条最佳的通信路径。

在 ICE 中,每个网络地址和端口组合被称为一个候选地址(candidate)。候选地址分为三种类型:

  1. 主机候选地址 :来自本地设备的 IP 地址和端口。
  2. 服务器反射候选地址 :通过 STUN 服务器获取的公网 IP 地址和端口。
  3. 中继候选地址 :通过 TURN 服务器获取的中继 IP 地址和端口。

ICE 通过以下步骤进行连接建立:

  1. 收集候选地址 :客户端收集自己的所有候选地址(主机、服务器反射和中继地址)。
  2. 交换候选地址 :通过 SDP 交换,通信双方互相告知自己的候选地址。
  3. 连接检测 :客户端使用收到的对方候选地址和自己的候选地址进行连接测试,找到一条可用的通信路径。
  4. 选取最佳路径 :客户端根据连接测试的结果,选取一条最佳的通信路径。

2.2 ICE 的组件:STUN 和 TURN

ICE 主要包括两个组件:STUN(Session Traversal Utilities for NAT)和 TURN(Traversal Using Relays around NAT)。

  1. STUN(Session Traversal Utilities for NAT)
    STUN 是一种帮助客户端穿透 NAT 的协议。当客户端位于 NAT 后时,它可以向 STUN 服务器发送请求,获取自己的公网 IP 地址和端口(即服务器反射地址)。然后,客户端将这些地址作为候选地址之一,用于 ICE 连接建立。
    STUN 服务器通常部署在公网上,以便客户端可以访问。WebRTC 支持的 STUN 协议包括:RFC 3489(Classic STUN)和 RFC 5389(STUN for ICE)。
  2. TURN(Traversal Using Relays around NAT)
    TURN 是一种用于在无法直接建立点对点连接时,通过中继服务器进行通信的协议。当客户端无法直接与对方建立连接时(例如,双方都位于对称 NAT 后),它可以请求 TURN 服务器为自己分配一个中继地址。然后,客户端将这个地址作为候选地址之一,用于 ICE 连接建立。当通信双方选中中继地址作为最佳路径时,它们的通信数据将通过 TURN 服务器中继传输。
    TURN 服务器通常部署在公网上,以便客户端可以访问。WebRTC 支持的 TURN 协议包括:RFC 5766(TURN)和 RFC 6062(TURN for TCP)。

通过 STUN 和 TURN 这两个组件,ICE 可以帮助 WebRTC 穿透各种复杂的网络环境,实现稳定、高效的实时音视频通信。在接下来的两章中,我们将详细讲解 STUN 协议 和 TURN 协议的原理和用法。

3. STUN (Session Traversal Utilities for NAT)

3.1 STUN 协议简介

STUN(Session Traversal Utilities for NAT)是一种网络协议,用于解决网络地址转换(NAT)环境下的通信问题。它的主要作用是帮助客户端发现自己在NAT后面的地址和端口,以便在P2P通信中建立连接。

STUN在WebRTC中扮演着重要的角色。WebRTC是一项用于浏览器之间实时通信的技术,涉及音视频通话、文件共享等场景。然而,由于NAT的存在,直接在NAT后面的设备之间建立P2P连接变得困难。这时候,STUN协议通过帮助设备发现自己的公网IP地址和端口,以及NAT类型等信息,为WebRTC提供了解决NAT穿越的基础。

STUN消息是基于二进制格式的,具有一定的结构和字段。它通常包含以下几个重要的部分:

项目描述
消息头(Message Header)包含STUN消息的类型、长度和事务ID等信息。
消息体(Message Body)包含具体的属性信息,用于传递额外的数据。
消息类型(Message Type)表示消息的目的和作用,包括请求消息和响应消息等类型。
属性(Attributes)包含在消息体中,用于传递特定的数据,例如地址、端口、NAT类型等。

STUN消息的格式和字段是通过字节序列进行编码和解码的,具体的格式和字段取决于协议规范的定义。

3.2 STUN 的工作流程

STUN协议涉及客户端与服务器之间的交互流程,用于获取客户端在NAT后面的地址和端口信息。以下是STUN协议的基本流程:

序号步骤描述
1客户端发起请求客户端向 STUN 服务器发送一个 Binding Request 消息,请求获取自己的公网 IP 地址和端口。
2STUN 服务器处理请求STUN 服务器收到 Binding Request 消息后,解析客户端的公网 IP 地址和端口。这些信息可以从收到的请求数据包中获取。
3服务器响应STUN 服务器将客户端的公网 IP 地址和端口打包成一个 Binding Response 消息,并将该消息发送回客户端。
4客户端处理响应客户端收到 Binding Response 消息后,解析出自己的公网 IP 地址和端口。然后,将这些地址作为候选地址之一,用于 ICE 连接建立。
5周期性检测为了应对网络环境的变化,客户端需要周期性地向 STUN 服务器发送 Binding Request 消息,以获取最新的公网 IP 地址和端口。

STUN协议的流程可以帮助客户端绕过NAT,获得公网可达的地址和端口信息,从而实现更可靠和高效的实时通信。通过以上步骤,STUN 协议帮助客户端获取自己的公网 IP 地址和端口,并将这些地址用于 WebRTC 的 ICE 连接建立过程。这使得 WebRTC 能够在复杂的网络环境中实现稳定、高效的实时音视频通信。

3.3 STUN JavaScript 编程

3.3.1 发送和接收STUN消息

在 WebRTC 中,STUN 消息的发送和接收通常是通过 RTCPeerConnection 对象自动处理的。RTCPeerConnection 对象会根据提供的 STUN 服务器配置自动发送 STUN 绑定请求并处理响应。
以下是具体的步骤:

配置 STUN 服务器: 首先,你需要配置 STUN 服务器的地址和端口。这些信息将作为 RTCPeerConnection 对象的配置参数。

const stunServerConfig = {
  iceServers: [
    {
      urls: 'stun:stun.rixtelecom.se',
    },
  ],
};

创建 RTCPeerConnection 对象: 使用 STUN 服务器配置创建一个 RTCPeerConnection 对象。

const peerConnection = new RTCPeerConnection(stunServerConfig);

触发 ICE 候选收集: 为了让 RTCPeerConnection 对象与 STUN 服务器进行交互并收集 ICE 候选信息,你需要创建一个数据通道或媒体流,并设置 SDP 描述。

// 创建一个空的 DataChannel,用于触发 ICE 候选收集
peerConnection.createDataChannel('');

// 创建并设置 Offer SDP
peerConnection
  .createOffer()
  .then((offer) => peerConnection.setLocalDescription(offer));

监听 ICE 候选事件: RTCPeerConnection 对象会自动发送 STUN 绑定请求并处理 STUN 响应。你需要监听 onicecandidate 事件以获取 ICE 候选信息。

peerConnection.onicecandidate = function (event) {
  if (event.candidate) {
    console.log('ICE 候选:', event.candidate);
  } else {
    // ICE 候选收集完成
    console.log('ICE 候选收集完成');
  }
};

在这个过程中,RTCPeerConnection 对象会自动处理与 STUN 服务器的交互,包括发送 STUN 绑定请求和接收 STUN 响应。你不需要手动构造、发送或接收 STUN 消息。你只需要关注 ICE 候选事件,从中获取公网 IP 地址和端口信息。

一些补充:

  • STUN 协议不是基于 HTTP 的:
    STUN 是一个基于 UDP 或 TCP 的传输层协议,而不是基于 HTTP 的应用层协议。因此使用 XMLHttpRequest 对象尝试向 STUN 服务器发送请求是不合适的,同样也不能使用 基于XMLHttpRequest 封装的模块进行请求,如使用 axios。在浏览器种,你需要使用 WebRTC API 中专用的的 RTCPeerConnection 对象来处理 STUN 服务器的交互,如上面所介绍的。

3.3.2 STUN 公共服务器

公共STUN服务器是由第三方提供并开放给公众使用的服务器。这些服务器已经配置好并且可以处理STUN请求和响应。为了使用公共STUN服务器,我们需要配置服务器的地址和端口,并将其用于发送STUN请求。

在这里,已经为各位读者找到了一些免费的公共 stun 服务器:

stun.l.google.com:19302
stun1.l.google.com:19302
stun2.l.google.com:19302
stun3.l.google.com:19302
stun4.l.google.com:19302
stun.iptel.org
stun.rixtelecom.se
stun.voiparound.com
stun01.sipphone.com
stun.ekiga.net
stun.schlund.de
stun.voipbuster.com
stun.voipstunt.com
stun.voxgratia.org
stun.xten.com
stunserver.org
stun.softjoys.com
stun.fwdnet.net
stun.ideasip.com

如果有读者搭建 stun 服务器愿意公开使用也可以在留言区评论。

例如:

// STUN服务器地址和端口
var configuration = {
  iceServers: [
    {
      urls: 'stun:stun.l.google.com:19302'
    }
  ]
};

// 创建RTCPeerConnection对象,并传递配置对象
var peerConnection = new RTCPeerConnection(configuration);

// 创建一个虚拟的数据通道,以触发STUN服务器的连接
var channel = peerConnection.createDataChannel('stun-channel');

// 监听onicecandidate事件,获取本地候选地址
peerConnection.onicecandidate = function(event) {
  if (event.candidate) {
    // 处理ICE候选地址,获取IP地址信息
    var ip = event.candidate.address;
    console.log('本地IP地址:', ip);
  }
};

// 创建一个空的SDP描述,触发ICE候选地址的收集
peerConnection.createOffer().then(function(offer) {
  // 设置本地SDP描述
  return peerConnection.setLocalDescription(offer);
}).catch(function(error) {
  console.log('创建offer失败:', error);
});

在这里插入图片描述

3.4 RTCPeerConnection API 解析

3.4.1 概述

RTCPeerConnection APIWebRTC 的核心组件,它代表了从本地计算机到远程对等方的 WebRTC 连接,在后面的 TURN 协议种也会用到。该接口提供了创建、保持、监控和关闭连接的方法实现。其主要功能包括:

功能描述
创建连接通过构造函数 new RTCPeerConnection() 创建一个新的 RTCPeerConnection 实例,它接受一个可选的配置对象,例如 STUN/TURN 服务器信息。
媒体流和数据通道API 提供了将本地和远程媒体流附加到连接的方法(如 addTrack()addTransceiver() 方法),以及创建数据通道(createDataChannel()方法)。
SDP 交换RTCPeerConnection 提供了创建(createOffer()createAnswer()方法)和设置(setLocalDescription()setRemoteDescription()方法 )SDP 描述的方法,以进行信令交换。
ICE 候选收集API 自动处理与 STUN/TURN 服务器的交互,如收集和发送 ICE 候选。可以通过监听 onicecandidate 事件来获取 ICE 候选信息。
连接状态RTCPeerConnection 提供了一些属性来监控连接状态,如 iceConnectionState、iceGatheringState 和 connectionState。

3.4.2 属性

属性描述
connectionState表示连接的当前状态,例如 newconnectingconnecteddisconnectedfailedclosed
currentLocalDescription表示当前连接的本地 SDP 描述
currentRemoteDescription表示当前连接的远程 SDP 描述
iceConnectionState表示 ICE 连接的当前状态,例如 newcheckingconnectedcompletedfaileddisconnected
iceGatheringState表示 ICE 候选收集的当前状态,例如 newgatheringcomplete
localDescription表示已经应用到连接的本地 SDP 描述
pendingLocalDescription表示在等待应用到连接的本地 SDP 描述
pendingRemoteDescription表示在等待应用到连接的远程 SDP 描述
remoteDescription表示已经应用到连接的远程 SDP 描述
sctp表示连接的 SCTP 传输对象

3.4.3 方法

方法总览

方法描述
addIceCandidate()向连接添加一个新的 ICE 候选。
addTrack()向连接添加一个媒体轨道。
addTransceiver()向连接添加一个新的 RTP 发送器/接收器对。
close()关闭连接。
createAnswer()创建一个 SDP 应答。
createDataChannel()创建一个新的数据通道。
createOffer()创建一个 SDP 提议。
getConfiguration()获取连接的当前配置。
getReceivers()获取连接的所有 RTCRtpReceiver 对象。
getSenders()获取连接的所有 RTCRtpSender 对象。
getStats()获取连接的统计信息。
getTransceivers()获取连接的所有 RTCRtpTransceiver 对象。
removeTrack()从连接中移除一个媒体轨道。
restartIce()重新启动 ICE 过程。
setConfiguration()设置连接的配置。
setLocalDescription()设置本地 SDP 描述。
setRemoteDescription()设置远程 SDP 描述。

addIceCandidate():向连接添加一个新的 ICE 候选

peerConnection.onicecandidate = function(event) {
  if (event.candidate) {
    remotePeerConnection.addIceCandidate(event.candidate)
      .then(function() {
        console.log("添加 ICE 候选成功");
      })
      .catch(function(error) {
        console.error("添加 ICE 候选失败", error);
      });
  }
};

addTrack():向连接添加一个媒体轨道

navigator.mediaDevices.getUserMedia({ audio: true, video: true })
  .then(function(stream) {
    stream.getTracks().forEach(function(track) {
      peerConnection.addTrack(track, stream);
    });
  });

addTransceiver():向连接添加一个新的 RTP 发送器/接收器对

const transceiver = peerConnection.addTransceiver("audio");

close():关闭连接

peerConnection.close();
createAnswer():创建一个 SDP 应答。
peerConnection.createAnswer()
  .then(function(answer) {
    return peerConnection.setLocalDescription(answer);
  })
  .then(function() {
    // 发送 answer 到远程对等端
  })
  .catch(function(error) {
    console.error("创建应答失败", error);
  });

createDataChannel():创建一个新的数据通道

const dataChannel = peerConnection.createDataChannel("myDataChannel");

createOffer():创建一个 SDP 提议

peerConnection.createOffer()
  .then(function(offer) {
    return peerConnection.setLocalDescription(offer);
  })
  .then(function() {
    // 发送 offer 到远程对等端
  })
  .catch(function(error) {
    console.error("创建提议失败", error);
  });

getConfiguration():获取连接的当前配置

const configuration = peerConnection.getConfiguration();
console.log(configuration);

getReceivers():获取连接的所有 RTCRtpReceiver 对象

const receivers = peerConnection.getReceivers();
console.log(receivers);

getSenders():获取连接的所有 RTCRtpSender 对象

const senders = peerConnection.getSenders();
console.log(senders);

getStats():获取连接的统计信息

peerConnection.getStats()
  .then(function(stats) {
    console.log(stats);
  });

getTransceivers():获取连接的所有 RTCRtpTransceiver 对象

const transceivers = peerConnection.getTransceivers();
console.log(transceivers);

removeTrack():从连接中移除一个媒体轨道

const senders = peerConnection.getSenders();
peerConnection.removeTrack(senders[0]);

restartIce():重新启动 ICE 过程

peerConnection.restartIce();

setConfiguration():设置连接的配置

const newConfiguration = { iceServers: [{ urls: "stun:stun.example.org" }] };
peerConnection.setConfiguration(newConfiguration);

setLocalDescription():设置本地 SDP 描述

peerConnection.createOffer()
  .then(function(offer) {
    return peerConnection.setLocalDescription(offer);
  })
  .catch(function(error) {
    console.error("设置本地描述失败", error);
  });

setRemoteDescription():设置远程 SDP 描述

// 假设 remoteOffer 是从远程对等端接收到的 SDP 提议
peerConnection.setRemoteDescription(remoteOffer)
  .then(function() {
    // 远程描述设置成功
  })
  .catch(function(error) {
    console.error("设置远程描述失败", error);
  });

3.4.4 事件处理程序

在 RTCPeerConnection 对象的上下文中,事件处理程序是在对象的特定属性发生变化时触发的函数。例如当 connectionState 属性发生变化时,onconnectionstatechange 事件处理程序将被触。

方法描述
onconnectionstatechangeconnectionState 属性发生变化时触发
ondatachannel当新的数据通道被创建时触发
onicecandidate当新的 ICE 候选可用时触发
onicecandidateerror是一个事件处理程序,它在 ICE 候选收集过程中出现错误时触发。当 WebRTC 使用 ICE 框架在对等连接中建立连接时,它会收集可用的网络候选(即可能的网络地址和端口)并与远程对等方交换这些候选。如果在收集或处理这些候选时发生错误,onicecandidateerror 事件处理程序将被触发。
oniceconnectionstatechangeiceConnectionState 属性发生变化时触发
onicegatheringstatechangeiceGatheringState 属性发生变化时触发。iceGatheringState 属性表示 ICE 候选收集过程的当前状态,可能的值包括:new、gathering 和 complete。
onnegotiationneeded当需要重新协商连接时触发
onsignalingstatechange是收到 signalingstatechange 事件时调用的事件处理器,当signalingState的值发生改变时,该事件被触发。
onstatsended当统计信息结束时触发
ontrack当新的媒体轨道被添加到连接时触发

例如:

const pc = new RTCPeerConnection();

pc.onconnectionstatechange = function (event) {
  console.log("连接状态已更改为:", pc.connectionState);

  if (pc.connectionState === "connected") {
    console.log("连接建立!");
  } else if (pc.connectionState === "failed") {
    console.error("连接失败!");
  }
};

// 其他 RTCPeerConnection 代码...

本例中,当连接状态发生变化时,会将新的状态记录到控制台。

  • 如果连接成功建立,将输出 “连接建立!”;
  • 如果连接失败,则输出 “连接失败!”。

又如:

const pc = new RTCPeerConnection();

pc.onicecandidateerror = function (event) {
  console.error("ICE候选错误:", event);
  // 在这里处理错误,例如向用户显示错误消息
};

// 其他 RTCPeerConnection 代码...

这个例子中,当发生 ICE 候选错误时,将错误事件记录到控制台。

再如:

const pc = new RTCPeerConnection();

pc.onicegatheringstatechange = function (event) {
  console.log("ICE收集状态已更改为:", pc.iceGatheringState);

  if (pc.iceGatheringState === "gathering") {
    console.log("ICE开始收集。");
  } else if (pc.iceGatheringState === "complete") {
    console.log("ICE收集完成。");
    // 在这里处理收集完成后的操作,例如发送ICE候选给远程对等方
  }
};

// 其他 RTCPeerConnection 代码...

这个例子中,当 ICE 收集状态发生变化时,会将新的状态记录到控制台。

  • 如果收集开始,将输出 “ICE开始收集。”;
  • 如果收集完成,则输出 “ICE收集完成。”。

4. TURN (Traversal Using Relays around NAT)

4.1 TURN 协议简介

TURN(Traversal Using Relays around NAT)是一种用于在 NAT(网络地址转换)环境中实现穿越的协议。在某些情况下,STUN 服务器无法帮助客户端建立直接的 P2P 连接。这时,TURN 协议就派上了用场。TURN 协议通过在客户端之间引入一个中继服务器来传输数据,从而实现 WebRTC 通信。

TURN 的原理是在客户端之间建立一个中继服务器,用于转发音频、视频和数据流。当客户端无法直接建立 P2P 连接时,TURN 服务器会充当中继节点,将数据从一个客户端转发到另一个客户端。这样,即使客户端位于复杂的 NAT 环境中,也能实现实时音视频通信。

4.2 TURN 的工作流程

TURN 的工作流程主要分为以下几个步骤:

序号步骤描述
1客户端发起请求客户端向 TURN 服务器发送一个 Allocate Request 消息,请求分配一个中继地址。
2TURN 服务器处理请求TURN 服务器收到 Allocate Request 消息后,为客户端分配一个中继地址(IP 地址和端口),并将该地址与客户端的公网地址绑定。
3服务器响应TURN 服务器将分配的中继地址打包成一个 Allocate Response 消息,并将该消息发送回客户端。
4客户端处理响应客户端收到 Allocate Response 消息后,解析出分配的中继地址。然后,将这些地址作为候选地址之一,用于 ICE 连接建立。
5数据转发ICE 连接建立过程中,如果客户端无法直接建立 P2P 连接,就会选择使用 TURN 服务器作为中继。此时,客户端将音频、视频和数据流发送到分配的中继地址,TURN 服务器再将这些数据转发给另一个客户端。
6周期性检测为了应对网络环境的变化,客户端需要周期性地向 TURN 服务器发送 Allocate Request 消息,以获取最新的中继地址。

通过以上步骤,TURN 协议帮助客户端在无法直接建立 P2P 连接的情况下,通过中继服务器实现实时音视频通信。这使得 WebRTC 能够在复杂的网络环境中实现稳定、高效的实时音视频通信。

4.3 TURN 相关编程实践

待补充

附. 积极拥抱 IPv6 的倡议

F.1 IPv4危机 之 地址耗尽

F.1.1 IPv4 地址的耗尽

拥有大约43亿个唯一地址的IPv4地址空间曾经被认为是绰绰有余的。然而,互联网的快速增长和互联网连接设备的激增导致了IPv4地址的短缺。互联网数字地址分配机构(IANA)在2011年分配了最后一个IPv4地址块,促使人们需要一个替代的寻址系统。

F.1.2 NAT 和 DHCP技术的应用

为了解决 IPv4 危机,开发了 网络地址转换(NAT)动态主机配置协议(DHCP) 等技术。NAT允许多个设备通过将私有IP地址转换为公共IP地址来共享一个公共IPv4地址。DHCP为网络上的设备动态分配IP地址,从而有效利用有限的IPv4资源。

这些技术缓解了 IPv4 危机,但它们不是长期的解决方案。

F.2 IPv4危机 之 安全担忧

F.2.1 美国控制下的 IPv4 跟根务器

美国对管理全球域名系统(DNS)的13个根服务器拥有重大控制权,其中10个位于US.DNS对于互联网的运行至关重要,因为它将人类可读的域名转换为IP地址。通过控制根服务器,美国有可能操纵或破坏全球互联网服务。

正如棱镜门事件所揭示,美国将网络战和监控作为其军事和情报行动的一部分。例如,被广泛认为是由美国和以色列开发的Stuxnet蠕虫病毒,目标就是伊朗的核program。此外,美国国家安全局(NSA)进行了广泛的全球监控。

美国对 IPv4 根服务器的控制及其对网络战和监控的参与引发了对全球安全和美国信任的担忧,尤其是棱镜门事件之后,包括默克尔等大量被视作美国盟友的西方国家政要被无差别监听的消息引来了全世界的指责。不仅是中国,同时包括美国在欧洲的盟友,对美国在互联网监管方面的主导地位以及美国利用这种控制为政治或军事目服务的可能性表示了广泛的担忧。

F.2.2 美国对IPv4根服务器控制的妥协

作为对这些担忧的回应,2016年年美国政府允许其与互联网名称与数字地址分配机构(ICANN)的合同到期,有效地将互联网数字地址分配机构(IANA)职能的监督权转移给了全球多利益主体社区。

F.2.3 不安全因素并未抹去

尽管美国已经通过允许与 ICANN 的合同到期来减少对互联网治理的控制,但由于 ICANN 与美国的联系、互联网治理中透明度和包容性的缺失、持续的网络战和监控活动以及地缘政治紧张局势加剧,全球担忧仍然存在。

  1. ICANN 与美国的联系: 虽然美国政府在 2016 年允许与 ICANN 的合同到期,将 IANA 功能的监督转交给全球多方利益攸关者社区,但由于 ICANN 与美国的历史和法律联系,人们仍然感到担忧。ICANN 是一家总部位于加利福尼亚的非营利组织,其法律管辖区在美国。这种联系引发了关于美国政府可能仍然对 ICANN 及其决策过程施加影响的问题。

  2. 互联网治理透明度和包容性的缺失: 尽管似乎美国已经让多方利益攸关者参与其中,但当前的互联网治理模式仍缺乏足够的透明度和包容性。西方国家和企业在互联网治理机构(如 ICANN)中的主导地位加剧了这些担忧,导致人们呼吁在互联网治理中实现权力更加公平的分配。

  3. 持续的网络战和监控活动: 美国参与了网络战和全球监控,例如 Stuxnet(蠕虫病毒) 和 Prism Gate(棱镜门) 等事件。这些活动导致其他国家,特别是与美国关系紧张的国家,感到不信任和不安。即使美国已经努力减少对互联网治理的控制,其持续参与网络活动仍可能加剧担忧。

  4. 地缘政治紧张局势和数字主权的推动: 美国和中国等大国之间日益加剧的地缘政治紧张局势导致了对数字主权的推动。各国寻求更大程度地控制其国内互联网基础设施,以保护国家利益,减少对外国实体的依赖,并降低因互联网资源集中控制而产生的潜在风险。

种种这些因素导致了对数字主权的推动和替代互联网基础设施的发展,例如中国采用 IPv6。

F.3 中国 IPv6 发展历程

中国IPv6的发展历程可以分为以下几个阶段:

  1. 早期探索阶段:中国在1990年代末期开始关注IPv6技术。在2003年,中国互联网协会IPv6工作组成立,标志着中国正式启动IPv6技术研究和试验工作。
  2. 积极推进阶段:2017年,中国政府发布了《推进互联网协议第六版(IPv6)规模部署行动计划》,明确了IPv6的发展方向和阶段目标。此后,中国在IPv6的建设和发展上取得了显著成果,如2020年10月,IPv6活跃用户数达到4.37亿,占比48.30%。
  3. 规模化部署阶段:2021年,中国IPv6发展取得明显进展,如IPv6活跃用户数持续上升,LTE网络和宽带接入网络大规模分配IPv6地址。

F.4 《推进互联网协议第六版(IPv6)规模部署行动计划》的出台

国内早期各大路由设备厂商默认关闭 IPv6 因为当时各大厂商 IPv6 尚未达到与IPv4一样的体验。但是目前 IPv6 相关技术已经成熟,如果所有厂商持续采取消极态度不利于国家安全和国家战略。积极推动 IPv6 的发展,不仅有助于提升国家竞争力和网络主权,还能推动数字经济和信息产业的发展。

日前 IPv6 已成为全球互联网发展的趋势,包括中国在内的各国都纷纷推动 IPv6 的部署。中国希望通过积极推广 IPv6,提升国家的国际竞争力,并在互联网领域的技术创新上占据重要地位。《推进互联网协议第六版(IPv6)规模部署行动计划》(以下简称“该计划”)。

在该计划提出的目标之一是:

“到2025年末,我国IPv6网络规模、用户规模、流量规模位居世界第一位,网络、应用、终端全面支持IPv6,全面完成向下一代互联网的平滑演进升级,形成全球领先的下一代互联网技术产业体系。”

目前国家正在努力升级改造广电网络。“以全国有线电视互联互通平台建设为契机,加快推动广播电视领域平台、网络、终端等支持IPv6,促进文化传媒领域业务创新升级。”

作为普通开发者,不论是站在技术发展的大潮流,还是响应国家号召,都应该积极拥抱国家政策,响应国家号召,针对 IPv6 技术做必要的学习、了解以及应用于生产实践。

F.5 从 WebRTC 角度看 IPv6

IPv6 技术为 WebRTC 带来了诸多变革,包括更多的地址空间、改进的连接建立、更好的网络性能、增强的安全性和更好的移动性。这些变革有助于提高 WebRTC 在实时通信场景中的可靠性和性能:

  1. 更多的地址空间: IPv6 提供了几乎无限的地址空间,这意味着每个设备都可以拥有一个唯一的公共 IP 地址。在 WebRTC 的场景中,这消除了 NAT(网络地址转换)的需要,从而简化了端到端通信的建立过程。在 IPv4 中,NAT 通常会导致连接失败或者需要额外的技术(如 STUN、TURN 服务器)来解决这些问题。

  2. 改进的连接建立: 由于 IPv6 减少了 NAT 的使用,WebRTC 中的连接建立过程可以更加简便,降低了连接失败的可能性。同时,IPv6 支持端到端的直接通信,可以提高连接质量和性能。

  3. 更好的网络性能: IPv6 提供了一些改进的网络功能,如流标签、IPv6 分片和底层 QoS(Quality of Service)支持。这些功能有助于提高 WebRTC 通话的质量和稳定性。

  4. 增强的安全性: IPv6 支持 IPsec(Internet Protocol Security),这是一种用于在 IP 层加密和认证数据的协议。在 WebRTC 场景中,这可以提供更强大的安全性,保护通信不被窃听或篡改。

  5. 更好的移动性: IPv6 支持移动 IPv6(MIPv6)技术,允许设备在不同网络间无缝漫游。对于 WebRTC 来说,这意味着用户在移动过程中可以更容易地保持音视频通话的稳定性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/666627.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Flutter——复选框实例代码超详细讲解!】

Flutter——复选框实例代码超详细讲解! 文章目录 Flutter——复选框实例代码超详细讲解!代码实现效果代码实例代码结构总结 代码实现效果 代码实例 import package:flutter/material.dart; // 导入 Flutter 的核心库void main() {runApp(const MyApp())…

linux-2.6.22.6内核poll总结

1.为什么需要poll,其原因是当进行某些操作时,该操作会一直消耗cpu,浪费资源,所以引入poll可以让该进程在指定时间内如果没有结果产生(可以是某个操作或者获取数据)则进行休眠,这样就会释放cpu。…

【MySQL】数据库基础 ②

✍LIKE 子句 说明: 使用 SELECT 来查询数据, 同时我们可以在 SELECT 语句中使用 WHERE 子句来获取指定的记录。 WHERE 子句中可以使用等号 来设定获取数据的条件,如 "字段(text_title) 值()"。 但是有时候我们需要获取 text_…

Android 神奇的 SpannableStringBuilder

文章目录 前言一、SpannableStringBuilder 是什么?二、使用步骤1.示例代码2.参数对应start:样式生效的开始位置,包括该位置end: 样式结束的位置,不包括该位置flags:取值有如下四个Spannable.SPAN_EXCLUSIVE…

wandb快速上手、使用心得(超好用的Tensorboard高替品)

这里写目录标题 1 wandb介绍2 快速上手3 使用心得3.1 一张图展示两条线3.2 想要科学上网和wandb一起使用(离线使用)3.3 未完待续 1 wandb介绍 wandb地址:wandb Wandb(Weights & Biases)是一个用于机器学习实验跟踪…

智慧城市建设电气火灾智慧消防措施 安科瑞 许敏

1、引言 “经检测,发现管辖单位南通王子造纸企业二氧化氯装置发生二级警报,可能引发火灾,请立即出警。”日前,南通消防救援支队大数据平台DCS化工火源预警系统发出警报,大屏幕显示辖区企业南通王子造纸企业出现险情。D…

B站618“杀”疯了?UP主直播带货GMV连年破亿!

众多主流平台已经早早构建出较为完整的直播带货体系,而B站则是从去年双十一才宣布正式加入全平台直播带货,同时上线购物直播专区,到今年618年中购物大促,B站已经在大步向前摸索属于本平台的直播带货阵营。 一直以来B站带着二次元…

TC8:SOMEIPSRV_FORMAT_15-18

SOMEIPSRV_FORMAT_15: Instance ID field of the Type 1 Entry 目的 检查Type 1 Entry(Offer Service)的“Instance ID”字段 测试步骤 DUT CONFIGURE:启动具有下列信息的服务Service ID:SERVICE-ID-1Instance数量:1Tester:客户端-1发送SOME/IP Notification消息Entry T…

后端web开发之maven

这里写目录标题 介绍创建maven项目作用作用1作用2作用3 简介 依赖管理依赖配置依赖传递简介依赖传递的可视化快捷键 排除依赖依赖范围生命周期介绍执行流程 介绍 创建maven项目 注意 maven属于项目一级,所以在创建项目的时候 直接选择maven项目按照步骤创建即可&a…

Java Web基础面试题整理

1、什么是Servlet? 可以从两个方面去看Servlet: a、API:有一个接口servlet,它是servlet规范中定义的用来处理客户端请求的程序需要实现的顶级接口。 b、组件:服务器端用来处理客户端请求的组件,需要在we…

【2023,学点儿新Java-12】小结:阶段性复习 | Java学习书籍推荐(小白该读哪类Java书籍?有一定基础后,再去读哪类书籍?)

前情回顾: 【2023,学点儿新Java-11】基础案例练习:输出个人基础信息、输出心形 | Java中 制表符\t 和 换行符\n 的简单练习【2023,学点儿新Java-10】Java17 API文档简介&获取 |详解Java核心机制:JVM |详解Java内存…

【FPGA入门】第六篇、异步串口通信

目录 第一部分、相关知识 1、UART和RS232的区别 2、UART与USART的区别 3、全双工? 4、RS232通信协议 5、波特率 6、如何将外部异步信号变为内部同步信号? 7、什么时间点让FPGA去采集rx线上的数据? 第二部分、串口通信时序图 1、…

OWASP之SSRF服务器伪造请求

文章目录 一、SSRF定义二、形成原因1.提供请求功能2.地址没做限制 三、漏洞危害1.可以对服务器所在内网、本地进行端口扫描,获取一些服务的信息等2.目标网站本地敏感数据的读取3.内外网主机应用程序漏洞的利用4.内外网Web站点漏洞的利用 四、ssrf挖掘1.从WEB功能上寻…

SpringBoot相关知识

SpringBoot知识 1 SpringBoot 介绍及其使用原因 Spring Boot是一个用于创建独立的、基于Java的生产级别的应用程序的框架。它旨在简化Spring应用程序的开发过程,减少开发人员的配置工作,从而提高开发效率。 原因: (1) 简化开发:Spring Boot…

Hadoop(HA)

文章目录 1、HA 概述2、HDFS-HA 集群搭建3、HDFS-HA 核心问题4、HDFS-HA 手动模式4.1 环境准备4.2 规划集群4.3 配置 HDFS-HA 集群4.4 启动 HDFS-HA 集群 5、HDFS-HA 自动模式5.1 HDFS-HA 自动故障转移工作机制5.2 HDFS-HA 自动故障转移的集群规划5.3 配置 HDFS-HA 自动故障转移…

java企业工程项目管理系统平台源码

工程项目管理软件(工程项目管理系统)对建设工程项目管理组织建设、项目策划决策、规划设计、施工建设到竣工交付、总结评估、运维运营,全过程、全方位的对项目进行综合管理 工程项目各模块及其功能点清单 一、系统管理 1、数据字典&#…

基于pyqt5、mysql、yolov7、chatgpt的小麦病害检测系统的设计与实现(基础版)

基于pyqt5、mysql、yolov7、chatgpt的小麦病害检测系统设计与实现 一、界面设计1.1安装pyqt51.2创建用户子窗体1.3创建管理员主窗体1.4创建管理员子窗体1.5创建系统登陆界面 二、环境搭建2.1pyqt5工具配置2.2mysql5.7安装 三、编程实现3.1初始化数据库3.2创建用户数据库sdk文件…

从零构建后端项目-配置Shiro+JWT

目录 Shiro和JWT技术 一、Shiro简介 什么是认证? 什么是授权? Shiro靠什么做认证与授权的? 二、JWT简介 JWT可以用在单点登录的系统中 JWT兼容更多的客户端 创建JwtUtil工具类 一、导入依赖库 二、定义密钥和过期时间 三、创…

强大的Kotlin也能搞定,测试利器MockK你不能不知道

目录 前言: 为什么需要MockK 关键字 Mock Kotlin的类时报错 静态方法如何Mock Jmockit MockK使用示例 普通使用 mockkObject mockkStatic mock private method Context Mock 遇到的一些小坑 最后 前言: MockK是一个强大且易于使用的Kotli…

爆肝整理,手机App接口测试大全指南,看这篇就够了...

目录:导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 App和Web请求服务…