nytris/memcached 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

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

nytris/memcached

最新稳定版本:v0.0.9

Composer 安装命令:

composer create-project nytris/memcached

包简介

README 文档

README

Build Status

Standard PECL ext-memcached with dynamic mode/auto-discovery support for Memcached AWS ElastiCache.

Why?

Use the stable and performant standard ext-memcached from PECL while still taking advantage of AWS ElastiCache auto-discovery.

How does it work?

References to ext-memcached's Memcached class will be replaced using PHP Code Shift to references to the src/Memcached/MemcachedHook.php class in this package.

Additionally, session connections can also take advantage of auto-discovery.

When adding a server, if dynamic mode is enabled for this package in nytris.config.php, the AWS ElastiCache auto-discovery feature will be used, and all discovered nodes added to the Memcached instance.

Currently, by default the following references to Memcached will be hooked, but this can be customised using new MemcachedPackage(memcachedClassHookFilter: ...):

Usage

Install this package with Composer:

$ composer require nytris/memcached tasque/tasque tasque/event-loop

Configure Nytris platform:

nytris.config.php

<?php

declare(strict_types=1);

use Nytris\Boot\BootConfig;
use Nytris\Boot\PlatformConfig;
use Nytris\Memcached\Library\ClientMode;
use Nytris\Memcached\MemcachedPackage;
use Tasque\EventLoop\TasqueEventLoopPackage;
use Tasque\TasquePackage;

$bootConfig = new BootConfig(new PlatformConfig(__DIR__ . '/var/cache/nytris/'));

$bootConfig->installPackage(new TasquePackage(
    // Disabled for this example, but also works with Tasque in preemptive mode.
    preemptive: false
));
$bootConfig->installPackage(new TasqueEventLoopPackage());
$bootConfig->installPackage(new MemcachedPackage(
    // Use dynamic mode/auto-discovery when connecting to an AWS ElastiCache cluster.
    clientMode: ClientMode::DYNAMIC
));

return $bootConfig;

Optimal host resolution

Where possible, the private IP returned from AWS ElastiCache auto-discovery will be used. Otherwise, if the $dnsResolverFactory constructor argument is provided to MemcachedPackage, the host returned will be resolved by the given ReactPHP DNS resolver, which can then be cached, unlike the PECL ext-memcached DNS resolution which is not.

$ composer require nytris/dns

nytris.config.php

<?php

declare(strict_types=1);

use Nytris\Dns\Dns;
use Nytris\Memcached\MemcachedPackage;

// ...

$bootConfig->installPackage(new MemcachedPackage(
    // Use dynamic mode/auto-discovery when connecting to an AWS ElastiCache cluster.
    clientMode: ClientMode::DYNAMIC,

    // Perform DNS lookups via ReactPHP DNS resolver.
    // Note that $cachePath is provided as a convenient way to refer to the cache directory
    // if using an on-disk cache.
    dnsResolverFactory: static fn (string $cachePath) => (new Dns())->createResolver(
        cache: new ReactCacheAdapter(
            // Cache DNS across requests in APCu.
            psrCachePool: new LightApcuAdapter(
                namespace: 'nytris.react_dns',
            )
        )
    )
));

// ...

Sessions support

Sessions are supported with the native ext-memcached session handling via Nytris\Memcached\Session\NativeMemcachedSessionHandler.

This will perform auto-discovery if enabled when the config endpoint is provided with either the session.save_path INI setting or the $savePath constructor argument.

<?php

use Nytris\Memcached\Session\NativeMemcachedSessionHandler;

session_set_save_handler(new NativeMemcachedSessionHandler());

See also

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-08-09