Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/glasswalk3r/rabbitmq-management-proxy
A Nginx configuration to setup a reverse proxy for RabbitMQ Management plugin
https://github.com/glasswalk3r/rabbitmq-management-proxy
access-control bdd monitoring nginx proxy rabbitmq
Last synced: 6 days ago
JSON representation
A Nginx configuration to setup a reverse proxy for RabbitMQ Management plugin
- Host: GitHub
- URL: https://github.com/glasswalk3r/rabbitmq-management-proxy
- Owner: glasswalk3r
- License: gpl-3.0
- Created: 2018-08-26T18:06:32.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2018-11-23T21:03:58.000Z (about 6 years ago)
- Last Synced: 2024-11-19T20:53:15.753Z (2 months ago)
- Topics: access-control, bdd, monitoring, nginx, proxy, rabbitmq
- Language: Ruby
- Homepage:
- Size: 30.3 KB
- Stars: 4
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# rabbitmq-management-proxy
A Nginx configuration to setup a reverse proxy for RabbitMQ Management plugin[Rabbitmq](https://www.rabbitmq.com/) has a plugin named [rabbitmq-management](https://www.rabbitmq.com/management.html) that is used to manage by using a HTTP interface.
A side effect of this plugin is to enable some monitoring of the RabbitMQ node (or cluster). There are endpoints available to check the availability from several parts from RabbitMQ. One could use this API to pull metrics to a timeseries database and/or evaluate the broker health.
Unfortunately, the plugin access control (authorization) is course grained and might expose too much instead of just monitoring endpoints. In order to fix that, it is possible to configure a reverse proxy to be put in front of the RabbitMQ node (or cluster) to control such access.
There are [configuration instructions](https://www.rabbitmq.com/management.html#proxy) about setting up a reverse proxy, but only for Apache webserver. If you want to use Nginx instead, you will find it a lot of more difficult: the configuration syntax is not intuitive to follow up and it's really easy to make mistakes.
This project features are:
- forwarding requests to following RabbitMQ HTTP Management API endpoints:
- /api/nodes
- /api/aliveness-test
- /api/queues
- denies any other request to other API endpoints might change the broker configuration and/or state.
- offers a /health itself for monitoring purposes.
- limits the HTTP requests to only GET and HEAD methods.
- templates to generate the configuration for Nginx.
- templates to build a customized Nginx image.
- automatic unit tests to validate the RabbitMQ user to provide access to the HTTP management plugin API endpoints (using [RSpec](http://rspec.info/)).
- BDD tests to validate the functional expected behavior (using [Cucumber](https://cucumber.io/)).## Project status
This project should be treated as beta software. Code may fail, tests probably need a revision.
## Quick intro
To use this project you will need to:
1. Configure a user in the RabbitMQ (see User Management section).
2. Copy all the virtual hosts (vhosts) you have available in the RabbitMQ to the vhosts.txt file.
3. Run the Rspec test to see if the setup is correct for the user created at step 1.
4. Export the configuration of your RabbitMQ node to use in the local environment (copy the JSON file to `test/local/rabbit_config.json`).
5. Run `docker-compose up` to create a copy of your environment.
6. Run the Cucumber BDD tests.## Configuration steps
1. `git clone` this repository.
2. Edit the app.yaml file. The properties should intuitive enough.
3. Install the project dependencies using [Bundler](https://bundler.io). Use `bundle install --path vendor/bundle` to get the required programs available in your local directory.
4. Run `gencfg.rb` to populate the templates to generate the configuration files for Nginx and the corresponding Dockerfile to generate the Docker image you're going to use for testing and deploy:```
$ ./gencfg.rb -h
Usage: gencfg [options]
-e, --environment ENVIRONMENT: the environment to make the deploy (see app.yaml)
```From that you should have a `tmp` directory with the following files:
```
tmp
├── default.conf
├── Dockerfile
└── nginx.conf
```In order to generate a container, just `cd` into the `tmp` directory and run `docker build -t rabbitmq-management-proxy .` from there.
## User Management
The reverse proxy requires a user added to the RabbitMQ to provide the proper access to the HTTP management plugin.
Thus, you will need to add one with the following (minimal) items:
- give access to all vhosts available in the broker
- for each vhost, include only the following permissions:
- Configure regexp: aliveness-test
- Write regexp: amq.default
- Read regexp: aliveness-test
- given the `monitoring` tag of the HTTP management pluginOnce created, this user configuration can be validated by using RSpec for validation. The login and password must be managed and added to the Nginx configuration file as described in the previous section.
```
$ bundle exec rspecRabbitMQAccess
#access_nodes?
can access the /api/nodes endpoint
#access_queues?
#access_queues from vhost /sample-vhost
#access_queues from vhost /sample/complex-vhost
#check_vhost_alive?
#check_vhost_alive /sample-vhost
#check_vhost_alive /sample/complex-vhostFinished in 0.03879 seconds (files took 0.12732 seconds to load)
5 examples, 0 failures
```The currently implementation of uses http://localhost:15672 to connect to and run the validations. You will want to edit the `vhosts.txt` to add all the vhosts you want to monitor from RabbitMQ.
## BDD
This project includes BDD tests so you can keep your configuration documented and properly tested.
Beware that these tests uses Docker Compose and expect that the reverse proxy container image was generate with the name `rabbitmq-management-proxy`. You can, of course, update the `docker-compose.yml` file with the right value, or generate a Docker image with the expected name.
In order to run the tests, execute:
```
cd tests\local
docker-compose up
```Then, in another shell:
```
cd tests
bundle install
bundle exec cucumber -f pretty
```You should see something like that:
```ruby
Feature: check the reverse proxy health
To ensure the proper functioning of the proxy
As a monitoring application
I want to check the health endpoint of itScenario: the reverse proxy is healthy # features/proxy_health.feature:8
If a request is made to the /health endpoing of the reverse proxy, a success message is received.
Given the reverse proxy is located at http://localhost:8080 # features/step_definitions/monitor_steps.rb:4
When a HTTP GET request is made to /health # features/step_definitions/monitor_steps.rb:18
Then a HTTP 200 response will be received # features/step_definitions/monitor_steps.rb:22Feature: get all available nodes in RabbitMQ
To be able to check the RabbitMQ cluster health
As an application that relies on it
I want to verify the corresponding endpoint of itScenario: we can query the nodes via the reverse proxy # features/rabbitmq_nodes.feature:8
Accessing the endpoint /api/nodes of the reverse proxy, we receive a successful message with the corresponding data of the nodes
Given the reverse proxy is located at http://localhost:8080 # features/step_definitions/monitor_steps.rb:4
When a HTTP GET request is made to /api/nodes # features/step_definitions/monitor_steps.rb:18
Then a HTTP 200 response will be received # features/step_definitions/monitor_steps.rb:22
And the response type should be JSON # features/step_definitions/monitor_steps.rb:26Feature: check the availability of virtual hosts on RabbitMQ
To be able to check the availability of a specific virtual host on RabbitMQ
As an application that depends on it
I want to access the corresponding endpoint of it to check the related statusBackground: # features/vhost_aliveness.feature:8
Given the reverse proxy is located at http://localhost:8080 # features/step_definitions/monitor_steps.rb:4Scenario: validate the aliveness of a simple vhost from the reverse proxy # features/vhost_aliveness.feature:11
Accessing /api/aliveness-test at the reverse proxy using as parameter a simple vhost name (one with a single slash at the beginning) a successful message is received
When a HTTP request is made to /api/aliveness-test with any simple vhost # features/step_definitions/monitor_steps.rb:8
Then a HTTP 200 response will be received # features/step_definitions/monitor_steps.rb:22
And the response type should be JSON # features/step_definitions/monitor_steps.rb:26Scenario: validate the aliveness of a complex vhost from the reverse proxy # features/vhost_aliveness.feature:18
Accessing /api/aliveness-test at the reverse proxy using as parameter a complex vhost name (one with multiple slashes) a successful message is received
When a HTTP request is made to /api/aliveness-test with any complex vhost # features/step_definitions/monitor_steps.rb:13
Then a HTTP 200 response will be received # features/step_definitions/monitor_steps.rb:22
And the response type should be JSON # features/step_definitions/monitor_steps.rb:26Feature: verify the associated queues within a specific virtual host at RabbitMQ
To be able to check the associated queues status of a specific virtual host at a RabbitMQ
As an application that depends on it
I want to access the corresponding endpoint of those queuesBackground: # features/vhost_queues.feature:8
Given the reverse proxy is located at http://localhost:8080 # features/step_definitions/monitor_steps.rb:4Scenario: check the queues status of a simple virtual host from the reverse proxy # features/vhost_queues.feature:11
Accessing /api/aliveness-test at the reverse proxy using as parameter a simple vhost name (one with a single slash at the beginning) a successful message is received
When a HTTP request is made to /api/queues with any simple vhost # features/step_definitions/monitor_steps.rb:8
Then a HTTP 200 response will be received # features/step_definitions/monitor_steps.rb:22
And the response type should be JSON # features/step_definitions/monitor_steps.rb:26
And the JSON structure represents queues # features/step_definitions/monitor_steps.rb:32Scenario: check the queues status of a complex virtual host from the reverse proxy # features/vhost_queues.feature:19
Accessing /api/aliveness-test at the reverse proxy using as parameter a complex vhost name (one with multiple slashes) a successful message is received
When a HTTP request is made to /api/queues with any complex vhost # features/step_definitions/monitor_steps.rb:13
Then a HTTP 200 response will be received # features/step_definitions/monitor_steps.rb:22
And the response type should be JSON # features/step_definitions/monitor_steps.rb:26
And the JSON structure represents queues # features/step_definitions/monitor_steps.rb:326 scenarios (6 passed)
25 steps (25 passed)
0m0.143s
```There are other options for the `-f` option of the cucumber program. You might want to check the documentation for it to see the available formats.
## Tested environment
This project was tested on the following environment:
- Linux Ubuntu 16.04
- Ruby 2.3.1p112 (2016-04-26) [x86_64-linux-gnu]
- Bundler 1.11.2
- RSpec 3.8.0
- Cucumber 3.2.0