Tor主循环源码解析

Tor笔记目录索引

主循环在启动前首先要

  • 注册信号(如常用的SIGINT
  • 初始化时间并注册时间时间
  • 初始化TLS key
  • 设置带宽限制
  • 触发启动控制事件(只会被调用一次)
  • 如果要启动目录服务器功能,则启动对应的功能(位于src/feature/dirauth/authmode.cint authdir_mode_v3(const or_options_t *options)函数)
  • 启动DNS映射服务
  • 正式启动主循环
  • 循环过程中会通过注册的事件来触发相应周期性服务

Tor带宽

在这里设置的Tor带宽涉及到BandwidthRateBandwidthBurstRelayBandwidthRateRelayBandwidthBurst四个torrc配置项

在这里流量控制使用令牌桶算法,并分别设置全局的令牌桶(global_bucket)与中继令牌桶(global_relayed_bucket),如果中继带宽未被设置,则将中继令牌桶设置为全局带宽的设置

其中,前两者是程序整体的带宽,后两者则是作为中继的带宽;同时,burst指峰值带宽,rate则是平均带宽1

目录服务器

目录服务器主要用于获取Tor的一些中继信息
在Tor里,可以在torrc中将AuthoritativeDirectoryV3AuthoritativeDirectory设置为1从而可以让Tor作为目录服务器提供服务

周期性服务

主循环本身不执行操作,所有操作都先注册为周期性服务(periodic events),并在主循环中逐个调用

注册周期性服务在src/core/mainloop/periodic.cvoid periodic_events_register(periodic_event_item_t *item)中,在各个子系统服务或者别的地方中调用该函数来保证其被调用


  1. Can anybody explain the Advertised bandwidth, MaxAdvertisedBandwidth, Measured bandwidth, Bandwidth burst, RelayBandwidth rate? ↩︎