承接 satoruk/concurrency-mongo 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

satoruk/concurrency-mongo

最新稳定版本:0.1.1

Composer 安装命令:

composer require satoruk/concurrency-mongo

包简介

some concurrency solution library with MongoDB

README 文档

README

Build Status

concurrency-mongodb

MongoDBを使った並列処理のライブラリです.

素のPHP自体はマルチスレッド、マルチプロセスに対応していないので 多重起動、サーバのクラスタリングを組んだ場合に利用できるようになっています.

JobQueue

ジョブキューイングのライブラリ群

ResourcePool

排他的なリソース管理

MongoDB上の構造

  • JobQueue_${name}
  • _id : object. ObjectID
  • value : any types. this is a job value.
  • priority : integer. 0 is most high priority. defult is 50
  • resolution :
  • opid : Operation ID
  • lockExpiredAt : lock expired at
  • lockBy : sets the locked uuid

ロック戦略

悲観的排他制御にてロックを行っています.

以下はロックの手順です.

利用するフィールド

  • JobQueue_${name}.lockExpiredAt
  • ロック有効期限 MondoDB内の時間で判定
  • JobQueue_${name}.lockBy
  • ロックをかけたuuid

lockExpiredAt以内に処理が終わらなかった場合、再処理されます.

Project setup

For Developer

開発環境の構築手順

$ git clone git://github.com/satoruk/php-concurrency-mongodb.git concurrency-mongodb
$ cd concurrency-mongodb
$ curl -s https://getcomposer.org/installer | php -- --install-dir=bin
$ ./bin/composer.phar install --dev
$ ./bin/phpcs --config-set default_standard PSR2

Testing

$ ./bin/phpunit

统计信息

  • 总下载量: 29
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 1
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: Unknown
  • 更新时间: 2012-12-28