/pera

RESTful API to monitor the Erlang runtime

Primary LanguageErlang

Analytics

#PERA Pure Erlang RESTful API to monitor the Erlang runtime.

About

PERA is a RESTful API that exposes as resources info about a running Erlang VM. This resources provide a simple way to access information about the Erlang runtime.

This API can be exploited to build more powerful tools like webapps or command line tools that give a simple and more focused view of the current state of the runtime.

Examples

Below is a request to GET the /processes/:pid resource:

process resource

Resources

The resources group info about the Erlang runtime in way that is easy an useful to consume. Most of the info is fetched using functions in the erlang module.

Available resources

The exposed resources are:

  • / : root of the API. Contains links to the other exposed resources.
  • system : info about the emulator.
  • /processes : collection of all running processes.
  • /processes/:pid : a single running process.
  • /modules : collection of all the loaded modules.
  • /memory : memory usage in the runtime.

More resources will be added as the API is developed.

Media type

PERA uses HAL+json as the media type for representing its resources and their relations with hyperlinks. This has the following benefits:

  • The resources share a simple but standarized format.
  • Documentation can be discovered through the API.
  • Relations can be discovered through the API.
  • It is not reinventing the wheel. This means that there are already tools out there to consume APIs that use HAL as media type.
  • Its human and machine readable.

Relations documentation

Location of the documentation for the relations accessible from a resource is given in the own resource. As the HAL spec says:

Link rels should be URLs which reveal documentation about the given link

    "_links": {
        "curies": {
            "href": "/relations/{rel}",
            "name": "pera",
            "templated": true
        },
        "pera:modules": {
            "href": "/modules"
        },

For example, the previous resource points out that you could find info about pera:modules at /relations/modules.

HAL browser

hal browser

The HAL browser is included in the aplication to help with the usage of the API and to highlight the benefits of auto-discoverable resources. To use it, point your browser to http://localhost:8000/hal-browser/ and navigate through the available resources and documentation.

Usage

Start the PERA application and the API will be available at 0.0.0.0:8000.

TODO

  • Add more resources. For example:
    • /modules/:module: info about a module.
    • /system/allocators : info about the current allocators.
    • /system/cpu : info about de CPU topology.
  • Allow parameterized requests so the response contain only the neccesary info.
  • Include a configuration file to easily setup PERA i.e. port, address, etc.

Tests

Unit test where done with the Eunit. To run them:

rake test

or, in case you don't have rake installed:

rebar eunit skip_deps=true

Contribute

Ideas are allways welcomed and if you find or think that something isn't working properly, just open an issue.

Pull requests and patches are welcome.

Author

This stuff has been writen by Farruco sanjurjo

If you like the project, please star it 😄

License

Copyright [2014] [Farruco Sanjurjo Arcay]

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.