# imi
**Repository Path**: chew/IMI
## Basic Information
- **Project Name**: imi
- **Description**: imi 是基于 Swoole 的 PHP 协程开发框架,它支持 Http、Http2、WebSocket、TCP、UDP、MQTT 等主流协议的服务开发,特别适合互联网微服务、即时通讯聊天im、物联网等场景!。QQ群:17916227
- **Primary Language**: PHP
- **License**: Not specified
- **Default Branch**: 2.0
- **Homepage**: https://www.imiphp.com/
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 130
- **Created**: 2021-09-18
- **Last Updated**: 2021-09-18
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# imi - PHP 长连接微服务分布式开发框架
[](https://packagist.org/packages/imiphp/imi)

[](https://secure.php.net/)
[](https://github.com/swoole/swoole-src)
[](https://doc.imiphp.com/v2.0/)
[](https://github.com/imiphp/imi/blob/master/LICENSE)
[](https://gitee.com/yurunsoft/IMI/stargazers)
## 介绍
imi 是一款支持长连接微服务分布式的 PHP 开发框架,它可以运行在 PHP-FPM、Swoole、Workerman 多种容器环境下。
imi 拥有丰富的功能组件,v2.0 版本内置了 2 个分布式长连接服务的解决方案。
imi 框架现在已经稳定运行在:文旅电商平台、物联网充电云平台、停车云平台、支付微服务、短信微服务、钱包微服务、卡牌游戏服务端、数据迁移服务(虎扑)等项目中。
> imi 第一个版本发布于 2018 年 6 月 21 日
imi 框架交流群:17916227 [](https://jq.qq.com/?_wv=1027&k=5wXf4Zq)
## 官方视频教程(完全免费)
imi 框架入门教程(免费11集全)
imi 框架进阶教程——五子棋游戏开发(免费7集全)
### 核心组件
* Http、Http2、WebSocket、TCP、UDP、MQTT 服务器
* 分布式长连接解决方案(消息队列模式、网关模式)
* MySQL 连接池 (主从+负载均衡)
* Redis 连接池 (主从+负载均衡)
* 超好用的 ORM (Db、Redis、Tree)
* 毫秒级热更新
* AOP
* Bean 容器
* 缓存 (Cache)
* 配置读写 (Config)
* 枚举 (Enum)
* 事件 (Event)
* 门面 (Facade)
* 验证器 (Validate)
* 锁 (Lock)
* 日志 (Log)
* 异步任务 (Task)
### 扩展组件
* [MQTT](src/Components/mqtt)
* [RPC](src/Components/rpc)
* [gRPC](src/Components/grpc)
* [Hprose](src/Components/hprose)
* [消息队列](src/Components/queue)
* [AMQP](src/Components/amqp) (支持 AMQP 协议的消息队列都可用,如:RabbitMQ)
* [Kafka](src/Components/kafka)
* [JWT](src/Components/jwt) (在 imi 框架中非常方便地接入 jwt)
* [权限控制](src/Components/access-control)
* [Smarty 模版引擎](src/Components/smarty)
* [限流](src/Components/rate-limit)
* [跨进程变量共享](src/Components/shared-memory)
* [雪花算法发号器](src/Components/snowflake)
* [Swagger API 文档生成](src/Components/apidoc)
* [Swoole Tracker](src/Components/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`
[完全开发手册](https://doc.imiphp.com/v2.0/)
## 运行环境
* Linux 系统 (Swoole 不支持在 Windows 上运行)
* [PHP](https://php.net/) >= 7.4
* [Composer](https://getcomposer.org/) >= 2.0
* [Swoole](https://www.swoole.com/) >= 4.7.0
* Redis、PDO 扩展
## Docker
推荐使用 Swoole 官方 Docker:
## 成功案例
不论您使用 imi 开发的是个人项目还是公司项目,不管是开源还是商业,都可以向我们提交案例。
案例可能会被采纳并展示在 imi 官网、Swoole 官网等处,这对项目的推广和发展有着促进作用。
**提交格式:**
* 项目名称
* 项目介绍
* 项目地址(官网/下载地址/Github等至少一项)
* 联系方式(电话/邮箱/QQ/微信等至少一项)
* 项目截图(可选)
* 感言
### 案例展示
* [腾悦物联](https://www.teny.tech/)

**项目介绍:** 基于imi开发的高性能高并发分布式(千万级设备)的能源销售管理平台,提供多场景充电桩、售电柜、换电柜、智能电池等设备接入,开放API第三方应用五分钟即可完成新能源物联网售电设备接入
---
* [Adorecipe鸡尾酒资源库](https://adorecipe.com)

**项目介绍:** 本项目是基于imi 2.0的高性能 MVC 实战项目(一人完成开发),搭配 nginx 实现前端静态资源的访问及缓存,View 层很任性地采用了原生模板渲染。项目中大量使用了 imi 提供的缓存注解,优化数据查询的性能,点赞等场景使用了 imi 提供的锁机制保证并发场景下的数据一致性。强推大家使用 imi 开发此类项目!
---
* [看个蛋影视搜索 - 全网影视资源搜索平台](http://www.kangedan.com/)

**项目介绍:** 从最早的建站初心是为了自己方便!放到网络的以来,当流量越来越大的时候是要考虑升级配置还是重构项目,前几天 git 上看到 imiphp,索性就拿来实践一下,也是简单就重构出了所有页面,模版引擎引入了 TP 的 think-template,整个重构也就一天不到,所以 imiphp 确实很容易上手!加油!
---
* [虎扑 - 上亿数据迁移服务]

**项目介绍:** 随着数据规模的越来越大,mysql已经不能适用大数据多维度的查询,需要用ES等一类的搜索引擎,进行多维度的分词查询,MYSQL现阶段使用按天分表存储,不能满足跨天的长时间查询。
如何以最快的速度完成数据迁移,将数据库中的数据迁移到ES中,是需要评估的一个重要技术点。
在高IO密集的场景下,单次请求需要80毫秒,imi运用Swoole协程,不断在用户态和内核态之间进行切换,充分利用计算机CPU,从而能快速完成海量数据迁移。
根据普罗米修斯的监控统计,在 两台 2C 4G的机器上,imi以每秒钟同步1000~1500条的同步速度,完成了上亿级别的数据迁移。
博文地址:
---
## 版权信息
imi 遵循 木兰宽松许可证(Mulan PSL v2) 开源协议发布,并提供免费使用。
## 鸣谢
感谢以下开源项目 (按字母顺序排列) 为 imi 提供强力支持!
* [doctrine/annotations](https://github.com/doctrine/annotations) (PHP 注解处理类库)
* [PHP](https://php.net/) (没有 PHP 就没有 imi)
* [Swoole](https://www.swoole.com/) (没有 Swoole 就没有 imi)
## 贡献者
[](https://github.com/imiphp/imi/graphs/contributors)
你想出现在贡献者列表中吗?
你可以做的事(包括但不限于以下):
* 纠正拼写、错别字
* 完善注释
* bug修复
* 功能开发
* 文档编写
* 教程、博客分享
> 最新代码以 `dev` 分支为准,提交 `PR` 也请合并至 `dev` 分支!
提交 `Pull Request` 到本仓库,你就有机会成为 imi 的作者之一!
参与框架开发教程详见:
## 捐赠

开源不求盈利,多少都是心意,生活不易,随缘随缘……