https://github.com/gjerokrsteski/reactphp-pimf
reactive RESTful API which uses ReactPHP and PIMF PHP micro framework
https://github.com/gjerokrsteski/reactphp-pimf
devops docker microservice oop php php7 pimf-micro-framework reactphp
Last synced: 5 months ago
JSON representation
reactive RESTful API which uses ReactPHP and PIMF PHP micro framework
- Host: GitHub
- URL: https://github.com/gjerokrsteski/reactphp-pimf
- Owner: gjerokrsteski
- Created: 2016-02-24T22:28:56.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2021-03-10T08:46:17.000Z (over 4 years ago)
- Last Synced: 2025-04-04T01:41:19.459Z (7 months ago)
- Topics: devops, docker, microservice, oop, php, php7, pimf-micro-framework, reactphp
- Language: PHP
- Homepage: http://gjerokrsteski.github.io/reactphp-pimf/
- Size: 582 KB
- Stars: 26
- Watchers: 5
- Forks: 7
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Security: SECURITY.md
Awesome Lists containing this project
README
# Welcome to PHP Nuclear Reactor
This is an reactive RESTful API which uses ReactPHP and PIMF micro framework.[](https://travis-ci.org/gjerokrsteski/reactphp-pimf)
[](https://codeclimate.com/github/gjerokrsteski/reactphp-pimf)ReactPHP is one of the most promising libraries. It brings the powerful concept of event-driven, non-blocking I/O
(Hi NodeJS) to PHP. With this technology in mind we are able to write our own HTTP stack in PHP and have control back
over the memory without destroying it at the end of each request.*ReactPHP* is responsible for establishing the TCP-Socket, transferring the raw HTTP Requests and sending
the HTTP Responses back.*PIMF micro framework* is responsible for managing the HTTP Resources using the HTTP request methods,
validation and handling the persistence interactions.## Benchmark Results, over 19500 requests completed per second
[vagrant@gkrsteski php-reactor]$ loadtest http://10.0.49.227:5501/articles/10 -t 20 -c 20 --rps 1000
[Wed Feb 10 2016 12:24:47 GMT+0100 (CET)] INFO Requests: 0, requests per second: 0, mean latency: 0 ms
[Wed Feb 10 2016 12:24:52 GMT+0100 (CET)] INFO Requests: 4516, requests per second: 903, mean latency: 10 ms
[Wed Feb 10 2016 12:24:57 GMT+0100 (CET)] INFO Requests: 9515, requests per second: 1000, mean latency: 0 ms
[Wed Feb 10 2016 12:25:02 GMT+0100 (CET)] INFO Requests: 14515, requests per second: 1000, mean latency: 10 ms
[Wed Feb 10 2016 12:25:07 GMT+0100 (CET)] INFO
[Wed Feb 10 2016 12:25:07 GMT+0100 (CET)] INFO Target URL: http://10.0.49.227:5501/articles/10
[Wed Feb 10 2016 12:25:07 GMT+0100 (CET)] INFO Max time (s): 20
[Wed Feb 10 2016 12:25:07 GMT+0100 (CET)] INFO Concurrency level: 20
[Wed Feb 10 2016 12:25:07 GMT+0100 (CET)] INFO Agent: none
[Wed Feb 10 2016 12:25:07 GMT+0100 (CET)] INFO Requests per second: 1000
[Wed Feb 10 2016 12:25:07 GMT+0100 (CET)] INFO
[Wed Feb 10 2016 12:25:07 GMT+0100 (CET)] INFO Completed requests: 19512
[Wed Feb 10 2016 12:25:07 GMT+0100 (CET)] INFO Total errors: 0
[Wed Feb 10 2016 12:25:07 GMT+0100 (CET)] INFO Total time: 20.000516531000002 s
[Wed Feb 10 2016 12:25:07 GMT+0100 (CET)] INFO Requests per second: 976
[Wed Feb 10 2016 12:25:07 GMT+0100 (CET)] INFO Total time: 20.000516531000002 s
[Wed Feb 10 2016 12:25:07 GMT+0100 (CET)] INFO
[Wed Feb 10 2016 12:25:07 GMT+0100 (CET)] INFO Percentage of the requests served within a certain time
[Wed Feb 10 2016 12:25:07 GMT+0100 (CET)] INFO 50% 2 ms
[Wed Feb 10 2016 12:25:07 GMT+0100 (CET)] INFO 90% 9 ms
[Wed Feb 10 2016 12:25:07 GMT+0100 (CET)] INFO 95% 18 ms
[Wed Feb 10 2016 12:25:07 GMT+0100 (CET)] INFO 99% 30 ms
[Wed Feb 10 2016 12:25:07 GMT+0100 (CET)] INFO 100% 36 ms (longest request)## Installation
1. clone this repository
1. run: `./init-app.sh`## Run using PHP
php run-server.php
## Or run with Docker
Build a Docker image for your application by running:
docker build -t="reactphp-pimf-api" .
Finally, run your application as a Docker container by running:docker run -d -p 1337:1337 reactphp-pimf-api
## Try out the RESTful API
- http://{reactive.hosts}:{reactive.port}/articles/
- use HTTP method OPTIONS to find how to use the API## Expected API behavior for resource: /articles
```
HTTP Verb | Entire Collection (e.g. /articles) | Specific Item (e.g. /articles/{id})
-----------------------------------------------------------------------------------------------------------------------------------------------------------------
GET | 400 (Bad Request) | 200 (OK), single article.
| | 404 (Not Found), if ID not found or 400 (Bad Request) if invalid.
-----------------------------------------------------------------------------------------------------------------------------------------------------------------
PUT | 405 (Method Not Allowed) | 200 (OK),
| - unless you want to update/replace every resource in the entire collection. | 404 (Not Found) if ID not found or 400 (Bad Request) if invalid.
| - 'Location' header with link to API documentation |
-----------------------------------------------------------------------------------------------------------------------------------------------------------------
POST | 201 (Created), | 405 (Method Not Allowed)
| - 'Location' header with link to /articles/{id} containing new ID. | - 'Location' header with link to API documentation
-----------------------------------------------------------------------------------------------------------------------------------------------------------------
DELETE | 404 (Not Found) or 405 (Method NOt Allowed) | 200 (OK)
| - unless you want to delete the whole collection—not often desirable. | 404 (Not Found) if ID not found or 400 (Bad Request) if ID invalid.
| - 'Location' header with link to API documentation |```
## Run tests
Install a Composer to your project's rootphp composer.phar require "codeception/codeception:*"
// or ...
composer require "codeception/codeception:*"
Execute tests
php vendor/codeception/codeception/codecept run --colors
// or if want to see steps ...
php vendor/codeception/codeception/codecept run --steps
// or if want to see fancy HTML report page
php vendor/codeception/codeception/codecept run --html