定制 php-lrpm/php-lrpm-cluster 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

php-lrpm/php-lrpm-cluster

最新稳定版本:v1.0.0

Composer 安装命令:

composer require php-lrpm/php-lrpm-cluster

包简介

PHP Long Running Process Manager Cluster

README 文档

README

Clustering support for PHP-LRPM, including different sharding strategies.

Usage

You should extend the abstract PHPLRPM\Cluster\ShardingConfigurationSource class and implement a nullary (zero-argument) constructor which will be initializing instances of PHPLRPM\ConfigurationSource, PHPLRPM\Cluster\Providers\ClusterConfigurationProvider and PHPLRPM\Cluster\Filters\ShardingConfigurationFilter:

namespace MyNamespace;
use PHPLRPM\Cluster\ShardingConfigurationSource;

class MyLRPMWorkerShardingConfiguration extends ShardingConfigurationSource
{
    public function __construct()
    {
        //instance of PHPLRPM\ConfigurationSource
        $this->confSource = new MyLRPMWorkerConfiguration()
        //instance of PHPLRPM\Cluster\Providers\ClusterConfigurationProvider
        $this->clusterConfProvider = new EnvironmentBasedClusterConfigurationProvider();
        //instance of PHPLRPM\Cluster\Filters\ShardingConfigurationFilter
        $this->configurationFilter = new BalancedShardingConfigurationFilter();
    }
}

Then you may provide MyLRPMWorkerShardingConfiguration as a regular ConfigurationSource for PHP-LRPM, e.g.

lrpm '\MyNamespace\MyLRPMWorkerShardingConfiguration'

See https://github.com/vrza/php-lrpm#usage for more details.

Sharding Strategies

You can either write your own ShardingConfigurationFilter or use one of the built-in filters.

Balanced

Use the BalancedShardingConfigurationFilter when either:

  • scaling involves restarting the entire cluster

  • perfect load balancing is necessary

Pros Cons

Perfect load balancing

Potentially large number of disrupted processes when rescaling

Rendezvous Hashing

Use the RendezvousHashingShardingConfigurationFilter when both:

  • minimal worker process disruption is highly desirable

  • load balancing biased towards certain nodes is tolerable

Pros Cons

Minimal disruption when rescaling

Biased load balancing

Simple hashing

Use the HashingShardingConfigurationFilter to achieve:

  • decent (but not perfect) load balancing

  • some (but not complete) worker process disruption when cluster is rescaled

Pros Cons

Strikes a balance between load balancing and disruption

Guarantees neither perfect load balancing nor minimal disruption

Cluster Configuration and Providers

Cluster configuration parameters are

  • total number of nodes in the cluster

  • zero-based index of current node

You can either write your own ClusterConfigurationProvider or use one of the built-in providers.

Environment-based Cluster Configuration Provider

Use the EnvironmentBasedClusterConfigurationProvider to load cluster configuration from environment variables PHP_LRPM_NUMBER_OF_INSTANCES and PHP_LRPM_INSTANCE_NUMBER. Default variable names can be overridden.

File-based Cluster Configuration Provider

Use the FileBasedClusterConfigurationProvider to load cluster configuration from a JSON configuration file, e.g.:

{
    "numberOfInstances": 3,
    "instanceNumber" : 2
}

Installation

Assuming you have PHP Composer installed, and that the composer executable is in your $PATH:

composer require php-lrpm/php-lrpm-cluster

统计信息

  • 总下载量: 6.9k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 2
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: BSD-3-Clause
  • 更新时间: 2024-03-26