高级设置
- 主题:
- 最佳实践
创建对象:
- 有经验的
- 管理员
- 开发人员
Commerce是一种高度灵活且可伸缩的产品,包含适用于各种规模的商家的解决方案。 本节介绍有关配置Commerce以处理大量数据、极端负载和其他企业案例的最佳实践和建议。
校准索引性能
在处理大量数据时,重新索引可能会成为一个问题。 Commerce团队选择了加载次数最多的索引并启用了批量索引,这允许您设置要在每个迭代上处理的数据的一部分。 这样,用户就可以根据数据库中数据的类型和大小调整批量大小。
要管理此设置,请在相应模块的di.xml
文件中编辑batchRowsCount
参数。 以下索引支持此功能:
- 类别产品索引(目录模块)
- 价格指数(目录模块)
- EAV索引(目录模块)
- 股票指数(CatalogInventory模块)
您可以通过调整索引批量处理大小变量来调整索引器性能。 这控制索引器一次处理的实体数。 在某些情况下,我们发现索引时间显着减少。
例如,如果您运行类似B2B Medium的配置文件,则可以在app/code/Magento/catalog/etc/di.xml
中覆盖配置值batchRowsCount
并将默认值5000
覆盖为1000
。 使用默认MySQL配置,这会将完整索引时间从4小时缩短到2小时。
按网站限制客户组和共享目录
大量产品SKU、网站、客户组或共享目录将影响产品价格和目录规则索引器的运行时间。 这是因为默认情况下,所有网站都会分配给所有客户组(共享目录)。
若要缩短索引时间,您可以从客户组(共享目录)中排除某些网站。
设置Redis
有时,一个Redis实例不足以处理传入的请求。 要解决这种情况,我们可以建议采用几种解决方案。
首先,Commerce允许您为每个缓存类型配置单独的缓存存储。 这样,您可以安装与在Magento中注册的缓存类型数相同数量的单独Redis实例。 实际上,您可能希望最常用缓存的Redis实例,例如配置、布局和块。
另一种解决方案是将配置缓存放在文件系统上,并将其他缓存移动到Redis服务器。 使用此解决方案,您需要一个单独的工具来集中使所有Web节点上的配置缓存失效。
您还可以使用一个Redis群集,该群集执行自动增加节点数的并行读/写操作。 Commerce不提供此案例的配置,但可以通过少量自定义启动它。
设置RabbitMQ
Adobe Commerce支持通过RabbitMQ实现的消息队列。 Commerce使用此服务执行大量异步操作,包括B2B目录操作和异步库存更新。 所有用于将更多作业添加到作业服务器的界面都随产品一起分发,并可用于第三方扩展范围内的自定义异步逻辑实施。 与任何其他集成一样,Commerce为RabbitMQ提供了一个示例配置文件,其中包含所有推荐的设置并完全准备好用于生产。
拆分数据库
Adobe Commerce允许您配置可扩展的数据库存储,以满足不断增长的业务的需要。 您可以设置三个独立的主数据库,为特定域提供服务:
- 主(目录)数据库
- 签出数据库
- Order Management System (OMS)数据库
要配置其他数据库,必须创建一个空数据库并运行以下命令之一:
用于签出主数据库
bin/magento setup:db-schema:split-quote
对于OMS主数据库
bin/magento setup:db-schema:split-sales
这些命令将特定域表从主数据库迁移到域数据库。 它们还会更改Commerce配置以允许处理相应的连接和约束。
通过为签出和Order Management设置单独的数据库,您可以在数据库服务器之间分配负载。 您可以每秒提供更多的结账并处理更多订单,而不会影响目录和其他操作的可用性。 我们建议在瞬间或活跃销售期间拆分数据库,或永久用于自然高负载项目。 应在系统管理员的监督下执行当前数据在数据库之间的迁移。 在生产模式下请勿拆分数据库。
除了主数据库之外,Commerce还允许您配置多个从属数据库(系统中声明的每个数据资源各一个)。 从属数据库用作主数据库或域主数据库之一的完整复制副本。 它针对特定资源的读取操作发出。
您可以通过运行以下命令来添加从属数据库:
bin/magento setup:db-schema:add-slave
此命令执行配置更改,但不配置复制本身。 这应该手动完成。
拆分主数据库并设置从属数据库后,Commerce会自动调整到特定数据库的连接,根据请求类型(POST、PUT、GET等)和数据资源做出决策。 如果Commerce或其扩展对GET请求执行写入操作,系统会自动将连接从从属数据库切换到主数据库。 它与master数据库的工作方式相同:一旦您使用与签出相关的表,系统就会将所有查询重定向到特定数据库。 同时,所有与目录相关的查询将转到主数据库。
有关配置和多个主/从配置优点的更多详细信息,请参见
拆分数据库性能解决方案。
提供媒体内容
Magento不提供任何特定的集成来服务和交付媒体内容。 可在Magento中一起使用所有常用方法。
提供媒体内容的最简单方法是在Varnish服务器上交付和缓存媒体内容。 此方法假定使用共享文件系统来存储媒体内容,或者使用专用服务器指向Varnish。
对于中负载和高负载环境,我们建议使用内容交付网络(CDN)服务,如Fastly、Akamai和其他服务。 使用这些服务时,Commerce使用经典提取方法进行内容更新。 您必须配置Commerce个URL才能使用相应的CDN服务。 通过将媒体内容移动到CDN,可以显着减少实例的负载。
配置日志存储
日志的存储及其对其他磁盘操作的影响会影响Web节点的可用性,特别是在高负载情况下。 如果您不需要日志记录,我们建议您将其最小化。 您还可以配置日志记录,使其在独立的高访问速度存储系统上写入。 请注意,访问日志存储的任何瓶颈都可能会直接影响作为流的一部分记录写入或读取操作的传入请求的处理。