笨办法学 Python · 续 练习 24:URL 快速路由

简介: 练习 24:URL 快速路由 原文:Exercise 24: Fast URL Search 译者:飞龙 协议:CC BY-NC-SA 4.0 自豪地采用谷歌翻译我们将结束数据结构和算法的部分,并将数据结构用于实际问题。

练习 24:URL 快速路由

原文:Exercise 24: Fast URL Search

译者:飞龙

协议:CC BY-NC-SA 4.0

自豪地采用谷歌翻译

我们将结束数据结构和算法的部分,并将数据结构用于实际问题。我已经写了几个 Web 服务器,一个不断出现的问题是,将 URL 路径匹配到“动作”。你会在每个 Web 框架,Web 服务器,和必须基于层次化的键来“路由”信息的任何东西中发现此问题。当你的 Web 服务器收到URL /do/this/stuff/时,必须确定每个部分是否可能附加了某种操作或配置。如果你在/do/配置了 Web 应用程序,那么你的网络服务器应该使用/this/stuff/做什么呢?是否认为它是失败的,或将其传递给 Web 应用程序?如果/do/this/中有一个目录怎么办?而且,如何快速检测到错误的 URL,因此你不必处理不存在的巨大请求?

这种层次化的搜索经常出现,这是对你将算法和数据结构应用于问题的能力,以及性能分析能力进行测试的最佳测试。

挑战练习

首先,请确定你了解 URL 是什么以及如何使用。如果没有,那么我建议你花时间去写一个带有一些复杂路由的小型 Flask 应用程序。这是你将要实现的路由。

接下来,你应该执行以下操作:

  • 创建一个简单的基本的URLRouter类,你将为所有实现派生它。你应该可以对此URLRouter执行以下操作:
    • 添加一个带有关联对象的新 URL。
    • 获取 URL 的完全匹配。搜索/DO/THIS/STUFF/只返回正好是它的东西。
    • 获取 URL 的最佳匹配。搜索/DO/THIS/STUFF/将匹配/DO/,如果这是唯一的匹配。
    • 获取以此 URL 开头的所有对象。
    • 获取 URL 的最短匹配对象。搜索/DO/THIS/STUFF/会返回/DO/而不是/DO/THIS/
    • 获取 URL 的最长匹配对象。搜索/DO/THIS/STUFF/将返回/DO/THIS/而不是/DO/
  • 使用TSTree创建URLRouter的子类,因为这样最容易了。确保测试了下面这些事情:
    • 不同长度的随机 URL 和路径,在TSTREE和你搜索的内容里面。
    • 在不同情况下只寻找部分路径
    • 完全不存在的路径
  • 存在和不存在的非常长的路径
  • 一旦你让这个子类工作,并测试完毕,推广你的测试,所以你可以在所有打算完成的实现中运行它。
  • 然后,尝试使用DoubleLinkedListBSTreeDictionary和 Python 的dict来实现。确保你的泛用测试适用于所有这些。
  • 一旦完成了,开始分析这些实现的不同操作的性能。

目标是看看与其他数据结构相比,TSTree有多快。它可能会击败大多数东西,但也许 Python dict多数情况会赢,因为它针对 Python 进行了优化。你甚至可以为每个操作猜测,哪个数据结构具有最佳性能。

研究性学习

  • 我省略了SuffixArray,因为它类似于TSTree,但为了使用它,你必须添加相同的操作。实现它,然后看看SuffixArray如何比较。
  • 研究你最喜欢的 Web 服务器或 Web 框架是如何实现的。你会发现很多使用 URL 人不知道什么是三叉搜索树,尽管它对于常见操作非常有用。

深入学习

如果你想深入了解算法和数据结构,我强烈推荐 Steven S. Skiena 的《The Algorithm Design Manual》一书。他的书使用 C,所以你可能需要先阅读《笨办法学 C》,以便能够浏览它。除此之外,它是一本很好的书,因为它涵盖了分析算法和数据结构的性能的理论和实现。

