欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

php 联接zookeeper实例

程序员文章站 2024-02-06 13:31:28
...
php 连接zookeeper实例

1、安装成功zookeeper后,在zookeeper 的bin目录下有启动相应的启动脚本

php 联接zookeeper实例

启动Server

./zkServer.sh start

启动client:(*注:cli需要安装java)

zkCli.sh

2、PHP实例:

class ZookeeperDemo extends Zookeeper {
public function watcher( $i, $type, $key ) {
echo "Insider Watcher\n" ;
// Watcher gets consumed so we need to set a new one
$this->get( '/test', array ($this, 'watcher' ) );
}
}
$zoo = new ZookeeperDemo( '127.0.0.1:2181' );
$zoo->get( '/test', array ($zoo, 'watcher' ) );
while ( true ) {
echo '.' ;
sleep(2);
}

leader与worker任务的分配:

class Worker extends Zookeeper {
const CONTAINER = '/cluster' ;
protected $acl = array(
array (
'perms' => Zookeeper:: PERM_ALL,
'scheme' => 'world' ,
'id' => 'anyone' ) );
private $isLeader = false;
private $znode ;
public function __construct( $host = '', $watcher_cb = null , $recv_timeout = 10000 ) {
parent:: __construct( $host, $watcher_cb, $recv_timeout );
}
public function register() {
if( ! $this->exists( self ::CONTAINER ) ) {
$this->create( self ::CONTAINER , null, $this-> acl );
}
$this->znode = $this->create( self ::CONTAINER . '/w-' ,
null ,
$this->acl,
Zookeeper::EPHEMERAL | Zookeeper::SEQUENCE );
$this-> znode = str_replace( self ::CONTAINER .'/' , '' , $this-> znode );
printf( "I'm registred as: %s\n", $this-> znode );
$watching = $this->watchPrevious();
if( $watching == $this-> znode ) {
printf( "Nobody here, I'm the leader\n" );
$this->setLeader( true );
}
else {
printf( "I'm watching %s\n" , $watching );
}
}
public function watchPrevious() {
$workers = $this->getChildren( self ::CONTAINER );
sort( $workers );
$size = sizeof( $workers );
for( $i = 0 ; $i
if( $this-> znode == $workers[ $i ] ) {
if ( $i > 0 ) {
$this->get( self ::CONTAINER . '/' . $workers[ $i - 1 ], array ( $this, 'watchNode' ) );
return $workers[ $i - 1 ];
}
return $workers[ $i ];
}
}
throw new Exception( sprintf( "Something went very wrong! I can't find myself: %s/%s",
self ::CONTAINER ,
$this-> znode ) );
}
public function watchNode( $i, $type, $name ) {
$watching = $this->watchPrevious();
if( $watching == $this-> znode ) {
printf( "I'm the new leader!\n" );
$this->setLeader( true );
}
else {
printf( "Now I'm watching %s\n" , $watching );
}
}
public function isLeader() {
return $this-> isLeader ;
}
public function setLeader($flag) {
$this-> isLeader = $flag;
}
public function run() {
$this->register();
while( true ) {
if( $this->isLeader() ) {
$this->doLeaderJob();
}
else {
$this->doWorkerJob();
}
sleep( 2 );
}
}
public function doLeaderJob() {
echo "Leading\n" ;
}
public function doWorkerJob() {
echo "Working\n" ;
}
}
$worker = new Worker( '127.0.0.1:2181' );
$worker->run();可以启动3个php进程,查看脚本的运行。
进程1:
[[email protected] zookeeper]# php -f worker.php
I'm registred as: w-0000000010
Nobody here, I'm the leader
Leading
进程2:
[[email protected] zookeeper]$ php -f worker.php
I'm registred as: w-0000000011
I'm watching w-0000000010
Working
进程3:
[[email protected] zookeeper]$ php -f worker.php
I'm registred as: w-0000000012
I'm watching w-0000000011
Working

ctrl + c 关闭leader进程后,会发现进程2与3会选举出新的leader





php 联接zookeeper实例

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

相关文章

相关视频


网友评论

文明上网理性发言,请遵守 新闻评论服务协议

我要评论
  • php 联接zookeeper实例
  • 专题推荐

    作者信息
    php 联接zookeeper实例

    认证0级讲师

    推荐视频教程
  • php 联接zookeeper实例javascript初级视频教程
  • php 联接zookeeper实例jquery 基础视频教程
  • 视频教程分类