附件 Gearman.doc
1:介绍gearman
1.1 简介
Gearman是一个用来把工作委派给其他机器、分布式的调用更适合做某项工作的机器、并发的做某项工作在多个调用间做负载均衡、或用来在调用其它语言的函数的系统
开源:Gearman免费并且开源而且有一个非常活跃的开源社区,如果你想来做一些贡献,请点击 。
多语言支持:Gearman支持的语言种类非常丰富。让我们能够用一种语言来编写Worker程序,但是用另外一种语言编写Client程序。
灵活:不必拘泥于固定的形式。您可以采用你希望的任何形式,例如 Map/Reduce。
快速:Gearman的协议非常简单,并且有一个用C语言实现的,经过优化的服务器,保证应用的负载在非常低的水平。
可植入:因为Gearman非常小巧、灵活。因此您可以将他置入到现有的任何系统中。
没有单点:Gearman不仅可以帮助扩展系统,同样可以避免系统的失败
但有弊端就是占用系统资源较多,例如CPU、内存
1.2 使用场景
将任务分发到多台服务器周期性的并发执
邮件短信发送
异步
跨语言相互调用(对于密集型计算的需求,可以用C实现,PHP直接调用)
典型架构:
1.3 工作原理
一个Gearman请求的处理过程涉及三个角色:Client -> Job -> Worker。
Client:请求的发起者,可以是 C,PHP,Perl,MySQL UDF 等等。
Job:请求的调度者,用来负责协调把 Client 发出的请求转发给合适的 Worker。
Worker:请求的处理者,可以是 C,PHP,Perl 等等。
因为 Client,Worker 并不限制用一样的语言,所以有利于多语言多系统之间的集成。
甚至我们通过增加更多的 Worker,可以很方便的实现应用程序的分布式负载均衡架构。
2:linux下安装Gearman
2.1准备安装软件
Gearman: https://launchpad.net/gearmand/1.2/1.1.2
Php扩展:http://pecl.php.net/get/gearman
2.2编译gearman
基本面
基本的编辑步奏,如果编译有问题,按照
如果提示错误 按照提示相应的解决
编译完成之后:
gearmand -d
启动一个守护进程,gearmand –help 查看相关参数的用途
简单说明:
-d 守护进程模式
-L 监听 IP
-p 端口(7003为旧版本的默认端口,现在已经改为4730)
2.3编译gearman php扩展
操作:
编译后生成 .so 文件 加入到ph.ini中 reload service
extension="gearman.so"
phpinfo() 查看是否开启该模块
3:php 作为worker client 的基本使用
3.1Worker.php
3.2Client.php
Cli 下运行:
php worker.php
&
php
client
.php
4. Gearman中的TCP消息机制
Gearman中Client和Job、Worker和Job之间的通讯是通过TCP套接字数据包实现
G
earman中的消息是基于TCP的变长二进制消息:
请求和响应分别由Message Flag区分。这是一个4字节的结构。
Message Type目前共有36个,详细的定义可见
http://gearman.org/index.php?id=protocol
。它是一个4字节的big-endian的整形。
Data length定义了消息体的长度。它也是一个4字节的big-endian的整形。
消息体可由0-N个argument构成,argument间以’