swoolefy 基于 Swoole 轻量级高性能应用服务框架

发布于 2020-11-06 19:39:15 字数 5935 浏览 1356 评论 0

swoolefy 是一个基于 swoole 实现的轻量级高性能的常驻内存型的协程级应用服务框架, 高度支持 httpApi,websocket,udp 服务器,以及基于 tcp 实现可扩展的rpc服务, 同时支持 composer 包方式安装部署项目。

基于实用,swoolefy 抽象 Event 事件处理类, 实现与底层的回调的解耦,支持协程调度,同步|异步调用,全局事件注册,心跳检查,异步任务,多进程(池),连接池等, 内置 view、log、session、mysql、redis、mongodb 等常用组件等。

目前 swoolefy4.2+ 版本完全支持 swoole4.4.+ 的协程,最高支持最新版的 swoole 4.4.+,推荐使用 swoole 4.4.8+.

实现的功能特性

  • 架手脚一键创建项目
  • 路由与调度,MVC三层,多级配置
  • 支持composer的PSR-4规范,实现PSR-3的日志接口
  • 支持自定义注册命名空间,快速部署项目,简单易用
  • 支持httpServer
  • 支持websocketServer,udpServer
  • 支持基于tcp实现的rpc服务,开放式的系统接口,可自定义协议数据格式,并提供rpc-client协程组件
  • 支持容器,组件IOC
  • 支持全局日志
  • 支持协程单例注册
  • 支持mysql协程组件,redis协程组件,mongodb组件,提供基于tp改造的swoolefy-orm协程mysql组件
  • 支持mysql的协程连接池,redis协程池
  • 支持protobuf buffer的数据接口结构验证,压缩传输等
  • 异步务管理TaskManager,定时器管理TickManager,内存表管理TableManager
  • 自定义进程管理ProcessManager,进程池管理PoolsManger
  • 支持底层异常错误的所有日志捕捉
  • 支持自定义进程的redis,rabitmq,kafka的订阅发布,消息队列等
  • 支持crontab
  • 支持热更新
  • 支持定时的系统信息采集,并以订阅发布,udp等方式收集至存贮端
  • 命令行形式高度封装启动|停止控制的脚本,简单命令即可管理整个框架
  • 分布式服务注册(zk,etcd)

常用组件

组件名称安装说明
prediscomposer require predis/predis:1.1.1swoolefy基于predis组件实现容器封装,使用redis操作需要安装此组件
mongodbcomposer require mongodb/mongodb:1.3mongodb组件,需要使用mongodb必须安装此组件
rpc-clientcomposer require bingcool/rpc-client:dev-masterswoolefy的rpc客户端,当与rpc服务端通信时,需要安装此组件,支持在php-fpm中使用
cron-expressioncomposer require dragonmantank/cron-expressioncrontal组件,需要使用定时任务时必须安装此组件

定义组件

开放式组件接口,闭包回调实现创建组件过程,return 对象即可

