Skip to content
Phystrix integration with Symfony2 framework. This bundle provides phystrix command factory service: phystrix.command_factory with default configuration.
PHP HTML
Branch: master
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
DataCollector
DependencyInjection
Resources
Tests
.gitignore
.travis.yml
LICENSE
OdeskPhystrixBundle.php
README.md
composer.json
phpunit.xml

README.md

SensioLabsInsight Build Status Scrutinizer Code Quality

Phystrix Bundle

This bundle provides phystrix command factory service: phystrix.command_factory with default configuration

Installation

Install component by using Composer. Update your project's composer.json file to include dependency.

"require": {
    "odesk/phystrix-bundle": "~1.1"
}

Register bundle in your AppKernel

class AppKernel extends Kernel
{
    public function registerBundles()
    {
        $bundles = array(
            // ...
            new Odesk\Bundle\PhystrixBundle\OdeskPhystrixBundle()
            // ...
        );
    }
}

Configuration

Default configuration:

app/config/config.yml

odesk_phystrix:
  default:
    fallback: ~
    circuitBreaker:
      errorThresholdPercentage: 50
      forceOpen: false
      forceClosed: false
      requestVolumeThreshold: 20
      sleepWindowInMilliseconds: 5000
    metrics:
      healthSnapshotIntervalInMilliseconds: 1000
      rollingStatisticalWindowInMilliseconds: 10000
      rollingStatisticalWindowBuckets: 10
    requestCache: ~
    requestLog: ~

Web Profiler

Phystrix bundles comes with a web profiler plugin, it is enabled automatically whenever Symfony profiler is enabled. You only need to make sure requestLog feature is turned on:

odesk_phystrix:
  default:
    requestLog:
      enabled: true

Only do this in mode/environment where profiler is active.

Usage

You may use phystrix.service_locator to provide additional dependencies in runtime:

$container->get('phystrix.service_locator')->set('somekey', $somevalue);

How to create and run a command:

$command = $container->get('phystrix.command_factory')->getCommand('MyCommand', $parameter1, $parameter2);
$command->execute();

License

This file is a part of the Phystrix Bundle

Copyright 2013-2017 Upwork Global Inc. All Rights Reserved.

This file is licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

You can’t perform that action at this time.