🚀 Hyperf 发布 Nats 组件及 v1.1.5 版本 | 企业级的 PHP 微服务云原生协程框架

更新于 2019-11-07  çº¦ 8 分钟

更新内容

本周更新主要为新增 hyperf/nats 组件,Nats 是一个开源、轻量级、高性能的云原生消息系统,本组件使 Hyperf 与 Nats 进行交互提供了可能性。同时对 Consul 集群作为服务注册中心提供了支持,以及为 Redis 集群提供了客户端支持,同时我们还修复了一些组件的 🐛Bug,使 Hyperf 1.1.* 系列版本更加的健壮了,发布于 1.1.5 版,建议使用 1.1 的用户更新。
直接访问 官网 hyperf.io 或 文档 hyperf.wiki 查看。

新增

  • #812 新增计划任务在集群下仅执行一次的支持;
  • #820 新增 hyperf/nats 组件;
  • #832 新增 Hyperf\Utils\Codec\Json;
  • #833 新增 Hyperf\Utils\Backoff;
  • #852 为 Hyperf\Utils\Parallel 新增 clear() 方法来清理所有已添加的回调;
  • #854 新增 Hyperf\GraphQL\GraphQLMiddleware 用于解析 GraphQL 请求;
  • #859 新增 Consul 集群的支持,现在可以从 Consul 集群中拉取服务提供者的节点信息;
  • #873 新增 Redis 集群的客户端支持;

修复

  • #831 修复 Redis 客户端连接在 Redis Server 重启后不会自动重连的问题;
  • #835 修复 Request::inputs 方法的默认值参数与预期效果不一致的问题;
  • #841 修复数据库迁移在多数据库的情况下连接无效的问题;
  • #844 修复 Composer 阅读器不支持根命名空间的用法的问题;
  • #846 修复 Redis 客户端的 scan, hScan, zScan, sScan 无法使用的问题;
  • #850 修复 Logger group 在 name 一样时不生效的问题;

优化

  • #832 优化了 Response 对象在转 JSON 格式时的异常处理逻辑;
  • #840 使用 \Swoole\Timer::* 来替代 swoole_timer_* 函数;
  • #859 优化了 RPC 客户端去 Consul 获取健康的节点信息的逻辑;

关于 Hyperf

Hyperf 是基于 Swoole 4.4+ 实现的高性能、高灵活性的 PHP 协程框架,内置协程服务器及大量常用的组件,性能较传统基于 PHP-FPM 的框架有质的提升,提供超高性能的同时,也保持着极其灵活的可扩展性,标准组件均基于 PSR 标准 实现,基于强大的依赖注入设计,保证了绝大部分组件或类都是 可替换 与 可复用 的。

框架组件库除了常见的协程版的 MySQL 客户端、Redis 客户端,还为您准备了协程版的 Eloquent ORM、WebSocket 服务端及客户端、JSON RPC 服务端及客户端、GRPC 服务端及客户端、OpenTracing(Zipkin, Jaeger) 客户端、Guzzle HTTP 客户端、Elasticsearch 客户端、Consul 客户端、ETCD 客户端、AMQP 组件、Nats 组件、Apollo 配置中心、阿里云 ACM 应用配置管理、ETCD 配置中心、基于令牌桶算法的限流器、通用连接池、熔断器、Swagger 文档生成、Swoole Tracker、Blade 和 Smarty 视图引擎、Snowflake 全局ID生成器 等组件,省去了自己实现对应协程版本的麻烦。

Hyperf 还提供了 基于 PSR-11 的依赖注入容器、注解、AOP 面向切面编程、基于 PSR-15 的中间件、自定义进程、基于 PSR-14 的事件管理器、Redis/RabbitMQ 消息队列、自动模型缓存、基于 PSR-16 的缓存、Crontab 秒级定时任务、i18n 国际化、Validation 表达验证 等非常便捷的功能,满足丰富的技术场景和业务场景,开箱即用。

框架初衷

尽管现在基于 PHP 语言开发的框架处于一个百花争鸣的时代,但仍旧未能看到一个优雅的设计与超高性能的共存的完美框架,亦没有看到一个真正为 PHP 微服务铺路的框架,此为 Hyperf 及其团队成员的初衷,我们将持续投入并为此付出努力,也欢迎你加入我们参与开源建设。

设计理念

Hyperspeed + Flexibility = Hyperf,从名字上我们就将 超高速 和 灵活性 作为 Hyperf 的基因。
   

  • 对于超高速,我们基于 Swoole 协程并在框架设计上进行大量的优化以确保超高性能的输出。   
  • 对于灵活性,我们基于 Hyperf 强大的依赖注入组件,组件均基于 PSR 标准 的契约和由 Hyperf 定义的契约实现,达到框架内的绝大部分的组件或类都是可替换的。   

基于以上的特点,Hyperf 将存在丰富的可能性,如实现 单体 Web 服务,API 服务,网关服务,分布式中间件,微服务架构,游戏服务器,物联网(IOT)等。

文档齐全

我们投入了大量的时间用于文档的建设,以解决各种因为文档缺失所带来的问题,文档上也提供了大量的示例,对新手同样友好。
Hyperf 官方开发文档

生产可用

我们为组件进行了大量的单元测试以保证逻辑的正确,目前存在 1163 个单测共 3427 个断言条件,同时维护了高质量的文档,在 Hyperf 正式对外开放(2019年6月20日)之前,便已经过了严酷的生产环境的考验,我们才正式的对外开放该项目,现在已有很多的大型互联网企业都已将 Hyperf 部署到了自己的生产环境上并稳定运行。

官网及交流

Github 👈👈👈👈👈 点 Star 支持我们   
Gitee 码云 👈👈👈👈👈 点 Star 支持我们   
Hyperf 官网
Hyperf 文档   
QQ 群: 862099724  

阅读 266更新于 2019-11-07

推荐阅读
目录