当前位置: 首页 > news >正文

虚拟电子商务网站建设前期规划方案苏州专业网站建设

虚拟电子商务网站建设前期规划方案,苏州专业网站建设,电商系统平台,工业设计公司简介内核-用户空间鸿沟 构建自己的 TCP栈是一项极具挑战的任务。通常#xff0c;当用户空间应用程序需要互联网连接时#xff0c;它们会调用操作系统内核提供的高级 API。这些 API 帮助应用程序 连接网络创建、发送和接收数据#xff0c;从而消除了直接处理原始数据包的复杂性。…内核-用户空间鸿沟 构建自己的 TCP栈是一项极具挑战的任务。通常当用户空间应用程序需要互联网连接时它们会调用操作系统内核提供的高级 API。这些 API 帮助应用程序 连接网络创建、发送和接收数据从而消除了直接处理原始数据包的复杂性。这是开发标准应用程序的绝佳选择。 然而当您打算构建自定义 TCP 栈时事情就会变得棘手。为了实现自定义TCP 栈您不仅仅是网络服务的消费者还必须是管理者、处理者和调度者。这意味着需要直接与原始网络数据包交互并处理它们然后将它们发送到各自的目的地。本质上您必须绕过操作系统的内置 TCP 栈才能在用户空间 TCP 栈中直接接收和处理来自网络的原始数据包。 为了能够实现[在用户空间]处理原始网络数据包需要设置一个虚拟网络接口。虚拟网络接口将“欺骗”内核将传入数据包直接传递给它就像物理 NIC网络接口卡一样但内核不会干预原始数据包处理。对于这个小技巧我们将使用 Linux TUN/TAP 设备驱动程序专注于 TUN网络来启动我们的虚拟网络接口。 从本质上讲TUN 设备是一个存在于操作系统内核中的基于软件的[虚拟]网络接口。该虚拟网络接口的行为与物理网络接口非常相似但它不依赖于物理硬件。 TUN 设备在 OSI 模型的第 3 层运行并向任何需要发送或接收数据包的应用程序公开文件描述符。 一旦启动并运行了 TUN 设备任何针对其 关联 IP 地址的数据包都将被内核重定向内核不过问任何问题不处理任何数据包直接进入已将自身绑定到的用户空间应用程序的怀抱中的TUN 设备。这种设置为我们提供了全权委托我们可以随心所欲地处理原始数据包。 linux Tun/Tap 原理 注意tun0 直接把数据包转发给了 User Application B这样User Application B 就会接收到原始数据 数据包处理工作流程TUN 设备与标准网络堆栈 StepWith TUN Device TUNWithout TUN Device1Packet arrives at physical NIC.数据包到达物理网卡。Packet arrives at physical NIC.数据包到达物理网卡。2Kernel’s routing sends packet to TUN.内核的路由将数据包发送到TUN。Kernel’s network stack processes packet.内核的网络堆栈处理数据包。3Packet forwarded to TUN device.数据包转发到 TUN 设备。Packet may be filtered, NAT’d, etc.数据包可能会被过滤、NAT 等。4User-space app reads packet from TUN.用户空间应用程序从 TUN 读取数据包。OS passes packet to appropriate socket操作系统将数据包传递到适当的套接字5User-space stack processes packet.用户空间堆栈处理数据包。Application reads packet from socket.应用程序从套接字读取数据包。6Optional: User-space modifies packet.可选用户空间修改数据包。N/A 不适用7Optional: Packet sent out via TUN.可选通过 TUN 发送的数据包。N/A 不适用8Kernel routes the outgoing packet.内核路由传出数据包。Kernel routes the outgoing packet.内核路由传出数据包。 With a TUN Device: TUN 设备内核执行的工作最少。它将数据包转发到 TUN 设备允许用户空间应用程序我们的 TCP 应用程序处理大部分数据包处理包括可选的修改和潜在的重传。 Without a TUN Device: 非TUN 设备内核自己的网络堆栈完全处理数据包包括任何路由、过滤和 NAT 操作。应用程序只是从套接字读取数据包从底层细节中抽象出来。 现在理解了为什么需要使用 TUN 设备可以开始编写一些代码了。可以通过运行创建一个全新的 Rust 项目。 cargo new blah blaj我们将使用 TunTap crate 它是 Tun/Tap 驱动程序的 Rust 包装。要将其添加到项目中只需将以下行添加到 Cargo.Toml 文件中。 tun-tap 0.1.4use std::io;fn main() - io::Result() {// Create a new TUN interface named tun0 in TUN mode.let nic tun_tap::Iface::new(tune, tun_tap::Mode::Tun)?;// Define a buffer of size 1504 bytes (maximum Ethernet frame size without CRC) to store received data.let mut buf [0u8; 1504];// Main loop to continuously receive data from the interface.loop {// Receive data from the TUN interface and store the number of bytes received in nbytes.let nbytes nic.recv(mut buf[..])?;eprintln!(read {} bytes: {:x?}, nbytes, buf[..nbytes]);}Ok(()) }使用 cargo b --release 构建二进制文件后需要提升编译后的二进制文件的权限。通过运行 sudo setcap cap_net_admineip ./target/release/tcp 来实现这一点。这授予二进制文件操作网络接口和路由表所需的权限。 一旦执行了二进制文件就会创建一个名为“tun0”的新虚拟网络接口。为了验证它的存在可以运行 ip addr 它应该显示所在机器上所有网络接口的列表包括新创建的“tun0”它通常位于列表的底部如下所示。 4: tun0: POINTOPOINT,MULTICAST,NOARP mtu 1500 qdisc noop state DOWN group default qlen 500 link/none 但要注意此时它没有 IP 地址。所以不能向它发送任何数据包。为了解决这个问题可以执行 sudo ip addr add 192.168.0.1/24 dev tun0 给 创建的名为 tun0 的网络接口 分配 IP 地址 192.168.0.1 和子网掩码 255.255.255.0 由 /24 表示 。然后可以再次运行 ip addr 命令进行确认将看到如下所示的输出确认虚拟网络接口现在已附加一个 IP 地址现在可以 ping 并向其发送数据包。 4: tun0: POINTOPOINT,MULTICAST,NOARP mtu 1500 qdisc noop state DOWN group default qlen 500 link/none inet 192.168.0.1/24 scope global tun0 valid_lft forever preferred_lft forever接下来通过执行 sudo ip link set up dev tun0 激活网络接口。 现在我们已经准备好进行测试了。如果您还记得之前我们说过将在内核发送给用户空间程序中处理原始网络数据包那么现在看看它的实际情况。继续运行以下命令来 ping 虚拟网络接口或其中的任何子网。 [同时二进制文件仍在执行] ping - I tun0 192.168.0.2 您会注意到应用程序收到了一些原始字节。像下面这样的东西。这挺令人兴奋。 [0, 0, 86, dd, 60, 0, 0, 0, 0, 8, 3a, ff, fe, 80, 0, 0, 0, 0, 0, 0, 15, 62, d0, a2, 5c, 4e, c2, 45, ff, 2, 0, 0, 0, 0, 0, 0,0, 0, 0, 0, 0, 0, 0, 2, 85, 0, 78, 9e, 0, 0, 0, 0]]辅助脚本 为了方便操作可以编写整个过程的脚本 #!/bin/bash cargo b --release sudo setcap cap_net_admineip ./target/release/tcp ./target/release/tcp pid$1 sudo ip addr add 192.168.0.1/24 dev tun0 trap kill $pid INT TERM wait $pid参考 Virtual networking 101: Bridging the gap to understanding TAP 虚拟网络 101弥合理解 TAP 的差距Corresponding Code 对应代码 原文地址
http://www.w-s-a.com/news/563316/