// 在应用层配置文件中
components => [
  // 例如创建phpredis扩展连接实例
  'redis' => function($com_name) { // 定义组件名,闭包回调实现创建组件过程,return对象即可
    $redis = new \Swoolefy\Library\Cache\Redis();
    $redis->connect('127.0.0.1', 6379);
    $redis->auth('123456789');
    return $redis;   
  },

  // predis组件的redis实例
  'predis' => function($name) {
    $parameters = [
     'scheme' => 'tcp',
     'host'   => '127.0.0.1',
     'port'   => 6379,
     'password' => '123456789'
    ];
    $predis = new \Swoolefy\Library\Cache\Predis();
    $predis->setConfig($parameters);
    return $predis;
  },

   // 适配swoole的mysql客户端组件(参考tp和yii)
  'db' => function() {
    $config = [
     // 地址
     'hostname'    => '127.0.0.1',
     // 数据库
     'database'    => 'bingcool',
     // 用户名
     'username'    => 'bingcool',
     // 密码
     'password'    => '123456789',
     // 端口
     'hostport'    => '3306',
     // dsn
     'dsn'      => '',
     // 数据库连接参数
     'params'     => [],
     // 数据库编码,默认采用utf8
     'charset'    => 'utf8',
     // 数据库表前缀
     'prefix'     => '',
     // 是否断线重连
     'break_reconnect' => true,
     // 是否支持事务嵌套
     'support_savepoint' => false
    ];

    $db = new \Swoolefy\Library\Db\Mysql($config);
    return $db;
  },
    
  // 适配swoole的postgresql客户端组件(参考tp和yii)
  'pg' => function() {
    $config = [
     // 地址
     'hostname'    => '127.0.0.1',
     // 数据库
     'database'    => 'dbtest',
     // 用户
     'username'    => 'bingcool',
     // 密码
     'password'    => '123456789',
     // 端口
     'hostport'    => '5432',
     // dsn
     'dsn'      => '',
     // 数据库连接参数
     'params'     => [],
     // 数据库编码,默认采用utf8
     'charset'    => 'utf8',
     // 数据库表前缀
     'prefix'     => '',
     // 是否断线重连
     'break_reconnect' => true,
     // 是否支持事务嵌套
     'support_savepoint' => false
    ];

    $pg = new \Swoolefy\Library\Db\Pgsql($config);
    return $pg;
  },

  // 其他的组件都可以通过闭包回调创建
  // 数组配置型log组件
  'log' => [
    'class' => \Swoolefy\Util\Log::class,
    'channel' => 'application',
    'logFilePath' => rtrim(LOG_PATH,'/').'/runtime.log'
  ],
  // 或者log组件利用闭包回调创建
  'log' => function($name) {
    $channel= 'application';
    $logFilePath = rtrim(LOG_PATH,'/').'/runtime.log';
    $log = new \Swoolefy\Util\Log($channel, $logFilePath);
    return $log;
  },
]

使用组件

use Swoolefy\Core\Application;
class TestController extends BController {
  public function test() {
    // 组件就是配置回调中定义的组件,这个过程会发生协程调度
    $redis = Application::getApp()->redis;
    //或者
    // $redis = Application::getApp()->get('redis');
    $redis->set('name', swoolefy);

    // predis组件,这个过程会发生协程调度
    $predis = Application::getApp()->predis;
    //或者
    // $predis = Application::getApp()->get('predis');
    $predis->set('predis','this is a predis instance');
    $predis->get('predis');
    
    // PDO的mysql实例,这个过程会发生协程调度
    $db = Application::getApp()->db;
    // 或者
    // $mysql = Application::getApp()->get('db');
    // 添加一条数据
    $sql = "INSERT INTO `user` (`username` ,`sex`) VALUES (:username, :sex)"; 
    $numRows = $db->createCommand($sql)->insert([
     ':username'=>'bingcool-test',
     ':sex' => 1
    ]);
    var_dump($numRows)    

    //查询
    $result = $db->createCommand('select * from user where id>:id')->queryOne([':id'=>100]);
    var_dump($result);  

    // pg实例  
    $pg = Application::getApp()->get('pg');   
    // 添加一条数据   
    $sql = "INSERT INTO `user` (username ,sex) VALUES (:username, :sex)"; 
    $pg->createCommand($sql)->insert([
     ':username'=>'bingcool-test',
     ':sex' => 1
    ]);
  }
}

github 地址:https://github.com/2733284198/swoolefy

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

JSmiles

生命进入颠沛而奔忙的本质状态,并将以不断告别和相遇的陈旧方式继续下去。

0 文章
0 评论
84961 人气
更多

推荐作者

已经忘了多久

文章 0 评论 0

15867725375

文章 0 评论 0

LonelySnow

文章 0 评论 0

走过海棠暮

文章 0 评论 0

轻许诺言

文章 0 评论 0

信馬由缰

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文