进度阐明(20220902)
imi-zookeeper 目前实现了配置核心的性能,因为 imi-config-center 形象出了接口,所以应用上和 imi-nacos、imi-etcd 十分相似。
与此同时,曾经开始了为 imi 接入微服务注册核心的工作,首个接入的注册核心是 Nacos。
目前曾经实现了向 Nacos 注册服务,接下来的工作是实现通过注册核心调用服务。
在实现 imi-zookeeper 的时候,应用到了 2 个扩大,别离是 php-zookeeper 和 swoole-zookeeper。测试时发现了扩大中的一些问题,棘手修复了一波。
其中 swoole-zookeeper 的 PR 曾经合并:https://github.com/swoole/ext…
php-zookeeper 的 PR 截止发稿时还未合并:https://github.com/php-zookee…
在开发开源我的项目的时候,用到了其它的开源我的项目,发现问题帮忙解决,这才是真正的开源。
我集体和 imi 都欢送各位来参加开源,共建能力让我的项目倒退得越来越好。
宇润在 imi 周围年直播流动中,向大家介绍了下一步的开发计划。
其中,明确指出了 imi 开发组要大力发展微服务生态,为 PHP 微服务添砖加瓦。
第一步,是为 imi 接入配置核心。
目前曾经实现了 imi-config-center 配置核心组件的抽象化。
实现并公布了 v2.1.0-beta
版本:
- imi-nacos
- imi-etcd
- imi-zookeeper
都已编写并通过了自动化集成测试,有测试用例是 imi 开发组对 imi 相干开发的根本要求
imi-zookeeper 的应用
装置
- Swoole 用户请装置 swoole-zookeeper 扩大。
- 非 Swoole 用户请装置 php-zookeeper 扩大。
composer require imiphp/imi-zookeeper:~2.1.0
应用阐明
配置
@app.beans
:
[
'ConfigCenter' => [
// 'mode' => \Imi\ConfigCenter\Enum\Mode::WORKER, // 工作过程模式
'mode' => \Imi\ConfigCenter\Enum\Mode::PROCESS, // 过程模式
'configs' => [
'zookeeper' => [
'driver' => \Imi\ZooKeeper\Config\SwooleZooKeeperConfigDriver::class, // Swoole 驱动
// 'driver' => \Imi\ZooKeeper\Config\ZooKeeperConfigDriver::class, // 非 Swoole 驱动
// 客户端连贯配置
'client' => ['host' => env('IMI_ZOOKEEPER_HOST', '127.0.0.1:2181'), // 主机名: 端口
'timeout' => 10, // 网络申请超时工夫,单位:秒
],
// 监听器配置
'listener' => [
'timeout' => 30000, // 配置监听器长轮询超时工夫,单位:毫秒
'failedWaitTime' => 3000, // 失败后期待重试工夫,单位:毫秒
'savePath' => Imi::getRuntimePath('config-cache'), // 配置保留门路,默认为空不保留到文件。php-fpm 模式请肯定要设置!'fileCacheTime' => 30, // 文件缓存工夫,默认为 0 时不受缓存影响,此配置只影响 pull 操作。php-fpm 模式请肯定要设置为大于 0 的值!'pollingInterval' => 10000, // 客户端轮询间隔时间,单位:毫秒
],
// 配置项
'configs' => [
'zookeeper' => [
'key' => 'imi-zooKeeper-key1',
'type' => 'json', // 配置内容类型
],
],
],
],
],
]
获取配置
\Imi\Config::get('zookeeper'); // 对应 imi-zooKeeper-key1
写入配置
/** @var \Imi\ConfigCenter\ConfigCenter $configCenter */
$configCenter = App::getBean('ConfigCenter');
$name = 'imi-zooKeeper-key1';
$value = json_encode(['imi' => 'niubi']);
$configCenter->getDriver('zookeeper')->push($name, $value);
配置核心的益处
咱们通常会把一些配置放到专门的配置文件里,个别会随着代码散发和部署。
在须要批改配置的时候,须要从新走发版流程,显得十分轻便和不不便。
这时候,配置核心的作用就体现了。
咱们从配置核心拿配置,而不是写死在我的项目里,能够比拟灵便地实现不中断服务的配置公布。
imi 配置核心组件设计
监听模式
工作过程模式
每个过程本人监听,实用于 Swoole 环境。
过程模式
由一个专门的过程监听,并告诉到其它过程。实用于 Swoole、Workerman 环境。
对配置核心压力更小。
php-fpm 模式比拟非凡,是走的文件缓存逻辑。超过肯定工夫才去申请配置核心,获取数据,实时性有肯定影响。
监听形式
客户端轮询
客户端定时申请配置核心,对配置核心服务端压力较大,然而最为通用。
服务端推送(长轮询)
如果配置核心反对服务端推送(长轮询),倡议用这个形式,对配置核心服务端压力较小。
近期开发计划
- 持续保护迭代 imi 外围性能万年不变
- 开发更多 imi 配置核心的具体实现(Apollo、Zookeeper、Consul)
如果你对开源和 imi 我的项目感兴趣,无妨一起来开发。
只需开发一个受认可的 imi 组件或基于 imi 的开源我的项目,即可成为 imi 开发组成员之一。
imi 介绍
imi 是一款反对长连贯微服务分布式的 PHP 开发框架,它能够运行在 PHP-FPM、Swoole、Workerman、RoadRunner 等多种容器环境下。
imi 领有丰盛的性能组件,v2.1 版本内置了 2 个分布式长连贯服务的解决方案。
imi 框架当初曾经稳固运行在:文旅电商平台、物联网充电云平台、停车云平台、领取微服务、短信微服务、钱包微服务、卡牌游戏服务端、数据迁徙服务(虎扑)等我的项目中。
imi 第一个版本公布于 2018 年 6 月 21 日
我的项目地址
- Github:https://github.com/imiphp/imi
- Gitee:https://gitee.com/yurunsoft/IMI
- 官网:https://www.imiphp.com/
- 文档:https://doc.imiphp.com/v2.1/
取得过的荣誉
- InfoQ 举荐:https://mp.weixin.qq.com/s/oB…
- 码云 GVP 我的项目:https://gitee.com/yurunsoft/IMI
开发组成员
宇润(张润宇),94 年植树节生,无锡人。Swoole 开发组成员、php-src 内核贡献者、TDengine 贡献者、2021 中国开源码力榜前百名。
开源我的项目包含但不限于:imi、PaySDK、YurunHttp、Guzzle-Swoole、YurunOAuthLogin、ChineseUtil 等
Github:https://github.com/Yurunsoft
NHZEX,次要奉献:代码优化、bug 修复、测试优化、PHP 8.1 兼容
Github:https://github.com/NHZEX
封尘,93 年,狮子座,宣城人。imi 框架开发组成员,开源作者。
开源我的项目包含但不限于:fcup、mjs、university font icon library、fcphp、fcblog 等
次要奉献:imi 晚期用户,imi 1.0、2.0 官网页面作者
Github:https://github.com/lovefc
阿诺 Eno,99 年出世,成都人,全栈程序员(主后端),医学生(本科护理学业余),硕士二战考生。
罕用编程语言 PHP、NodeJs 等,imi 框架开发组成员。
一名热衷于用代码发明世界的护士小哥,独爱 PHP,大学期间主导过 20 多个次要以 PHP 为后端的 WEB 我的项目的开发,具备丰盛的码农教训,也善于接国内外软件毕业设计。
次要奉献:文档编写、bug 修复
Github:https://github.com/Gumo666
青玄 Chris,96 年,广东人,时长 n 年半的 PHP 练习生,喜爱唱 \ 跳 \RAP\PHP , imi 框架开发组成员
喜爱参加开源用爱发电,imi 框架开发组成员,EasySwoole 社区贡献者
次要奉献:imi-etcd 作者
Github:https://github.com/ChrisLeeAr…