相关文章:

  • 四川省建设厅官网信息查询平台北京seo关键词优化外包
  • 网站建设响应式是什么意思wordpress弹窗打开网页
  • 做美工需要参考的网站漳州做网站的公司
  • 用源码建设网站关于网站开发的自我评价
  • 网站设计师图片自助建站编辑器
  • 网站建设的常用技术有哪些深圳建筑工地招工
  • 做软装找图片的网站wordpress 替代
  • 制作网站的后台公众号做视频网站会封吗
  • 广西企业建站邯郸景区网站制作
  • 开发商城网站多少钱城厢区建设局网站
  • 网站外链多的危害天水市建设局网站
  • 网站接入商学交互设计网站
  • 目前最新的网站后台架构技术综述什么网站可以做名片
  • 成都建站长沙做网站美工的公司
  • 湖南省住房与城乡建设厅网站平顶山网站关键词优化
  • 购物网站前台功能模块汕头网站设计电话
  • 网站你懂我意思正能量免费wordpress菜单底部导航代码
  • 一个主机可以建设多少个网站山东高端网站建设
  • 长沙网站建设搭建网络营销做得好的公司
  • 如何做网站的后台管理石家庄seo关键词排名
  • 给自己公司做个网站山东做外贸网站的公司
  • 张家港网站建设培训江苏省建设工程网站系统
  • html个人网站桂林建站
  • 湛江网站优化快速排名wordpress文章页面宽度
  • 自己建网站怎么弄唯品会一家专门做特卖的网站
  • 做文化传播公司网站做搜狗pc网站点
  • 免费的黄冈网站有哪些平台可以聊天呢要查询一个网站在什么公司做的推广怎么查
  • 凡客建站登录入口网站建设先进部门评选标准
  • 响应式设计 手机网站政务中心建设网站
  • 如何做卖衣服的网站网站登录接口怎么做