2017 © Pedro Peláez
 

lib deep-queue

Messaging library

image

oktopost/deep-queue

Messaging library

  • Monday, July 30, 2018
  • by alexey-pkv
  • Repository
  • 4 Watchers
  • 0 Stars
  • 174 Installations
  • PHP
  • 1 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 19 Versions
  • 4 % Grown

The README.md

Build Status, (*1)

DeepQueue

DeepQueue is a messaging library, (*2)

Installation

composer require oktopost/deep-queue

or inside composer.json, (*3)

"require": {
    "oktopost/deep-queue": "^1.0"
}

Usage example

Basic configuration

$deepQueue = new DeepQueue();

$deepQueue->config()
        ->setConnectorPlugin(Connectors::Redis(['prefix' => 'demo.queue']))
        ->setManagerPlugin(Managers::MySQL(['user' => 'root', 'db' => 'demo_queue']))
        ->setSerializer(DefaultSerializer::get())
        ->addLogProvider(new FileLogProvider(__DIR__));

//or using prepared configuration
$deepQueue = PreparedQueue::RedisMySQL(['prefix' => 'demo.queue'], 
    ['user' => 'root', 'db' => 'demo_queue']);

$deepQueue->config()
        ->addLogProvider(new FileLogProvider(__DIR__));

Working with queue object configuration

//creating and setting up new queue object
$queueObject = new QueueObject();
$queueObject->Name = 'demo.queue';
$queueObject->Config = new QueueConfig();
$queueObject->Config->DelayPolicy = Policy::ALLOWED;

$deepQueue->config()
    ->manager()
    ->create($queueObject);

//loading existing queue object
$queueObject = $deepQueue->getQueueObject('demo.queue');

Working with queue connector

//get connector
$queue = $deepQueue->get('demo.queue');

//enqueue data
$payload = new Payload('payload data');

$queue->enqueue($payload);

//or
$payload = new Payload('payload data');
$payload2 = new Payload('payload data2');

$queue->enqueueAll([$payload, $payload2]);


//dequeue data
$payloads = $queue->dequeue(255);

The Versions