Gearmand 任务分发系统

时间:2022-09-19 22:48:37

简介:

Gearmand 是一个用来把工作委派给其它机器、分布式的调用更适合做某项工作的机器、并发的做某项工作在多个调用间做负载均衡、或用来调用其它语言的函数的系统。

简单来讲,就是客户端程序把请求提交给 gearmand,gearmand 会把请求转发给合适的 worker 来处理这个请求,最后还通过 gearmand 返回结果。

运行流程:

Client --> Job --> Worker

1、Client 请求发起者,客户端程序可以是任何一种语言,C 、PHP 、Perl 、Python 等。
2、Job 请求调度者,负载协调把 Client 发出的请求转发给合适的 Worker。
3、Worker 请求处理者,处理 Job 分发来的请求,可以是任何一种语言。

下载地址:https://github.com/gearman/gearmand/releases

参考地址:http://wiki.phpboy.net/doku.php?id=2014-05:40-Gearman%E8%B0%83%E7%A0%94_%E6%B5%8B%E8%AF%95_%E5%8E%9F%E7%90%86%E5%88%86%E6%9E%90.md&do=

一、安装、启动 Gearmand

1、源码编译安装( 能够安装最新版本,需要自己解决依赖 )

shell > yum -y install boost-devel gperf libevent-devel libuuid-devel

shell > cd /usr/local/src
shell > tar zxf gearmand-1.1..tar.gz
shell > cd gearmand-1.1.
shell > ./configure; make; make install shell > gearmand -V
gearmand: error while loading shared libraries: libmysqlclient.so.: cannot open shared object file: No such file or directory 解决方法: shell > ln -s /usr/local/mysql-5.5./lib/libmysqlclient.so. /usr/lib64/ shell > gearmand -V
gearmand 1.1. - https://bugs.launchpad.net/gearmand shell > mkdir -p /usr/local/var/log
shell > touch /usr/local/var/log/gearmand.log shell > gearmand -L 0.0.0.0 -d # 启动 gearmand,-L 指定只监听 IPV4,-d 以守护进程的方式启动,-p port 默认 shell > killall gearmand # 停止 gearmand

2、yum 安装 gearmand( 简单、快捷,版本不是最新 )

shell > yum -y install gearmand

shell > /etc/init.d/gearmand start  # 启动 gearmand

shell > gearmand -V
gearmand 1.1. - https://bugs.launchpad.net/gearmand shell > vim /etc/sysconfig/gearmand # 指定 gearmand 启动参数
### Settings for gearmand
OPTIONS="-p 4370 -L 0.0.0.0" shell > /etc/init.d/gearmand restart # or stop

# 如果 gearmand 要向外提供服务,需要打开监听的 TCP 端口,默认 4370

二、PHP 安装 gearmand 扩展、启动 Worker

1、安装 gearmand 扩展

shell > /usr/local/php/bin/pecl install gearman
shell > echo 'extension=gearman.so' >> /usr/local/php/php.ini
shell > /usr/local/php/bin/php -m | grep gearman
gearman

2、编写 Worker ( Worker 进程可以启动在任意一台服务器上 )

shell > vim script/worker.php
<?php
$worker= new GearmanWorker();
$worker->addServer();
$worker->addFunction("reverse", "my_reverse_function");
while ($worker->work()); function my_reverse_function($job)
{
return strrev($job->workload());
}
?>

# 这是官网的一个测试例
# $worker->addServer(); 默认连接本机 gearmand,端口 4370,地址貌似是 IPV6,因为我指定 -L 0.0.0.0 启动 gearmand 时,Worker 提示连接失败
# $worker->addServer('192.168.1.30',4370); gearmand 不在本机或不是默认端口时,需要指定
# Worker 支持连接多个 gearmand,但并不是负载均衡,只是一个备机。

3、启动 Worker

shell > /usr/local/php/bin/php script/worker.php &  # Worker 进程可以启动多个,多次执行该命令即可

shell > ps aux | grep worker | grep -v grep | awk '{print $2}' | xargs -i kill {}  # 停止 Worker 进程

shell > pgrep php | xargs -i kill {}  # 这样也可以,或者直接 killall php,小心误杀哦

# Worker 进程管理脚本

shell > vim script/gearmand-worker.sh

#!/bin/bash
# author: Wang XiaoQiang // # 设置初始启动多少个 worker 进程,默认 个
worker_num=
# 设置 worker 脚本文件路径
worker_file='/root/script/worker.php' start_worker(){
i=
while [ $i -lt $worker_num ];do
/usr/local/php/bin/php $worker_file &
let i++
done [ $? -eq ] && status_worker || echo "Start falied"
} stop_worker(){
ps aux | grep -v grep | grep 'worker.php' | awk '{print $2}' | xargs -i kill {} [ $? -eq ] && echo "Worker process stoped" || echo "Stop falied"
} status_worker(){
line=`ps aux | grep -v grep | grep 'worker.php' | wc -l`
echo "Worker process number: $line"
} main(){
$
} case $ in
start)
main start_worker ;;
stop)
main stop_worker ;;
restart)
main stop_worker
main start_worker ;;
status)
main status_worker ;;
*)
echo "Usage: sh $0 [start|stop|restart|status]" ;;
esac # End

三、编写、执行 Client ( Client 可以在任意一台服务器上 )

shell > vim script/client.php
<?php
$client= new GearmanClient();
$client->addServer('192.168.1.30',);
print $client->do("reverse", "\nHello World!");
?>

# Client 连接 gearmand,192.168.1.30,端口 4370

shell > /usr/local/php/bin/php script/client.php
!dlroW olleH

