设计一个路由

简单地说一下常见的路由形式。

  • 数组存储。按照添加路由的顺序存储在数组中,查找时依次匹配。这种路由效率比较低。tornado就是这么设计的。

  • 字典存储。把路由存储在map里,查找效率很高,但是不支持URI中有参数。Golang中默认的mux就这么设计的。

  • 树。一般使用前缀树,空间更紧凑的用radix tree。如 httprouter 就是这种设计。

一般就这么几种,可能会有些许细节上的不同。


更多文章
  • Kubernetes 笔记
  • go mod 和 logrus 路径大小写的问题
  • Flask自动加载Blueprint
  • 在KVM里安装Minikube
  • 搞定面试中的系统设计题
  • Crontab + Sendmail实现定时任务并且通知
  • Nginx设置Referer来防止盗图
  • Graphviz dot简明教程
  • jQuery简明教程
  • Python RQ(Redis Queue)添加gevent支持
  • 读《超级运营术》- 如何做社区?
  • 技术人,光有技术是不行的
  • 搭建aria2服务器
  • 使用shairport-sync搭建airplay音频服务器
  • VirtManager Windows自适应屏幕