Notes on HTTP-the Definitive Guide

Caching
  • HTTP allows a cache to send a “conditional GET” to the origin server, asking the server to send back an object body only if the document is different from the copy currently in the cache: If-Modified-Since, If-None-Match
  • But, despite some subtle details, the basic workings of a web cache are mostly simple- Receiving, Parsing, Lookup, Freshness Check, Response creation, Sending and Logging.
  • HTTP/1.1 supports “weak validators,” which allow the server to claim “good enough” equivalence even if the contents have changed slightly.
  • Controlling Cachability: in decreasing order of priority, the server can:
    • Attach a Cache-Control: no-store header to the response.
    • Attach a Cache-Control: no-cache header to the response.
    • Attach a Cache-Control: must-revalidate header to the response.
    • Attach a Cache-Control: max-age header to the response.
    • Attach an Expires date header to the response.
    • Attach no expiration information, letting the cache determine its own heuristic expiration date.
  • If the response doesn’t contain either a Cache-Control: max-age header or an Expires header, the cache may compute a heuristic maximum age.
  • Clients use Cache-Control request headers to tighten or loosen expiration constraints.
  • The HTTP specification provides a detailed, but slightly obscure and often confusing, algorithm for computing document aging and cache freshness.
  • RFC 2227(“Simple Hit-Metering and Usage-Limiting for HTTP”): servers get periodic updates from caches about the number of times cached documents were hit. In addition, the server can control how many times documents can be served from cache, or a wall clock timeout, before the cache must report back to the server.

Gateways

  • Gateways are described by their client- and server-side protocols, separated by a slash: <client-protocol>/<server-protocol>
  • Early web servers were fairly simple creations, and the simple approach that was taken for implementing an interface for gateways has stuck to this day.

Tunnel

  • Web tunnels let you send non-HTTP traffic through HTTP connections, allowing other protocols to piggyback on top of HTTP.
  • Web tunnels are established using HTTP's CONNECT method. But the HTTP/1.1 specification reserves the CONNECT method but does not describe its function.


03-19
### IEEE 802.1Q VLAN Tagging Protocol Standard IEEE 802.1Q 是支持虚拟局域网(VLAN)的标准协议之一,通常被称为 Dot1q。该标准定义了一种用于以太网帧的 VLAN 标记系统以及交换机和桥接器处理这些标记帧的操作流程[^2]。 #### 协议结构概述 IEEE 802.1Q 的核心功能在于通过在以太网数据帧中插入特定字段来实现 VLAN 标签的功能。这种标签使得网络设备能够识别哪些流量属于哪个 VLAN,并据此执行转发决策。具体来说: - **Tag Header**: 在原始以太网帧头部增加了一个额外的 4 字节字段作为 VLAN 标签头。这四个字节包含了以下部分: - **Priority Code Point (PCP)**: 使用 3 比特表示优先级级别,范围从 0 到 7,主要用于 QoS 控制。 - **Canonical Format Indicator (CFI)**: 这是一个单比特位,在传统以太网环境中设置为零。 - **VLAN Identifier (VID)**: 使用 12 比特标识具体的 VLAN ID,理论上可以支持多达 4096 个不同的 VLAN(编号从 0 至 4095),其中某些特殊值保留给内部用途或管理目的。 #### 数据包处理机制 当一个带有 VLAN tag 的数据包进入支持 IEEE 802.1Q 的交换机时,它会依据此标签决定如何路由或者过滤该数据流。如果目标端口不属于同一 VLAN,则不会传输至其他无关联的物理接口上;反之亦然——只有相同 VLAN 成员之间才允许互相通信除非经过路由器跨网段访问[^1]。 此外,为了简化管理和配置过程并增强互操作性,还引入了一些辅助性的子协议和服务组件比如 GARP(通用属性注册协议)。GARP 可帮助分发有关 VLAN 成员资格的信息到各个连接节点以便动态调整其行为模式而无需频繁手动干预[^3]。 以下是创建带 VLAN TAG 的 Python 示例代码片段展示如何模拟构建这样的 Ethernet Frame: ```python from scapy.all import Ether, Dot1Q, IP, sendp def create_vlan_packet(src_mac="00:aa:bb:cc:dd:ee", dst_mac="ff:ff:ff:ff:ff:ff", vlan_id=100, src_ip="192.168.1.1", dst_ip="192.168.1.2"): ether = Ether(src=src_mac, dst=dst_mac) dot1q = Dot1Q(vlan=vlan_id) ip_layer = IP(src=src_ip, dst=dst_ip) packet = ether / dot1q / ip_layer return packet packet = create_vlan_packet() sendp(packet, iface="eth0") # Replace 'eth0' with your network interface name. ``` 上述脚本利用 Scapy 库生成包含指定源地址、目的地址及所属 VLAN 编号的数据报文并通过选定的网卡发送出去测试实际效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值