- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Symfony 2.7 和 Doctrine 开发一个网络应用程序。 Symfony 命令用于执行大量实体的更新。
我关注了Doctrine guidelines并不要对每个实体使用 $entityManager->flush()
。
这是 die Doctrine 示例代码:
<?php
$batchSize = 20;
for ($i = 1; $i <= 10000; ++$i) {
$user = new CmsUser;
$user->setStatus('user');
$user->setUsername('user' . $i);
$user->setName('Mr.Smith-' . $i);
$em->persist($user);
if (($i % $batchSize) === 0) {
$em->flush();
}
}
$em->flush(); //Persist objects that did not make up an entire batch
指南说:
You may need to experiment with the batch size to find the size that works best for you. Larger batch sizes mean more prepared statement reuse internally but also mean more work during flush.
所以我尝试了不同的批量大小。批处理大小越大,命令完成任务的速度就越快。
因此问题是:大批量的缺点是什么?为什么不在所有实体更新后仅使用 $entityManager->flush()
一次
文档只是说,较大的批量大小“意味着刷新期间需要更多工作”。但为什么/什么时候这会成为一个问题?
我能看到的唯一缺点是更新期间的异常
:如果脚本在保存的更改刷新之前停止,则更改将丢失。这是唯一的限制吗?
最佳答案
What are the downsides of large batch sizes?
如果您创建 10,000 个实体,则大批量可能会使用大量内存。如果您不批量保存实体,它们将在内存中累积,如果程序达到内存限制,则可能会导致整个脚本崩溃。
Why not use
$entityManager->flush()
only once, after all entities have been updated
这是可能的,但在调用一次 flush()
之前在内存中存储 10,000 个实体将比保存 100 个实体 100 个实体使用更多的内存。它也可能需要更多时间。
The docu just says, that larger batch sizes "mean more work during flush". But why/when could this be a problem?
如果最大批量大小没有任何性能问题,可能是因为您的数据不够大,无法填充内存或破坏 PHP 的内存管理。
因此,批处理的大小取决于多种因素,主要是内存使用与时间。如果脚本消耗太多 RAM,则必须减小批处理的大小。但使用非常小的批处理可能会比较大的批处理花费更多的时间。因此,您必须运行多个测试才能调整此大小,以便它使用大部分可用内存,而不是更多。
<小时/>我没有任何证据,但我记得曾与数千个实体合作过。当我只使用一个 flush()
时,我看到进度条变得越来越慢,看起来我的程序随着我在内存中添加越来越多的实体而变得越来越慢。
关于symfony - Symfony 和 Doctrine 中的批量插入 : How to select batch size?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38241720/
我开始从事一个用 Symfony 2.8 编写的大型项目。将整个项目升级到 SF 3 需要数百小时,现在还不可能。我想到了一个想法,将 symfony/symfony 包解压到它替换的单个包中(com
我在提交表单后使用 FOSUserEvents,但订阅者调用了两次。 这样我的验证码第一次有效第二次无效 这是我的代码 router = $router; $this->request
我有以下路线: blog_show: path: /test/123 defaults: { _controller: TotalcanBravofillBundle:Te
我是测试新手。我想测试我的功能。我已经成功安装了 phpUnit。我在互联网上查看了许多教程。但我无法获得有关测试的正确信息。这是我的功能代码: public function loginAction
我正在尝试重现 facebook batch requests 的行为在他们的图形 api 上运行。 所以我认为最简单的解决方案是在 Controller 上向我的应用程序发出几个请求,例如: pub
在 Symfony Progress Bar documentation有一个超酷酒吧的示例图像。不幸的是,看起来文档的其余部分没有解释如何获得这样的结果。 这是图片,以防您错过: 我怎么才能得到它?
我使用Finder发送假脱机电子邮件,但是自动名称生成器将点放在文件名中,有时它们出现在文件的开头。 查找程序似乎无法获取具有该名称的文件-那些文件被隐藏了……有人经历过这种行为吗?有什么建议如何使用
我正在尝试进行 LDAP 身份验证,我目前遇到此类错误: ServiceNotFoundException: The service "security.firewall.map.context.ma
有没有办法验证和检查集合数组是否为空。我已经尝试过: /** * @Assert\NotBlank() * @Assert\Length( min = 1) */ protected $work
使用Smyfony2和Doctrin2,可以使用以下示例创建数据固定装置:http://symfony.com/doc/current/bundles/DoctrineFixturesBundle/i
我看到在大多数Symfony 2示例中,例如,不存在记录时,Symfony 2会引发异常。我认为这种方法对最终用户不友好。为什么有人更喜欢引发异常而不在Flashbag上添加一些错误消息? 最佳答案
我对项目中的以下服务有疑问: app.security.guardAuthenticatorLoginPassword: class: AppBundle\Security\LoginPa
symfony缓存和登录Docker容器存在问题。 Web服务器从www-data用户和组执行,当我使用docker上安装的php从docker容器中清除symfony缓存时,它从root执行。 因此
我想了解 symfony 中的服务 我已阅读http://symfony.com/doc/2.3/book/service_container.html#creating-configuring-se
因为我对 Symfony 和 Doctrine 还很陌生,所以我有一个可能很愚蠢的问题;-) 有人可以用简单的词语向我解释集合(尤其是实体中的ArrayCollections)吗?它是什么以及何时以及
我收到了这个表格: {{ form_start(form) }} {{ form_end(form) }} 我想检查用户是否登录,我这样做了: {% if is_g
我的网站已准备好部署,我正在尝试将其设置为在线。 一些信息: 主持人是 OVH。 它不允许 SSH,我必须使用 FTP 发送文件。也没有命令行。 我现在希望能够在子目录中设置网站:/www/test(
过去几个月以来,我一直在尝试与symfony合作。昨晚我自动删除了不需要的存储库。之后,我无法使用symfony命令创建新的symfony项目。当我在终端中运行Symfony new Security
In the environnement variable, then in system variable, I edited the path and added在环境变量中,然后在系统变量
我们有一个 Symfony 1.4 应用程序,想升级到 Symfony 4。是否有可能或者我们必须重新编程该应用程序? 我们询问了我们附近的一家软件公司,他们告诉我们必须重新编写应用程序。 最佳答案
我是一名优秀的程序员,十分优秀!