如何解决Python后端设计模式
| 我现在正在为实时和历史跟踪Web服务开发大型后端系统。 我在Python方面经验丰富,打算与sqlalchemy(MySQL)结合使用以开发后端。 我没有开发健壮和可持续的后端系统的主要经验,我想知道你们是否可以指出一些有关后端设计模式的文档/书籍?我基本上需要通过实时查询不同的服务(通过HTML / SOAP / JSON)将数据提供给数据库,并保留该数据的历史记录。 谢谢!解决方法
您可以更精确地定义“后端”吗?通常,在Web开发人员中,我遵循MVC的结构,其中我的\“前端\”,html / css / js和处理显示其中任一代码的代码与我的\“后端\”模型(业务对象)松耦合和数据持久性;即数据库)。
我喜欢Django的Model / View / Template方法:
http://docs.djangoproject.com/en/dev/faq/general/#django-appears-to-be-a-mvc-framework-but-you-call-the-controller-the-view-and-the查看模板如何使用您的标准名称
但是,您尚未真正定义“后端”的含义,因此很难就设计模式提出建议。您说您具有Python的经验,您是否曾经开发过数据库驱动的Web应用程序?
更新
根据您的评论,我将无能为力,因为我没有太多的“后端”经验。但是,从您如何从网络中获取资源的角度来看,您的延迟/吞吐量将会非常高。因此,为了提高整体效率,您将需要一种可以以很高的并发性运行多个线程或进程的程序。我建议您在此线程上查看答案(并搜索类似的答案):
并发下载-Python
具体来说,我发现了递归Web服务器的示例及其后的示例可能是您解决方案的一个很好的起点:
http://eventlet.net/doc/examples.html#recursive-web-crawler
至于采纳这个想法,然后将其变成一个健壮/连续的过程,这将在很大程度上取决于您的平台以及错误处理的性能。基本上:
循环运行它,并确保您处理可能引发的任何错误
有某种过程监视您的工作程序进程挂起或死亡以杀死/重新启动它
确保您有监视解决方案来通知您它是否停止工作(nagios等)
保持事物“健壮”的最好方法之一就是使它们尽可能简单(而不是简单化)。如果您要做的只是从Web上获取信息,以某种方式对其进行解析,然后将该信息存储在DB中,然后尝试使过程保持简单。不要不必要地增加复杂性,以使其变得更强大。如果您最终得到了200行脚本来完成所需的工作,那就太好了!
,使用Apache,Django和Piston。
使用REST作为协议。
编写尽可能少的代码。
Django模型,表单和管理界面。
活塞式包装机可为您提供资源。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。