hyperf简介
2.0 介绍
Hyperf 是基于 Swoole 4.5+ 实现的高性能、高灵活性的 PHP 协程框架,内置协程服务器及大量常用的组件,性能较传统基于 PHP-FPM 的框架有质的提升,提供超高性能的同时,也保持着极其灵活的可扩展性,标准组件均基于 PSR 标准 实现,基于强大的依赖注入设计,保证了绝大部分组件或类都是 可替换 与 可复用 的。
框架组件库除了常见的协程版的 MySQL 客户端、Redis 客户端,还为您准备了协程版的 Eloquent ORM、WebSocket 服务端及客户端、JSON RPC 服务端及客户端、GRPC 服务端及客户端、Zipkin/Jaeger (OpenTracing) 客户端、Guzzle HTTP 客户端、Elasticsearch 客户端、Consul 客户端、ETCD 客户端、AMQP 组件、Apollo 配置中心、阿里云 ACM 应用配置管理、ETCD 配置中心、基于令牌桶算法的限流器、通用连接池、熔断器、Swagger 文档生成、Swoole Tracker、视图引擎、Snowflake 全局 ID 生成器 等组件,省去了自己实现对应协程版本的麻烦。
Hyperf 还提供了 基于 PSR-11 的依赖注入容器、注解、AOP 面向切面编程、基于 PSR-15 的中间件、自定义进程、基于 PSR-14 的事件管理器、Redis/RabbitMQ 消息队列、自动模型缓存、基于 PSR-16 的缓存、Crontab 秒级定时任务、国际化、Validation 表单验证器 等非常便捷的功能,满足丰富的技术场景和业务场景,开箱即用。
1.单例模式(Singleton)
模式定义
简单说来,单例模式的作用就是保证在整个应用程序的生命周期中,任何一个时刻,单例类的实例都只存在一个,同时这个类还必须提供一个访问该类的全局访问点。 常见使用实例:数据库连接器;日志记录器(如果有多种用途使用多例模式);锁定文件。
UML类图
单例模式类图
代码示例:https://xueyuanjun.com/post/2599.html
hyperf中的单例模式
在传统的 PHP-FPM 的框架里,会习惯提供一个 AbstractController 或其它命名的 Controller 抽象父类,然后定义的 Controller 需要继承它用于获取一些请求数据或进行一些返回操作,在 Hyperf 里是 不能这样做 的,因为在 Hyperf 内绝大部分的对象包括 Controller 都是以 单例(Singleton) 形式存在的,这也是为了更好的复用对象,而对于与请求相关的数据在协程下也是需要储存到 协程上下文(Context) 内的,所以在编写代码时请务必注意 不要 将单个请求相关的数据储存在类属性内,包括非静态属性。
2.简单工厂模式(Simple Factory)
模式定义
简单工厂的作用是实例化对象,而不需要客户了解这个对象属于哪个具体的子类。简单工厂实例化的类具有相同的接口或者基类,在子类比较固定并不需要扩展时,可以使用简单工厂。
UML类图
代码示例:https://xueyuanjun.com/post/2643
hyperf中的简单工厂模式
hyperf中server的创建由类ServerFactory完成,通过配置参数创建http_server或websocket_server等。代码如下:Hyperf\Server\ServerFactory
namespace Hyperf\Server;
use Hyperf\Server\Entry\EventDispatcher;
use Hyperf\Server\Entry\Logger;
use Psr\Container\ContainerInterface;
use Psr\EventDispatcher\EventDispatcherInterface;
use Psr\Log\LoggerInterface;
class ServerFactory
{
/**
* @var ContainerInterface
*/
protected $container;
/**
* @var null|LoggerInterface
*/
protected $logger;
/**
* @var null|EventDispatcherInterface
*/
protected $eventDispatcher;
/**
* @var ServerInterface
*/
protected $server;
/**
* @var null|ServerConfig
*/
protected $config;
public function __construct(ContainerInterface $container)
{
$this->container = $container;
}
public function configure(array $config)
{
$this->config = new ServerConfig($config);
$this->getServer()->init($this->config);
}
public function start()
{
return $this->getServer()->start();
}
public function getServer(): ServerInterface
{
if (! $this->server instanceof ServerInterface) {
$serverName = $this->config->getType();
$this->server = new $serverName(
$this->container,
$this->getLogger(),
$this->getEventDispatcher()
);
}
return $this->server;
}
public function setServer(Server $server): self
{
$this->server = $server;
return $this;
}
public function getEventDispatcher(): EventDispatcherInterface
{
if ($this->eventDispatcher instanceof EventDispatcherInterface) {
return $this->eventDispatcher;
}
return $this->getDefaultEventDispatcher();
}
public function setEventDispatcher(EventDispatcherInterface $eventDispatcher): self
{
$this->eventDispatcher = $eventDispatcher;
return $this;
}
public function getLogger(): LoggerInterface
{
if ($this->logger instanceof LoggerInterface) {
return $this->logger;
}
return $this->getDefaultLogger();
}
public function setLogger(LoggerInterface $logger): self
{
$this->logger = $logger;
return $this;
}
private function getDefaultEventDispatcher(): EventDispatcher
{
return new EventDispatcher();
}
private function getDefaultLogger(): Logger
{
return new Logger();
}
}