hyperf / gotask
Go 语言版的 Swoole TaskWorker 替代方案
v3.0.1
2023-12-20 03:21 UTC
Requires
- php: >=8.1
- ext-swoole: >=5.0
- hyperf/pool: ^3.0
- hyperf/process: ^3.0
- spiral/goridge: ^2.4
- symfony/event-dispatcher: ^6.3
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.21
- hyperf/command: ^3.0
- hyperf/config: ^3.0
- hyperf/di: ^3.0
- hyperf/framework: ^3.0
- hyperf/testing: ^3.0
- mockery/mockery: ^1.6
- phpstan/phpstan: ^1.10
- swoole/ide-helper: ^5.0
- dev-master / 3.0.x-dev
- v3.0.1
- v3.0.0
- v3.0.0-alpha
- v2.2.10
- v2.2.9
- v2.2.8
- v2.2.7
- v2.2.6
- v2.2.5
- v2.2.4
- v2.2.3
- v2.2.2
- v2.2.1
- v2.2.0
- v2.1.x-dev
- v2.1.1
- v2.1.0
- v2.0.3
- v2.0.2
- v2.0.1
- v2.0.0
- v1.0.2
- v1.0.1
- v1.0.0
- v0.3.0
- v0.2.0
- v0.1.3
- v0.1.2
- 0.1.1
- 0.1.0
- 0.0.3
- dev-dependabot/composer/spiral/goridge-tw-2.4or-tw-4.0
- dev-dependabot/composer/symfony/event-dispatcher-tw-6.3or-tw-7.0
- dev-dependabot/composer/friendsofphp/php-cs-fixer-tw-2.14or-tw-3.0
- dev-perm
This package is auto-updated.
Last update: 2024-08-31 11:34:00 UTC
README
英文 | 中文
GoTask 在 Swoole 中启动一个 Go 进程作为 Sidecar,并建立一个双向 IPC,以便将繁重任务卸载到 Go。可以将其视为 Go 中的 Swoole Taskworker。
composer require hyperf/gotask
特性
- 高性能,占用资源小。
- 基于 Swoole 4 协程 socket API。
- 支持 Unix Socket、TCP 和 stdin/stdout 管道。
- 支持 PHP 到 Go 和 Go 到 PHP 的调用。
- 自动 Sidecar 生命周期管理。
- 正确处理远程错误。
- 支持结构化有效载荷和二进制有效载荷。
- Sidecar API 与 net/rpc 兼容。
- 内置连接池。
- 可选集成 Hyperf 框架。
非常适合
- Swoole 中的阻塞操作,例如 MongoDB 查询。
- 密集型 CPU 操作,例如编码和解码。
- 利用 Go 生态系统,例如 Kubernetes 客户端。
要求
- PHP 7.2+
- Go 1.13+
- Swoole 4.4LTS+
- Hyperf 1.1+ (可选)
任务交付演示
package main import ( "github.com/hyperf/gotask/v2/pkg/gotask" ) type App struct{} func (a *App) Hi(name string, r *interface{}) error { *r = map[string]string{ "hello": name, } return nil } func main() { gotask.SetAddress("127.0.0.1:6001") gotask.Register(new(App)) gotask.Run() }
<?php use Hyperf\GoTask\IPC\SocketIPCSender; use function Swoole\Coroutine\run; require_once "../vendor/autoload.php"; run(function(){ $task = new SocketIPCSender('127.0.0.1:6001'); var_dump($task->call("App.Hi", "Hyperf")); // [ "hello" => "Hyperf" ] });
资源
英文文档尚未完成!请先查看示例。
基准测试
https://github.com/reasno/gotask-benchmark
致谢
- https://github.com/spiral/goridge 提供了 IPC 协议。
- https://github.com/twose 帮助创建了此项目。