相关文章
|
5月前
|
Python
路由(URL routing)
【8月更文挑战第23天】
43 4
|
4月前
|
缓存 中间件 网络架构
Python Web开发实战:高效利用路由与中间件提升应用性能
在Python Web开发中,路由和中间件是构建高效、可扩展应用的核心组件。路由通过装饰器如`@app.route()`将HTTP请求映射到处理函数;中间件则在请求处理流程中插入自定义逻辑,如日志记录和验证。合理设计路由和中间件能显著提升应用性能和可维护性。本文以Flask为例,详细介绍如何优化路由、避免冲突、使用蓝图管理大型应用,并通过中间件实现缓存、请求验证及异常处理等功能,帮助你构建快速且健壮的Web应用。
40 1
|
5月前
|
数据采集 索引 Python
Python中这样操作url也太爽了吧
Python中这样操作url也太爽了吧
135 5
|
5月前
|
API 开发者 Python
"FastAPI路由大揭秘!轻松玩转URL映射,让你的Web应用路由设计既RESTful又灵活多变,秒杀传统框架的秘籍在这里!"
【8月更文挑战第31天】在Web开发中,路由是连接用户请求与后端逻辑的关键。FastAPI作为现代Python Web框架的佼佼者,以其简洁的API设计和高性能,提供了高度灵活的路由系统。本文通过开发一个博客系统的案例,详细介绍了FastAPI中路由的实现方法,包括基础路由定义、参数类型验证及路由分组与嵌套等,展示了如何轻松构建RESTful风格的URL映射,提升应用的可维护性和扩展性。
169 2
|
5月前
|
开发者 Java UED
大文件传输不再头疼:揭秘Struts 2如何轻松应对文件上传与下载难题!
【8月更文挑战第31天】在Web应用开发中,文件上传与下载至关重要。Struts 2作为主流Java EE框架,凭借Commons FileUpload及文件上传拦截器简化了相关操作。本文探讨Struts 2在文件传输上的优势,通过具体配置与代码示例,展示如何设置最大文件大小、使用`fileUpload`拦截器以及实现文件上传与下载功能。对于大文件传输,Struts 2不仅能够轻松应对,还支持上传进度显示,有效提升了用户体验。总体而言,Struts 2为文件传输提供了高效便捷的解决方案,助力开发者构建稳定可靠的Web应用。然而,在处理大文件时需兼顾网络带宽与服务器性能,确保传输顺畅。
88 0
|
5月前
|
API UED 开发者
Vaadin路由魔法:导航之舟,带你穿越页面迷宫!驾驭神奇URL,解锁无限可能!
【8月更文挑战第31天】Vaadin是一款现代Java Web开发框架,其路由机制结合前后端路由,确保流畅的用户体验和高效服务器资源利用。通过`@Route`注解和`Router`类,开发者可以轻松定义和管理页面路径。例如,`@Route("home")`可指定视图路径,而参数化路由如`@Route("user/:userId")`则允许URL传参。此外,Vaadin还提供了丰富的导航API和自定义路由事件监听器,助力开发者构建结构清晰且体验优秀的Web应用。
76 0
|
6月前
|
JSON 中间件 数据处理
实践出真知:通过项目学习Python Web框架的路由与中间件设计
【7月更文挑战第19天】探索Python Web开发,掌握Flask或Django的关键在于理解路由和中间件。路由连接URL与功能,如Flask中@app.route()定义请求响应路径。中间件在请求处理前后执行,提供扩展功能,如日志、认证。通过实践项目,不仅学习理论,还能提升构建高效Web应用的能力。示例代码展示路由定义及模拟中间件行为,强调动手实践的重要性。
69 1
|
6月前
|
前端开发 安全 测试技术
【Python】已解决:The method is not allowed for the requested URL.
【Python】已解决:The method is not allowed for the requested URL.
597 3
|
6月前
|
Python
Python推导式:小练习
Python推导式:小练习
|
6月前
|
Python
Python 练习实例35
Python 练习实例35