# Gearmand 进程成功将 Client 请求转发到了 Worker,执行完成后返回结果

# Client 、Gearmand 、Worker 可以部署在同一台服务器,也可以分开部署。只要保证 Client 跟 Worker 都能连接到 Gearmand 即可。

四、Gearmand 监控

# 开源项目地址:https://github.com/yugene/Gearman-Monitor

# 脚本监控、加入 Zabbix

# 先这样,等空闲的时候补上这块内容

Gearmand 任务分发系统的更多相关文章

  1. 使用 expect 命令执行自动分发系统

    一.命令 except 实例详解 1. 介绍 expect 使用场景 expect可以让我们实现自动登录远程机器,并且可以实现自动远程执行命令.当然若是使用不带密码的密钥验证同样可以实现自动登录和自动 ...

  2. 基于BT协议的文件分发系统

    基于BT协议的文件分发系统构成:    1.一个Web服务器:保存着种子文件    2.一个种子文件:保存共享文件的一些信息(文件名,文件大小    ,Tracker服务器地址,torrent为后缀) ...

  3. 任务分发系统gearman

    1 Gearman是什么 Gearman Job Server@http://gearman.org/. Gearman 是一个任务分发系统,它提供了一个分发框架,能够分发某类任务到更适合处理这类任务 ...

  4. Django之路由分发系统

    web的基本工作流程 首先,我们先来思考一下我们平常在上网浏览网页时候的场景,大致就是打开一个web浏览器,输入某一个网站的地址,然后转到该网址,在浏览器中得到该网址的页面.从这个场景中我们可以抽象出 ...

  5. 关于LT分发系统的设计构想

    git地址 https://github.com/cxyxd/LtDistribution 背景 对tomcat做集群,在多机多tomcat的情况下,如果要更新代码,只能手动的将代码复制,粘贴,然后下 ...

  6. 深度解读阿里巴巴云原生镜像分发系统 Dragonfly

    Dragonfly 是一个由阿里巴巴开源的云原生镜像分发系统,主要解决以 Kubernetes 为核心的分布式应用编排系统的镜像分发难题.随着企业数字化大潮的席卷,行业应用纷纷朝微服务架构演进,并通过 ...

  7. expect脚本同步文件 expect脚本指定host和要同步的文件 构建文件分发系统 批量远程执行命令

    自动同步文件 #!/usr/bin/expect set " spawn rsync -av root@.txt /tmp/ expect { "yes/no" { se ...

  8. centos shell编程4【分发系统】 服务器标准化 mkpasswd 生成密码的工具 expect讲解 expect传递参数 expect自动同步文件 expect指定host和要同步的文件 expect文件分发系统 expect自动发送密钥脚本 Linux脚本执行方式 第三十八节课

    centos shell编程4[分发系统] 服务器标准化  mkpasswd 生成密码的工具  expect讲解   expect传递参数   expect自动同步文件  expect指定host和要 ...

  9. 第四部分shell编程5项目二分发系统

    第一部分:expect讲解expect可以让我们实现自动登录远程机器,并且可以实现自动远程执行命令.当然若是使用不带密码的密钥验证同样可以实现自动登录和自动远程执行命令.但当不能使用密钥验证的时候,我 ...

随机推荐

  1. EF 关系规则&lpar;一对一、一对多、多对多&period;&period;&period;&rpar;

    转自: http://www.cnblogs.com/dudu/archive/2011/07/11/ef_one-to-one_one-to-many_many-to-many.html Entit ...

  2. System&period;ArgumentOutOfRangeException&colon; 指定的参数已超出有效值的范围

    GridView指定的参数已超出有效值的范围GridView在更新过程中异常详细信息: System.ArgumentOutOfRangeException: 指定的参数已超出有效值的范围.参数名:v ...

  3. swift material

    import UIKit extension UIColor { convenience init(hex:Int, alpha:CGFloat=1.0) { let red = CGFloat((h ...

  4. Qt入门(2)——使用Qt编写的Hello world

    对于一个qt初学者来说,一步一步来直到作出一个hello world是最基础的入门. 从菜单:应用程序->编程中找到QtCreator

  5. cronjob不跑得原因

    能是环境的不同,能够在cronjob中加个env > /tmp/env.output查看 应用要同一时候输出标准错误合标准输出到一个文件能够&> /tmp/t

  6. Web前端的路该怎么走?很迷茫

    “路漫漫其修远兮,吾将上下而求索”,这句出自<离骚>. 虽然端午已过,但是还是不影响一个程序员想表(zhuang)达(boy)自己此刻心情的冲动. 偶然路过同事旁边,不(tou)小(kan ...

  7. js 第二课

    =赋值 ==比较 ===绝对比较 &&且 ||  或 !取反 a?1:0 a=ture a?1:0 function LeyBc() { var a={d:11,b:22,c:&quo ...

  8. MyBatis 源码分析 - 配置文件解析过程

    * 本文速览 由于本篇文章篇幅比较大,所以这里拿出一节对本文进行快速概括.本篇文章对 MyBatis 配置文件中常用配置的解析过程进行了较为详细的介绍和分析,包括但不限于settings,typeAl ...

  9. ecmall 基础类分析

    class ECBaseApp,继承自class BaseApp,是includes/ecapp.base.php文件. 该类是一个非常重要的类,他是各个APP的应用的基础继承类.处理相关的基础应用. ...

  10. PHP图像 因其本身有错无法显示

    昨天终于将客户的一个网站迁移至虚拟主机上,满怀希望的敲入网址.唰的一声,网站很轻松的被打开了. 心里那个高兴啊~~~ 咦,怎么产品图片都没有显示出来.一块块都是空白.敲入img src对应的地址,看看 ...