当前位置: 首页 > 网络应用技术

Django如何调用SDK避免内存溢出?

时间:2023-03-06 18:42:36 网络应用技术

  简介:今天,首席CTO Note将与您分享Django如何调用SDK如何避免内存溢出。如果您可以解决您现在面临的问题,请不要忘记注意此网站。让我们现在开始!

  1. Django形式很强大

  一些Django项目不会直接呈现HTML。第二个是API框架的形式,但您可能不会期望Django形成。Django形式不仅用于以这些API形式呈现HTML。最强的位置应该是其验证能力。让我们介绍几种与Django形式结合的模式:

  2.模型1:ModelTelt和默认验证

  最简单的模式是Modelform和Model中定义的默认验证方法的组合:

  #myApp/views.py

  来自django.views.gneric import createview,updateView

  从括号。视图导入loginrequiredmixin

  从.models导入文章

  类ArticleCreateAteview(LoginRequiredMixin,CreateView):

  型号=文章

  fields =('title','slug','review_num')

  class ArticleUpDateView(LoginRequiredMixin,UpdateView):

  型号=文章

  fields =('title','slug','review_num')

  如您在上面的代码中所见:

  ARTICLECREATEATEVIEW和ARTICEUPDATEVIEW设置模型作为文章

  两者都可以根据文章模型自动生成模态

  这些模型的验证基于文章模型中定义的字段转换

  3.模式2,修改和验证模型

  在上面的示例中,如果我们希望每个文章的开始都是“新”,那么我们该怎么办?首先,我们需要建立自定义验证(验证器):

  #utils/valivator.py

  来自django.core.corpeptions导入验证eRROR

  def value_begins(value):

  如果不是value.startswith(u'new'):

  提高验证Error(u'must从new'开始)

  可以看出,Django中的验证程序是不符合条件并抛出验证的功能。为了促进重复使用,我们将它们放入验证器中。

  接下来,我们可以将这些验证器添加到模型中,但是为了方便变化和维护,我们更倾向于加入该模型:

  #myApp/forms.py

  从django导入表格

  从utils.validators导入validate_begin

  从.models导入文章

  班级文章(forms.modelform):

  dev __init __(self, *args,** kwargs):

  Super(Artical Form,Self).__ Init __(8args,** kwargs)

  self.fields [“ title”]。验证者。

  元类:

  型号=文章

  Django的编辑视图(UpdateView和CreateView等)的默认行为基于为自动创建Modelform的模型属性。因此,我们需要调用自己的模型来涵盖自动创建:

  #myApp/views.py

  来自django.views.gneric import createview,updateView

  从括号。视图导入loginrequiredmixin

  从.models导入文章

  来自.forms导入文章

  类ArticleCreateAteview(LoginRequiredMixin,CreateView):

  型号=文章

  fields =('title','slug','review_num')

  form_class = ArtistForm

  class ArticleUpDateView(LoginRequiredMixin,UpdateView):

  型号=文章

  fields =('title','slug','review_num')

  form_class = ArtistForm

  4.模型三,使用form()和clear_field()方法

  如果我们要以形式验证多个字段,或验证现有存在中涉及的数据,则需要使用clean()和clear_field()表单的方法。多种密码与password2相同2:

  #myApp/forms.py

  从django导入表格

  类Myuserform(forms.form):

  用户名= forms.charfield()

  密码= forms.charfield()

  passwass2 = forms.charfield()

  def clean_password(self):

  密码= self.clenet_data ['密码']

  如果Len(密码)= 7:

  提高表格。ValidationError(“密码不安全”)

  返回密码

  def Clean():

  clear_data = super(myuserform,self).clean()

  密码= clear_data.get('密码','')

  passwass2 = clear_data.get('password2','')

  如果密码!=密码2:

  提高表格。ValidationError(“密码不匹配”)

  返回clean_data

  应当指出的是,在验证或修改后,必须将Clean()和Clean_field()()()的最后值返回到值。

  5.模式4,Modelform中的自定义字段

  我们经常以形式遇到默认验证。例如,模型中有许多不需要的项目,但是对于完整的信息,您希望必须填写这些字段:

  #myApp/models.py

  来自django.db导入模型

  类Myuser(Models.Model):

  用户名= models.charfield(max_length = 100)

  密码= models.charfield(max_length = 100)

  地址= models.textfield(空白= true)

  phone = models.charfield(max_length = 100,空白= true)

  为了满足上述要求,您可以直接添加字段以重写模型:

  #请不要这样做

  #myApp/forms.py

  从django导入表格

  来自.models导入myuser

  类Myuserform(forms.modelform):

  #请不要这样做

  地址= forms.charfield(必需= true)

  #请不要这样做

  phone = forms.charfield(必需= true)

  元类:

  模型= Myuser

  请不要这样做,因为这违反了“不重复”的原则,并且在许多复制和粘贴之后,代码将变得复杂且难以维护。正确的方法应该是使用__init __():

  #myApp/forms.py

  从django导入表格

  来自.models导入myuser

  类Myuserform(forms.modelform):

  def __init __(self, *args,** kwarg):

  super(myuserform,self).__ init __(*args,** kwargs)

  self.fields ['address']。必需= true

  self.fields ['Phone']。必需= true

  元类:

  模型= Myuser

  值得注意的是,django形式也是Python类。该类可以继承并继承或动态修改。

  解决django“懒惰”的基本方法

  现在,我们解决此问题的方法是“预载”。本质上,您要预先警告django orm,您必须一遍又一遍地告诉它相同的无聊指令。在上面的示例中,很容易添加此句子在DRF开始之前:

  querySet = queryset.prefetch_reled('orders')

  当DRF调用上述客户的相同序列化时,情况就是这样:

  获取所有客户(执行两个回合数据库操作,第一个是获取客户,第二个是获得相关客户的所有相关顺序。)。

  对于第一个客户,获取其订单(无需访问数据库,我们在上一步中获得了所需的数据)

  对于第二个返回客户,获取订单(无需访问数据库)

  对于第三个返回客户,获取订单(无需访问数据库)

  对于第四个返回客户,获取订单(无需访问数据库)

  对于第五返回客户,获取订单(无需访问数据库)

  对于第六返回客户,获取订单(无需访问数据库)

  您意识到您可以有很多客户,并且不再需要继续等待数据库。

  实际上,在步骤1中请求Django Orm的“准备”,该步骤1可以在本地高速缓存数据中提供步骤2+所需的数据,并具有先前数据库,从本地缓存数据中读取数据基本上是瞬时的,因此我们有当我们有很多客户时,获得了巨大的性能加速。

  解决Django REST框架的性能的标准化模式

  我们已经确定了一种通用模式,可以优化Django REST框架的性能,也就是说,每当序列化查询嵌套字段时,我们添加了一个新的@StaticMethod,名为Setup_eager_loading,如下:

  班级CobuliteRializer(Serializers.ModelSerializer):

  orders = orderSerializer(许多= true,read_only = true)

  def setup_eager_loading(cls,querySet):

  “”“”执行不加载数据。“”“”“”“”“”“”

  querySet = queryset.prefetch_reled('orders')

  返回QuerySet

  这样,无论您在何处使用此序列化,您只需要在调用serialization之前只调用setup_eager_loading,就像这样::

  customer_qs = customer.objects.all()

  customer_qs = cusiteerializer.setup_eager_loading(customer_qs)#设置急切的加载以避免n+1选择

  post_data = cusiteerializer(customer_qs,多个= true).data。

  或者,如果您有Apiview或Viewset,则可以在get_queryset方法中调用setup_eager_loading ::

  def get_queryset(self):

  querySet = cunituter.objects.all()

  #设置急切的加载以避免n+1选择

  querySet = self.get_serializer_class()。setup_eager_loading(querySet)

  返回QuerySet

  不是当您使用自己的管理员时,有一个配置文件捏,该文件只是在该文件中更改。管理员的本质实际上是工厂。当系统首次加载时,系统都由系统生成。配置了默认路径。默认路径为管理。由于您自己编写管理模块,因此您可以更改所写的URL路径,因此,当您访问时,您可以访问SA,例如管理员的初始基本路径是Admin1,并且您将与默认管理员分开,我想使用该服务,只需致电哪一个很好

  老实说,直到到目前为止,我都不欣赏django。这不是我的认知中的微妙设计。这只是功能所积累的“成熟解决方案”。但是,一切的兴起都是时代的选择。您不喜欢它,但需要它。希望有一天,Python可以拥有越来越丰富的成熟解决方案,并且不再因性能和维护而受到批评。(Fit End)

  将其本质带到滴度上,Django的优势很方便。我们的源代码阅读的目的是探索其便利性的本质。阅读源代码的计划对每个地方都不好,而是解释功能的功能。

  django-admin startproject helloworld可以生成django项目。命令行是EXE格式。

  manage.py将参数交给了命令行。

  execute_from_command_line()通过命令行参数创建管理类。然后运行他的execute()。

  如果设置了重新加载,请在启动之前检查_errors。

  check_errs()是一个关闭,因此在上一篇文章的末尾是(django.setup)()。

  查看最后一个句子设置.installed_apps.grab从设置

  请注意,此设置不是我们项目中的设置。

  这是设置类的懒负载包装包装,直到__getAttr __。然后从设置类的实例中获取值,然后说将其分配给您自己的__ -dict__(我会直接找到它下次我自己,因为__getAttr __优先级)

  为了促进调试,我们直接编写一个run.py。

  在项目下创建一个run.py,以模拟运行服务器命令

  调试抓取设置_MODULE

  回到setup()中的最后一句话

  开始观看apps.populate()

  首先查看本段

  这些应用最终被封装在appconfig中。

  随后,调用了每个AppConfig的import_models()和ready()方法。

  应用程序的加载部分通常是这样的

  为了促进调试,我们重写了最后一句话

  RES的类型是命令django.contrib.staticfiles.management.commands.runserver.com和object at 0x00000101ED5163A0

  重点是第二个句子,让我们跳到run_from_argv()方法,这是几个处理参数。

  用Pycharm指向手柄将进入基类,该基类无法获得正确的方向。实际上,子类已重写此方法。

  这里有两种情况。如果加载重新加载,它将直接执行inner_run(),并且项目首先从其他逻辑开始。

  当Django项目启动时,它实际上将启动两次。如果我们在项目入口(Manage.py)中设置一个贴心,您会发现它将打印两次。

  在第一个启动开始时,django_autoreload_env却没有,无法输入启动逻辑。将输入crandt_with_reloader()。

  在这里,您将将django_autoreload_env放置为true,然后重新启动。

  第二次,您可以输入启动逻辑。

  在此创建一个Django主线程以传递innit_run()。

  随后,此线程创建了一个旋转式,通过reloader.run(django_main_thread)询问监护过程。

  让我们看一下django innion_run()的主线程。

  当我们看到WSGI时,Django的启动逻辑已经结束。下一个作业已移交给WSGI服务器

  这相当于我们之前在Fastapi中所说的话,然后将Fastapi的应用程序交给ASGI服务器(ASGI也是Django提出的,这两个基本上是同源的)

  那么WSGI来自哪里?让我们回头回去

  此设置是一个对象,它已从以前的操作中从settings.py配置文件中获取了自己的属性。因此,我们只需要转到settings.py配置文件即可找到。

  让我们找到此get_wsgi_application()。

  它将再次调用setup(),返回WSGIHANDLER类的实例很重要。

  这是WSGIAPP本身。

  load_middleware()是WSGIAPP构建中间件堆栈的唯一方法。

  如果您之前阅读了FastAPI源代码,则应该对中间件堆栈不陌生。

  应用程序入口→中间件堆栈→路由→路由节点→端点

  因此,WSGIAPP已完成此操作,并将服务器传递到应用程序入口的请求中,并且可以通过中间件与该路由分配。

  Django的背景扩展具有扩展模型和一个扩展模型字段(字段),但我仍然最喜欢这种扩展方法(Django的官方文档,非常适合自定义):

  从:

  该原理非常简单,也就是说,在url.py上添加URL配置以覆盖背景的默认URL处理,然后您可以按照需要编写自己的视图

  显然,管理接口对于数据编辑非常有用(想象)。如果它用于完成某些数据的输入工作,则管理接口确实无人看管。我们猜测,本书中的大多数读者都有大量数据输入任务。

  Django管理界面特别注意那些没有技术背景的人使用数据输入;这也是发展此功能的目的。在Django的最初开发土地报纸,开发了典型的在线市政供水质量报告系统,需求如下:

  负责此主题的记者与开发人员结识并提交了现有数据。

  开发人员设计了围绕数据的模型,并为记者开发管理接口。

  当记者将数据输入Django时,程序员可以专注于公共访问界面的开发(最有趣的部分!)。

  换句话说,Django管理接口的主要目的是同时促进内容编辑器和程序员。

  当然,除了明显的数据输入任务外,我们发现管理接口在其他情况下非常有用。

  crqrwv a href = https://www.shouxicto.com/article/“” xwyekefymefu/a,[url =] eycmfqtvgmvb [/url],[link =]

  管理数据:很少有实际数据输入与这样的站点关联,因为大多数数据来自自动生成的来源。但是,当获得的数据错误造成麻烦时,它可以轻松找到并修改错误数据以帮助问题解决。。

  如果没有或只是自定义,Django管理界面就可以处理大多数常见情况。但是,正是由于Django管理界面可以处理这种常见情况,它无法处理其他编辑模型。

  4yqjmu a href = https://www.shouxicto.com/article/“” kdqfnmmekszw/a,[url =] zusybryiqeir [/url],[link =]

  管理

  bmufnt a href = https://www.shouxicto.com/article/“” ifhkpydljkaf/a,[url =] mqitqhmcazco [/url],[link =] qcmerxzxnmhj [/link],

  受信任的用户编辑结构化内容。

  是的,这很简单,但是这个简单是建立在一堆假设上的。django管理界面的所有设计概念都遵循这些假设,因此让我们理解这些后续部分中术语的含义。

  受信任的用户

  管理界面的设计是由像您这样的开发人员使用的人。在这里,不仅仅是通过身份验证的人;据说Django假设内容编辑器只能执行内容编辑器的工作。

  另一方面,这意味着,如果您信任用户,他们可以在不获得许可证的情况下编辑内容,并且没有人需要允许其编辑行为。另一个含义是,尽管身份验证系统具有强大的功能,但它不支持在本书中撰写时,访问对象 - 级基础的限制。如果您允许某人编辑新闻报告,则必须确保未经许可用户不会编辑其他人的报告。

  编辑

  Django管理界面的主要目的是让用户编辑数据。乍一看,这很明显,但是如果您考虑一下,它将变得有些难以捉摸且非凡。

  例如,尽管管理接口非常方便检查数据(如今所讨论),但这不是其最初的意图。例如,我们在第12章中提到,它缺乏视图允许允许。在管理接口中,还可以执行编辑器。

  还需要注意的是,这是缺乏远程呼叫工作流程。如果特定任务包括一系列步骤,则没有机制确保可以按特定顺序完成这些步骤。DJANGOMANACORAME接口专注于编辑,不关心改变周围活动。此逃避工作流程也来自信任原则:管理接口的设计概念是工作流是一件事情,并且不需要在代码中实现。

  最后,应该注意的是,管理接口中缺乏聚合。换句话说,它不支持显示总数,平均值等的内容。再次,管理界面仅用于编辑 - 期望您通过定义视图来完成所有其他任务。

  结构化内容

  30cen9 a href = https://www.shouxicto.com/article/“” bxyzitjhvwis/a,[url =] ylhgcrwsnuue [/url],[link =] mecoeqQxpail [/link],

  这里

  现在可以肯定的是,Django的管理接口并不打算成为每个人的通用工具。相反,我们选择专注于做一件事情并完成它。

  sapqz9 a href = https://www.shouxicto.com/article/“” fmvbpdngtcts/a,[url =] tvwreqwomvco [/url],[link =]

  必须记住的是,尽管管理界面很复杂,但它总是一个应用程序。只要有足够的时间,任何Django开发人员都可以做所有事情。将来的管理界面。这个新界面具有一系列不同的先决条件,并且工作方法完全不同。

  最后,应该指出的是,在撰写本文时,Django开发人员正在进行新的管理界面开发工作,该工作将提供更自定义的灵活性。当您阅读本文时,这些新功能可能已输入真正的Django版本。

  定制管理模板

  lryxwt a href = https://www.shouxicto.com/article/“” uokhfgxirpcl/a,[url =] wqhpuiouinaf [/url],[link =] fatpucympci [/link],

  现在,让我们看看如何快速自定义管理管理接口的外观。第6章讨论了一些最常见的任务:修改商标(对于那些讨厌蓝色头发的老板)或提供自定义表格。

  进一步的目标通常包括,更改模板中的一些特殊项目。每个管理员的视图,包括修改列表,编辑表格,删除确认页面和历史视图。有一个与之相关联的模板可以在许多方面覆盖。

  首先,您可以在全局情况下覆盖模板。Admin视图使用标准模板加载机制来查找模板。因此,如果您在模板目录中创建新模板,Django将自动加载它。图17中列出了图模板。-1。

  fd2cvv a href = https://www.shouxicto.com/article/“” fphafdvvvmhea/a,[url =] mompqgnztmob [/url],[link =] oamzxjphpsxv [/link],

  在大多数情况下,您可能只想修改单独的对象或应用程序,而不是修改整体设置。因此,每个管理员视图总是找到与模型或应用程序相关的模板。查找模板的顺序如下:

  admin/app_label/object_name/template.html

  jrmal2 a href = https://www.shouxicto.com/article/“” kqqeldaxlpkep/a,[url =] ihzkjznjrsqj [/url],[link =]

  admin/template.html

  例如,在书籍应用程序中,书籍模块添加/编辑表单的视图将按以下顺序找到模板:

  管理/书籍/书籍/thex_form.html

  admin/books/change_form.html

  admin/change_form.html

  自定义模型模板

  在大多数情况下,您想使用第一个模板来创建特定的模型模板。从基础上讲,最好的方法是将信息添加到基础模板中定义的块和块。

  例如,我们想在书页面的顶部添加一些帮助文本。这可能是图17-1所示的形式。

  图17-1。定制管理编辑表格。

  这很容易做到:只需构建Admin/BookStore/book/drack_form.html模板,然后输入以下代码:

  {%扩展“ admin/change_form.html”%}

  {%block form_top%}

  pinsert有意义的帮助消息在这里.https://www.shouxicto.com/p

  {%endblock%}

  mgrlx4 a href = https://www.shouxicto.com/article/“” omnhyzkldddtt/a,[url =] ydlrolrelntzkskj [/url],[link =]

  自定义JavaScript

  这些自定义模型模板的常见用途包括将自定义JavaScript代码添加到管理页面,以实现一些特殊的视图对象或客户端行为。

  幸运的是,这可能很容易。每个管理模板定义{%block extrahead%},您可以在head元素中添加新内容。例如,如果要将jquery()添加到管理员历史记录中,则可以做到这一点:

  {%扩展“ admin/object_history.html”%}

  {%阻止extrahead%}

  脚本src =“ https://www.shouxicto.com/article/” type =“ text/javascript”/脚本

  脚本类型=“ text/javascript”

  //代码在这里实际使用jQuery ...

  /脚本

  {%endblock%}

  评论

  我们不知道为什么您需要将jQuery放入历史页面,但是可以在任何模板中使用此示例。

  tyy7is a href = https://www.shouxicto.com/article/“” hpswriedwzmw/a,[url =] bvkzckktnoefm [/url],[link =]

  创建自定义管理视图

  现在,想要在Django的管理员 - 调节界面中添加自定义行为的人可能会感到有些奇怪。我们在这里谈论的是如何更改管理员管理界面的外观。他们都在喊叫:我们如何更改管理管理界面的内部工作机制。

  首先要提到的是这并不令人惊讶。Admin的管理界面没有做任何特别的事情。就像其他视图一样,仅处理数据。

  确实,这里有很多代码。它必须处理各种操作,现场类型和设置以显示模型的行为。当您注意到管理员界面只是一系列视图(视图)时,增加自定义管理,视图变得易于理解。

  例如,让我们将发布者报告的视图添加到第6章中的第6本书中。创建了管理视图列表,以显示出发布者划分的书籍列表,这是您要建立的自定义管理员报告视图的非常典型的示例。

  首先,在我们的urlconf.sert中连接视图以下行:

  (r'^admin/books/report/$','mysite.books.admin_views.report'),

  在将此行添加到此管理视图之前,原始URLCONF应该是这样的:

  来自django.conf.urls.defaults导入 *

  urlpatterns =模式('',,

  (r'^admin/bookstore/report/$','bookstore.admin_views.report'),

  (r'^admin/',inderude('django.contrib.admin.urls'),),),),

  治愈

  您为什么要尝试在管理内容之前放置自定义的尝试?回想一下Django处理订单的URL匹配。在管理内容与内容匹配后,如果我们扭转了这些行的顺序,Django会找到一个内部管理视图,以了解匹配公式,并将尝试在“书籍”应用程序中输入报告模型,然后输入列表,但这不存在。

  现在我们开始写一个视图。简单起见,我们只将所有书籍加载到上下文中,然后让模板使用{%regroup%}标签来处理组操作。创建book/admin_views.py文件并写下以下内容:

  来自mysite.books.models导入书籍

  来自django.template导入requestContext

  来自django.shortcuts导入render_to_response

  来自django.contrib.admin.views.decorators导入suffer_member_required

  DEF报告(请求):

  返回render_to_response(

  “ admin/books/report.html”,

  {'book_list':book.objects.all()},

  requestContext(请求,{}),

  治愈

  报告= Staff_Member_Required(报告)

  因为我们将小组操作留在模板上,所以视图非常简单。但是,有几个微妙的细节值得我们理解。

  我们在django.contrib.admin.views.decorators中使用了Staff_Member_Required修改器。装饰师类似于第12章中讨论的login_required,但它还检查了用户是否指定为内部人员来确定他是否允许他访问管理层界面。

  修饰符保护所有内容的管理视图,并使身份验证逻辑匹配管理接口的其他部分。

  我们分析了管理下的模板。尽管并非严格要求这样做,但这是将所有管理模板放入管理员目录中的好方法。我们还将应用程序的所有模板都放在名为书名的目录中,也是最佳实践。

  我们使用requestContext作为render_to_response的第三个参数(````context_instance“''')。这确保模板可以访问当前用户的信息。

  请参阅第10章以了解有关RequestContext的更多信息。

  最后,我们为此视图制作模板。我们将扩展构建的-in管理模板,以使视图显然成为管理接口的一部分。

  {%扩展“ admin/base_site.html”%}

  {%块标题%} publicsher {%endBlock%}的书籍列表

  {%阻止内容%}

  div ID =“ content-mail”

  公共书籍的h1list:/h1

  {%regroup book_list |dictsort:发布者的“ publisher.name”为books_by_publisher%}

  {books_by_publisher%的发布者%}

  H3 {Publisher.grouper}}/H3

  Ul

  {for in public in public.list |distsort:“ title”%}

  li {book}}/li

  {%endfor%}

  /ul

  {%endfor%}

  /div

  {%endblock%}

  通过扩展admin/base_site.html,我们无需付出任何努力即可出现Django管理接口。图17-2 i显示了这样的最终结果。

  图17-2。出版商分类的书籍管理视图

  使用此技术,您可以将梦想中的任何内容添加到管理界面。需要记住的是,这些称为自定义的管理视图实际上只是普通的Django视图。您可以使用本书其他部分中学到的技术来制作满足您需求的复杂管理界面。

  遮盖终点

  有时,默认管理视图无法完成某个工作。您可以轻松地放置自定义视图;您只需要用自己的URL覆盖构建的管理视图,换句话说,如果您的视图出现在URLConf中的默认管理视图中,则您的视图将替换默认视图并被调用。

  例如,我们可以使用允许用户简单地输入ISBN替换构建的书籍创建视图的窗口。然后,我们可以查询本书的信息并自动创建对象。

  此视图的代码作为练习留给读者。重要的部分是该URLCONF代码被打破:

  ;

  如果此代码片段在管理URL之前出现在URLConf中,则add_by_isbn视图将完全替换标准管理视图。

  这样,我们可以替换删除确认页面的任何部分,编辑页面或管理接口。

  结论:以上是主要CTO的全部内容,请注意Django如何调用SDK以避免内存溢出。感谢您阅读本网站的内容。我希望这对您有帮助。有关Django如何调用SDK如何避免内存溢出的更多信息。不要忘记在此站点上找到它。