imi 是一款支持长连接微服务分布式的 PHP 开发框架,它可以运行在 PHP-FPM、Swoole、Workerman 多种容器环境下。
imi 拥有丰富的功能组件,v2.0 版本内置了 2 个分布式长连接服务的解决方案。
imi 框架现在已经稳定运行在:文旅电商平台、物联网充电云平台、停车云平台、支付微服务、短信微服务、钱包微服务、卡牌游戏服务端、数据迁移服务(虎扑)等项目中。
imi 第一个版本发布于 2018 年 6 月 21 日
imi 框架入门教程(免费11集全)https://www.bilibili.com/video/av78158909
imi 框架进阶教程——五子棋游戏开发(免费7集全)https://space.bilibili.com/768718/channel/detail?cid=136926
- Http、Http2、WebSocket、TCP、UDP、MQTT 服务器
- 分布式长连接解决方案(消息队列模式、网关模式)
- MySQL 连接池 (主从+负载均衡)
- Redis 连接池 (主从+负载均衡)
- 超好用的 ORM (Db、Redis、Tree)
- 毫秒级热更新
- AOP
- Bean 容器
- 缓存 (Cache)
- 配置读写 (Config)
- 枚举 (Enum)
- 事件 (Event)
- 门面 (Facade)
- 验证器 (Validate)
- 锁 (Lock)
- 日志 (Log)
- 异步任务 (Task)
- MQTT
- RPC
- gRPC
- Hprose
- 消息队列
- AMQP (支持 AMQP 协议的消息队列都可用,如:RabbitMQ)
- Kafka
- JWT (在 imi 框架中非常方便地接入 jwt)
- 权限控制
- Smarty 模版引擎
- 限流
- 跨进程变量共享
- 雪花算法发号器
- Swagger API 文档生成
- Swoole Tracker
这些组件都已经在 imi 主仓库中维护
创建 Http Server 项目:composer create-project imiphp/project-http:~2.0
创建 WebSocket Server 项目:composer create-project imiphp/project-websocket:~2.0
创建 TCP Server 项目:composer create-project imiphp/project-tcp:~2.0
创建 UDP Server 项目:composer create-project imiphp/project-udp:~2.0
创建 MQTT Server 项目:composer create-project imiphp/project-mqtt:~2.0
推荐使用 Swoole 官方 Docker:https://github.com/swoole/docker-swoole
不论您使用 imi 开发的是个人项目还是公司项目,不管是开源还是商业,都可以向我们提交案例。
案例可能会被采纳并展示在 imi 官网、Swoole 官网等处,这对项目的推广和发展有着促进作用。
提交格式:
- 项目名称
- 项目介绍
- 项目地址(官网/下载地址/Github等至少一项)
- 联系方式(电话/邮箱/QQ/微信等至少一项)
- 项目截图(可选)
- 感言
项目介绍: 基于imi开发的高性能高并发分布式(千万级设备)的能源销售管理平台,提供多场景充电桩、售电柜、换电柜、智能电池等设备接入,开放API第三方应用五分钟即可完成新能源物联网售电设备接入
项目介绍: 本项目是基于imi 2.0的高性能 MVC 实战项目(一人完成开发),搭配 nginx 实现前端静态资源的访问及缓存,View 层很任性地采用了原生模板渲染。项目中大量使用了 imi 提供的缓存注解,优化数据查询的性能,点赞等场景使用了 imi 提供的锁机制保证并发场景下的数据一致性。强推大家使用 imi 开发此类项目!
项目介绍: 从最早的建站初心是为了自己方便!放到网络的以来,当流量越来越大的时候是要考虑升级配置还是重构项目,前几天 git 上看到 imiphp,索性就拿来实践一下,也是简单就重构出了所有页面,模版引擎引入了 TP 的 think-template,整个重构也就一天不到,所以 imiphp 确实很容易上手!加油!
- [虎扑 - 上亿数据迁移服务]
项目介绍: 随着数据规模的越来越大,mysql已经不能适用大数据多维度的查询,需要用ES等一类的搜索引擎,进行多维度的分词查询,MYSQL现阶段使用按天分表存储,不能满足跨天的长时间查询。
如何以最快的速度完成数据迁移,将数据库中的数据迁移到ES中,是需要评估的一个重要技术点。
在高IO密集的场景下,单次请求需要80毫秒,imi运用Swoole协程,不断在用户态和内核态之间进行切换,充分利用计算机CPU,从而能快速完成海量数据迁移。
根据普罗米修斯的监控统计,在 两台 2C 4G的机器上,imi以每秒钟同步1000~1500条的同步速度,完成了上亿级别的数据迁移。
博文地址:https://blog.csdn.net/qq_32783703/article/details/113576741
imi 遵循 木兰宽松许可证(Mulan PSL v2) 开源协议发布,并提供免费使用。
感谢以下开源项目 (按字母顺序排列) 为 imi 提供强力支持!
- doctrine/annotations (PHP 注解处理类库)
- PHP (没有 PHP 就没有 imi)
- Swoole (没有 Swoole 就没有 imi)
你想出现在贡献者列表中吗?
你可以做的事(包括但不限于以下):
- 纠正拼写、错别字
- 完善注释
- bug修复
- 功能开发
- 文档编写
- 教程、博客分享
最新代码以
dev
分支为准,提交PR
也请合并至dev
分支!
提交 Pull Request
到本仓库,你就有机会成为 imi 的作者之一!
参与框架开发教程详见:<doc/adv/devp.md>
开源不求盈利,多少都是心意,生活不易,随缘随缘……