Magento Enterprise 1.13+ 使用“部分索引”进程,该进程作为 Magento cron 作业的一部分在后台运行。我目前正在努力了解这个过程正在做什么。
我了解部分索引器的工作原理是跟踪实体以通过数据库中的“变更日志”表(catalog_category_flat_cl、catalog_category_product_cat_cl 等)重新编制索引,然后在 cron 运行时重新索引这些特定项目。
Magento cron 当前正在我的服务器上运行(同一个 cron 进程已经运行了大约 3 个小时)。 cron_schedule 表表明 enterprise_refresh_index 正在进行中,并与上述 cron 进程同时启动。
但是,当我计算更改日志表中的行时,值总是相同的;这些表中的行数没有减少(如果部分索引器正在处理它们,我会期望什么?)。 n98-magerun 工具列出了索引,但当前没有一个正在处理:
$ n98-magerun.phar index:list
+------------------------------+-----------------+------+
| code | status | time |
+------------------------------+-----------------+------+
| catalog_product_attribute | require_reindex | 28m |
| catalog_product_price | pending | 0 |
| catalog_url | pending | 0 |
| catalog_product_flat | pending | 0 |
| catalog_category_flat | pending | 0 |
| catalog_category_product | pending | 0 |
| catalogsearch_fulltext | pending | 0 |
| cataloginventory_stock | pending | 0 |
| tag_summary | require_reindex | 1s |
| url_redirect | pending | 0 |
| catalog_url_category | pending | 0 |
| catalog_url_product | pending | 0 |
| catalog_category_product_cat | pending | 0 |
| targetrule | pending | 0 |
+------------------------------+-----------------+------+
var/locks 目录似乎对每个索引器都有事件锁,这没有意义(当索引进程完成时,锁文件应该被删除吗?:
$ ls -lah
total 64K
drwxrws--- 2 www-data www-data 4.0K Sep 23 22:56 .
drwxrws--- 8 www-data www-data 4.0K Sep 10 07:12 ..
-rw-rw-r-- 1 www-data www-data 31 Sep 24 00:10 index_process_10.lock
-rw-rw-r-- 1 www-data www-data 31 Sep 24 00:10 index_process_11.lock
-rw-rw-r-- 1 www-data www-data 31 Sep 24 00:10 index_process_12.lock
-rw-rw-r-- 1 www-data www-data 31 Sep 24 00:10 index_process_13.lock
-rw-rw-r-- 1 www-data www-data 31 Sep 24 00:10 index_process_14.lock
-rw-rw-r-- 1 www-data www-data 31 Sep 23 22:20 index_process_1.lock
-rw-rw-r-- 1 www-data www-data 31 Sep 23 17:53 index_process_2.lock
-rw-rw-r-- 1 www-data www-data 31 Sep 24 00:10 index_process_3.lock
-rw-rw-r-- 1 www-data www-data 31 Sep 24 00:10 index_process_4.lock
-rw-rw-r-- 1 www-data www-data 31 Sep 24 00:10 index_process_5.lock
-rw-rw-r-- 1 www-data www-data 31 Sep 24 00:10 index_process_6.lock
-rw-rw-r-- 1 www-data www-data 31 Sep 24 00:10 index_process_7.lock
-rw-rw-r-- 1 www-data www-data 31 Sep 24 00:10 index_process_8.lock
-rw-rw-r-- 1 www-data www-data 31 Sep 24 00:10 index_process_9.lock
任何关于我如何能更多地了解部分索引过程、它目前正在做什么、它取得了什么进展/还有什么有待索引的建议都将不胜感激!
最佳答案
还有一些其他的表,查看enterprise_mview_*。
有一段时间没有使用企业索引器,但上次我为控制台配置了 XDebug 并分析了它的作用。或者到处都是 Mage::log(),但我不建议在真正的调试器上使用它。
希望它能让您走上正轨。
关于php - Magento 部分索引过程的可见性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26015563/
我正在编写一个方法,它将在一个类中定义一个实例方法;类似于attr_accessor:classFoocustom_method(:foo)end我通过将custom_method函数添加到Module模块并使用define_method定义方法来实现它,效果很好。但我无法弄清楚如何考虑类(class)的可见性属性。例如,在下面的类中classFoocustom_method(:foo)privatecustom_method(:bar)end第一个生成的方法(foo)必须是公共(public)的,第二个(bar)必须是私有(private)的。我怎么做?或者,如何找到调用我的cust
我发现自己需要这个。假设cart是一个包含用户列表的模型。defindex_of_itemcart.users.each_with_indexdo|u,i|ifu==current_userreturniendend获取此类关联索引的更简单方法是什么? 最佳答案 indexArray上的方法与您的index_of_item方法相同,例如cart.users.index(current_user)返回数组中第一个对象的索引==给obj。如果未找到匹配项,则返回nil。 关于ruby-on-
因此,当我遵循MichaelHartl的RubyonRails教程时,我注意到在用户表中,我们为:email属性添加了一个唯一索引,以提高find的效率方法,因此它不会逐行搜索。到目前为止,我们一直在根据情况使用find_by_email和find_by_id进行搜索。然而,我们从未为:id属性设置索引。:id是否自动索引,因为它在默认情况下是唯一的并且本质上是顺序的?或者情况并非如此,我应该为:id搜索添加索引吗? 最佳答案 大多数数据库(包括sqlite,这是RoR中的默认数据库)会自动索引主键,对于RailsMigration
假设我有一个可枚举对象enum,现在我想获取第三个项目。我知道一种通用方法是转换成数组,然后使用索引访问,如:enum.to_a[2]但这种方式会创建一个临时数组,效率可能很低。现在我使用:enum.each_with_index{|v,i|breakvifi==2}但这非常丑陋和多余。执行此操作最有效的方法是什么? 最佳答案 你可以使用take剥离前三个元素,然后剥离last从take给你的数组中获取第三个元素:third=enum.take(3).last如果您根本不想生成任何数组,那么也许:#Ifenumisn'tanEnum
在我的场景中,Logstash收到的系统日志行的“时间戳”是UTC,我们在Elasticsearch输出中使用事件“时间戳”:output{elasticsearch{embedded=>falsehost=>localhostport=>9200protocol=>httpcluster=>'elasticsearch'index=>"syslog-%{+YYYY.MM.dd}"}}我的问题是,在UTC午夜,Logstash在外时区(GMT-4=>America/Montreal)结束前将日志发送到不同的索引,并且索引在20小时(晚上8点)之后没有日志,因为“时间戳”是UTC。我们已
我想从特定索引开始遍历数组。我该怎么做?myj.eachdo|temp|...end 最佳答案 执行以下操作:your_array[your_index..-1].eachdo|temp|###end 关于ruby-从特定索引开始迭代数组,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/44151758/
我一直在努力学习如何处理由数组组成的数组。假设我有这个数组:my_array=[['ORANGE',1],['APPLE',2],['PEACH',3]我将如何找到包含'apple'的my_array索引并删除该索引(删除子数组['APPLE',2]因为'apple'包含在该索引的数组中)?谢谢-我非常感谢这里的帮助。 最佳答案 您可以使用Array.select过滤掉项目:>>a=[['ORANGE',1],['APPLE',2],['PEACH',3]]=>[["ORANGE",1],["APPLE",2],["PEACH",3
我想使用部分字符串搜索数组,然后获取找到该字符串的索引。例如:a=["Thisisline1","Wehaveline2here","andfinallyline3","potato"]a.index("potato")#thisreturns3a.index("Wehave")#thisreturnsnil使用a.grep将返回完整的字符串,使用a.any?将返回正确的true/false语句,但都不会返回匹配的索引找到了,或者至少我不知道该怎么做。我正在编写一段代码,该代码读取文件、查找特定header,然后返回该header的索引,以便它可以将其用作future搜索的偏移量。如果
我已经开始学习Ruby,我已经阅读了一些教程,甚至还买了一本书(“ProgrammingRuby1.9-ThePragmaticProgrammers'Guide”),我遇到了一些以前从未见过的新东西使用我知道的任何其他语言(我是一名PHP网络开发人员)。block和过程。我想我明白它们是什么,但我不明白的是为什么它们如此伟大,以及我应该在何时何地使用它们。我到处都看到他们说block和过程是Ruby中的一个很棒的特性,但我不理解它们。这里有人能给像我这样的Ruby新手一些解释吗? 最佳答案 block有很多好处。电梯演讲:bloc
如何在rakedb:migrate:status中删除带有“**NOFILE**”的迁移ID列表?例如:StatusMigrationIDMigrationName--------------------------------------------------up20131017204224Createusersup20131218005823**********NOFILE**********up20131218011334**********NOFILE**********我不明白为什么当我自己手动删除它时它仍然保留旧的迁移文件,因为我正在研究迁移的工作原理。这是为了记录吗?但