AWS Queue Bundle for Symfony2
The purpose of this bundle is to provide an easy integration between symfony services and AWS services. Queues are defined by Producers and Consumers
By using this bundle, together with aws bundle, the Consumer and Producer services that you define will automatically setup the AWS services on demand. This eases the requirement of setting up your queue and notification services through the AWS platform.
composer require beyerz/aws-queue-bundle
Add BeyerzAWSQueueBundle to the registerBundles()
method of your application kernel:
public function registerBundles()
{
return array(
new Beyerz\AWSQueueBundle\BeyerzAWSQueueBundle(),
);
}
config.yml
beyerz_aws_queue:
region: #Your AWS region that you want to use
account: #Your AWS Account ID
channel_prefix: "%kernel.environment%" #used to separate dev/stage/prod (mainly to make development eaiser)
run_local: false #This option should allow you to run remotely using aws, or locally using no-queue or gearman
Due to the way that Aws has defined the working tree, the aws-queue-bundle cannot automatically append your configs.
The result of this is that you will need to define the aws configuration yourself.
Creating a producer that can be used in your system is really simple, here is some sample code to get you started You can also look at the demo folder in this bundle AcmeBundle/Producers/MyAwesomeProducer.php
<?php
namespace Acme\AcmeBundle\Producers;
use Beyerz\AWSQueueBundle\Interfaces\ProducerInterface;
use Beyerz\AWSQueueBundle\Producer\ProducerTrait;
class MyAwesomeProducer implements ProducerInterface
{
use ProducerTrait;
public function publish($message)
{
$this->producer->publish($message);
}
}
Producers require some setup which is handled by this bundle and you dont really have to worry too much about it. We have provided both and interface and trait for producers and as long you have included them, the setup should go smoothly.
Next, we need to define the producer as a service so that we can tag it and make the AwsQueueBundle aware that it exists :)
AcmeBundle/Resources/config/services.yml
parameters:
acme.my_awesome_producer.class: Acme\AcmeBundle\Producers\MyAwesomeProducer
services:
acme.my_awesome_producer:
class: "%acme.my_awesome_producer.class%"
tags:
- {name: "beyerz_aws_queue.producer", channel: "awesome_producer"}
You can now access your producer as you normally would through symfony container
<?php
$myAwesomeProducer = $this->container->get('acme.my_awesome_producer');
$myMessage = "My Awesome Message";
$myAwesomeProducer->publish($message);
After running this producer, you can go to SNS service in your amazon account and see a new topic has been created for you. You will not yet have queues in your SQS as we have not yet created any consumers
Consumer are a little more complex than producers, but the basic concept to understand is that your consumer class receives the message from the queue for you to process.
AcmeBundle/Consumers/MyAwesomeConsumer.php
<?php
namespace Acme\AcmeBundle\Consumers;
use Beyerz\AWSQueueBundle\Interfaces\ConsumerInterface;
class MyAwesomeConsumer implements ConsumerInterface
{
public function consume($message)
{
//do something awesome with your message
}
}
Consumers require some setup which is handled by this bundle and you dont really have to worry too much about it. We have provided both an interface and as long you have implemented it, the setup should go smoothly. Your consumer class gets "wrapped" in a special consumer service. This wrapper connects to the queue and passes the message to your consume function. This wrapper loads your consumer using service container, this means that you can create your service as you normally would, so you can even add dependecies to a constructor!
Next, we need to define the consumer as a service so that we can tag it and make the AwsQueueBundle aware that it exists :) There are two tags that we are going to use. The first tag tells the bundle that this is a consumer and the defines the name of the SQS queue using the channel key The second tag tells the bundle which producer this consumer wants to subscribe to. If you want to subscribe this queue to more than one producer, just duplicate the tag and define the producer name accordingly
AcmeBundle/Resources/config/services.yml
parameters:
acme.my_awesome_consumer.class: Acme\AcmeBundle\Consumers\MyAwesomeConsumer
services:
acme.my_awesome_consumer:
class: "%acme.my_awesome_consumer.class%"
tags:
- {name: "beyerz_aws_queue.consumer", channel: "awesome_consumer"}
- {name: "beyerz_aws_queue.subscriber", producer: "awesome_producer"}
Now you can run your producer using cli
php app/console beyerz:consumer awesome_consumer
Your consumer will keep running unless you specify a max message limit or something crashes. Its probably best to start your consumers using a task management system such as supervisor or even jenkins. If you have processes that you prefer to run at specific times and not continuosly you can also use crontab