Download the PHP package fuermao/eureka_php without Composer

On this page you can find all versions of the php package fuermao/eureka_php. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package eureka_php

PHP Eureka

说明

该版本根据piwvh/php-eureka稍作配置上的优化而来。

使用说明

安装

使用composer依赖管理工具进行安装即可;

使用

该组件基本未改变原始用法,仅作了添加日志的操作。可参见原作者piwvh/php-eureka

Create Eureka Client

The very first thing you should do is to create an instance of EurekaClient using your configuration:

List of all available configuration includes:

You can also change configuration after creating EurekaClient instance, using setter methods:

Operations

After creating EurekaClient instance, there will be multiple operations you can do:

You can register your instance and sent periodic heartbeat using start() method:

With this method, first your service gets registered with Eureka using the configuration you have provided, then a heartbeat will be sent to the Eureka periodically based on heartbeatInterval config. This interval time can be changed just like any other configuration item:

Discovery Strategy

When fetching instances of a service from Eureka, you probably get a list of available instances registered with Eureka. You can choose one of them based on your desired strategy of load balancing. For example, a Round-robin or a Random strategy might be your choice.

Currently this library only supports RandomStrategy, but you can create your custom strategy by implementing getInstance() method of DiscoveryStrategy interface:

Then all you have to do is to introduce your custom strategy to EurekaClient instance:

Local Registry and Caching

As you know, failure is inevitable, specially in cloud-native or distributed applications. So, sometimes Eureka may not be available duo to the failure. In this case, we should have a local registry of services to avoid cascading failures.

In the default behaviour, if Eureka is down, the fetchInstance() method fails and so the application throws and exception and can not continue to work. To solve this problem, you should create a local registry in your application.

There is an interface called InstanceProvider which you can make use of. You should implement getInstance() method of this interface and return instances of a service based on your ideal logic.

In this example, we have cached the instances of the service in the database and are retrieving them from the database when Eureka is not available.

After creating your custom provider, just make it work by adding it to the configuration:

Your custom provider only gets called when Eureka is down or is not answering properly.

That's it. By adding this functionality, your application continues to work even when Eureka is down.

For caching all available instances of a specific service, you can call fetchInstances() method which return all instances of a service, fetched from Eureka:


All versions of eureka_php with dependencies

PHP Build Version
Package Version
Requires guzzlehttp/guzzle Version ^6.3
php Version >=7.1
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package fuermao/eureka_php contains the following files

Loading the files please wait ....