apntalk/ami-client 问题修复 & 功能扩展

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

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

apntalk/ami-client

最新稳定版本:v1.0.1

Composer 安装命令:

composer require apntalk/ami-client

包简介

High-performance, non-blocking Asterisk Manager Interface (AMI) client for PHP 8.4+

README 文档

README

Dialer-optimized, multi-server AMI client for PHP/Laravel.

Key Features

  • Multi-server tick multiplexing with AmiClientManager::tickAll().
  • Non-blocking runtime contract (NBRC) for tick/connect/reconnect behavior.
  • Strong per-node isolation across correlation, parsing, queues, and reconnect state.
  • Bounded buffers/queues with backpressure controls.
  • Typed actions plus GenericAction for arbitrary AMI actions.
  • Laravel 12 adapter layer (src/Laravel) with ami:listen.

Production Readiness

Use current gate artifacts as the source of truth (do not rely on hardcoded scores in README).

Resolve the latest files by UTC timestamp in filename:

  • Latest score/verdict: docs/ami-client/production-readiness/audits/*-production-readiness-score.md
  • Latest findings: docs/ami-client/production-readiness/findings/*-findings.md
  • Latest chaos final suite: docs/ami-client/chaos/reports/*-final-chaos-suite-results.md
  • Latest remediation report/index: docs/ami-client/production-readiness/reports/*-pr-remediation-report.md and *-pr-remediation-artifacts-index.md

If the latest chaos suite is not green, release notes must include an accepted-outcome decision record:

Install (Core)

composer require apntalk/ami-client

Requirements:

  • PHP >=8.4

Install (Laravel Adapter)

The core package is framework-agnostic. To use src/Laravel/*, install Laravel components in your app:

composer require illuminate/support illuminate/console

Quickstart (Laravel 12)

use Apn\AmiClient\Cluster\AmiClientManager;
use Apn\AmiClient\Protocol\Ping;

$manager = app(AmiClientManager::class);
$manager->default()->send(new Ping());

GenericAction example:

use Apn\AmiClient\Cluster\AmiClientManager;
use Apn\AmiClient\Protocol\GenericAction;

app(AmiClientManager::class)
    ->server('node_1')
    ->send(new GenericAction('QueueSummary', ['Queue' => 'support']));

Start listener worker:

php artisan ami:listen --server=node_1
# or all configured servers
php artisan ami:listen --all

Quickstart (Pure PHP)

use Apn\AmiClient\Cluster\ConfigLoader;
use Psr\Log\NullLogger;

$config = require __DIR__ . '/config/ami-client.php';
$manager = ConfigLoader::load($config, new NullLogger());

while (true) {
    $manager->tickAll(25); // bounded selector wait (ms), avoids hot-spin
}

Docs

Contributing / Governance

NBRC is authoritative for runtime behavior. Execute work by active batch/task files, and keep delta/task updates batch-scoped rather than appending to large plan files.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-02-27

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固