以下内容需要结合es的源码,不然可能会觉得跳跃.先描述下es启动的大致流程.es启动的时候注册异常处理函数以及加载配置文件.根据位置文件的设置选择启动哪种swoole服务.然后用一个事件注册类,注册swoole服务需要的回调函数handler. 在启动前根据配置文件是否启动consoleTcpserver子服务.其他服务可以在EasySwooleEvent::mainServerCreate中注册.es3和es2的区别,es3支持协程以及更加组件化.分为了http组件rpc组件等 根路径的执行路…
连接池的含义,很多都知道,比如mysql的数据库连接是有限的,一开始连接mysql创建N个连接,放到一个容器里,每次有请求去容器中取出,取出用完再放回去. es3demo里,有mysql的连接池. EasySwooleEvent::30行,执行initialize方法会注册一个MysqlPool::class MysqlPool是继承于AbstractPool的只实现了createObject方法来创建mysql连接对象 AbstractPool这个抽象类,里我们分析下2个函数getObj和re…
前文讲过可以通过配置开启一个tcp服务,叫做consoleTcpservice.EasySwoole\EasySwoole\Core::83行 (new TcpService(Config::getInstance()->getConf('CONSOLE'))); 这个就是一个console的Tcp子服务.然后可以自定义客户端去和主服务通信. 注意了源码注册了一个TcpParser,EasySwoole\EasySwoole\Console\TcpParser 这个解析器要求了数据的分包规则.…
swoole已经升级到4了,主要的特性是更好的支持协程,easyswoole也为了更好支持协程推出了es3.我本地环境是php7.2.9 centos7 在github下载最新的3.0的demo.地址为:https://github.com/easy-swoole/demo git下载demo注意分支要是3.x  在xshell中选择执行路径输入:git clone -b 3.x https://github.com/easy-swoole/demo.git demo 安装依赖    cd de…
前文,我们访问地址的时候服务端会输出类似trace信息.那么原理是什么呢?其实es3已经把这个独立出来作为单独组件了,名字叫做Trace组件 在demo里的调用原理是 EasySwooleEvent::30行, initialize方法设置了链追踪器的,生成Token和链结束的回调 //调用链追踪器设置Token获取值为协程id TrackerManager::getInstance()->setTokenGenerator(function (){ return \Swoole\Corouti…
demo在手,总得去试试看效果吧.我们先把默认的服务改成webserver,并且添加数据库的配置. 建立数据库,github里面有相关内容 CREATE TABLE `user_list` ( `userId` int(11) NOT NULL AUTO_INCREMENT, `account` varchar(45) NOT NULL, `password` varchar(45) NOT NULL, `session` varchar(45) DEFAULT NULL, `addTime`…
目录 需求分析 使用示例 模块设计 UML 类图 入口 事务 连接池 连接 查询器的组装 总结 需求分析 本篇我们将通过 Swoole 实现一个自带连接池的 MySQL 查询器: 支持通过链式调用构造并执行 SQL 语句: 支持连接池技术: 支持多协程事务并发执行(协程安全性): 支持连接对象的健康检测: 支持连接对象断线重连: 程序需要可扩展,为未来的改造留好扩展点: 完整项目地址:[协程版 MySQL 查询器](https://github.com/linvanda/mysql) (注:该项…
概述 Druid是阿里巴巴开源的一个数据库连接池 源码地址.下面简单分析一下连接池是怎么实现的 怎么开始阅读 如果使用过Druid连接池的都只要在Spring配置中配置jdbc的时候配置Driver是使用的DruidDataSource.因此,在读源码的时候也可以从这个类入口. Datasouce 什么是Datasouce呢,其实就是用于管理数据库连接的工厂类.接口就2个方法 public interface DataSource extends CommonDataSource, Wrappe…
Solr4.8.0源码分析(24)之SolrCloud的Recovery策略(五) 题记:关于SolrCloud的Recovery策略已经写了四篇了,这篇应该是系统介绍Recovery策略的最后一篇了.本文主要介绍Solr的主从同步复制.它与前文<Solr4.8.0源码分析(22)之SolrCloud的Recovery策略(三)>略有不同,前文讲到的是SolrCloud的leader与replica之间的同步,不需要通过配置solrconfig.xml来实现.而本文主要介绍单机模式下,利用so…
Solr4.8.0源码分析(14) 之 SolrCloud索引深入(1) 上一章节<Solr In Action 笔记(4) 之 SolrCloud分布式索引基础>简要学习了SolrCloud的索引过程,本节开始将通过阅读源码来深入学习下SolrCloud的索引过程. 1. SolrCloud的索引过程流程图 这里借用下<solrCloud Update Request Handling 更新索引流程>流程图: 由上图可以看出,SolrCloud的索引过程主要通过一个索引链过程来实…