-
Notifications
You must be signed in to change notification settings - Fork 166
Report more TLS-related values via HTTP API #163
Comments
@pickettphil I can't reproduce so far. I see the options as expected on current stable when starting a single node with management enabled. Can I see the relevant part of the configuration file? Is this with only management started or is there other nodes? Is the correct configuration file picked up at startup? |
@essen are trying with the tip of stable or 3.6.1?
|
@michaelklishin Stable after doing "make up". |
Please try with 3.6.1 to compare ;)
|
No problem with the 3.6.1 tag (should I try the release directly?) |
There is no harm in trying |
I have the following rabbitmq.config: [ and am running RabbitMQ 3.6.1 on Erlang 18.2 on CentOS 7. I see the http://localhost:15672/api/overview{"management_version":"3.6.1","rates_mode":"basic","exchange_types":[{"name":"direct","description":"AMQP http://localhost:15672/api/nodes[{"cluster_links":[],"disk_free":14689619968,"disk_free_details":{"rate":0.0},"fd_used":49,"fd_used_details":{"rate":0.0},"io_read_avg_time":0,"io_read_avg_time_details":{"rate":0.0},"io_read_bytes":1,"io_read_bytes_details":{"rate":0.0},"io_read_count":1,"io_read_count_details":{"rate":0.0},"io_sync_avg_time":0,"io_sync_avg_time_details":{"rate":0.0},"io_write_avg_time":0,"io_write_avg_time_details":{"rate":0.0},"mem_used":50617064,"mem_used_details":{"rate":196.8},"mnesia_ram_tx_count":13,"mnesia_ram_tx_count_details":{"rate":0.0},"proc_used":202,"proc_used_details":{"rate":0.0},"sockets_used":0,"sockets_used_details":{"rate":0.0},"partitions":[],"os_pid":"12087","fd_total":1024,"sockets_total":829,"mem_limit":410145587,"mem_alarm":false,"disk_free_limit":50000000,"disk_free_alarm":false,"proc_total":1048576,"rates_mode":"basic","uptime":277807,"run_queue":0,"processors":1,"exchange_types":[{"name":"direct","description":"AMQP Phil On Wed, Mar 30, 2016 at 3:21 AM, Loïc Hoguin notifications@github.com
|
Oh, I see why I am seeing something different. The management plugin was configured to use SSL and it is those "ssl_opts" that are shown. This makes sense since SSL options for rabbit use the "ssl_options" key while SSL options for the management plugin use the "ssl_opts" key which is what is shown in the results above. I'd be more interested in seeing the server ssl options than the management plugin's ssl options, but reporting both may be best. |
That's it. The management plugin's ssl options are reported just fine. The server's ssl options are not reported at all. With config: [ At URL {"management_version":"3.6.1","rates_mode":"basic","exchange_types":[{"name":"topic","description":"AMQP topic exchange, as per the AMQP specification","enabled":true},{"name":"direct","description":"AMQP direct exchange, as per the AMQP specification","enabled":true},{"name":"fanout","description":"AMQP fanout exchange, as per the AMQP specification","enabled":true},{"name":"headers","description":"AMQP headers exchange, as per the AMQP specification","enabled":true}],"rabbitmq_version":"3.6.1","cluster_name":"rabbit@rmqremote","erlang_version":"18.2","erlang_full_version":"Erlang/OTP 18 [erts-7.2] [source] [64-bit] [async-threads:64] [hipe] [kernel-poll:true]","message_stats":{},"queue_totals":{"messages":0,"messages_details":{"rate":0.0},"messages_ready":0,"messages_ready_details":{"rate":0.0},"messages_unacknowledged":0,"messages_unacknowledged_details":{"rate":0.0}},"object_totals":{"consumers":0,"queues":0,"exchanges":8,"connections":0,"channels":0},"statistics_db_event_queue":0,"node":"rabbit@rmqremote","statistics_db_node":"rabbit@rmqremote","listeners":[{"node":"rabbit@rmqremote","protocol":"amqp","ip_address":"::","port":5672},{"node":"rabbit@rmqremote","protocol":"amqp/ssl","ip_address":"::","port":5671},{"node":"rabbit@rmqremote","protocol":"clustering","ip_address":"::","port":25672}],"contexts":[{"node":"rabbit@rmqremote","description":"RabbitMQ Management","path":"/","port":"15672","ssl":"true","ssl_opts":{"cacertfile":"/opt/pivotal/ssl/testca/cacert.pem","certfile":"/opt/pivotal/ssl/server/cert.pem","keyfile":"/opt/pivotal/ssl/server/key.pem","verify":"verify_none","fail_if_no_peer_cert":"false"}}]} |
Understood, will take a look. Thanks! |
Looks like we don't currently save listener SSL options. So first we need to record those when starting listeners and then add them to management. One question though: do we want just the SSL options or do we also care about some TCP options (like backlog for example)? |
Maybe some history would help. The customer had added a base64 encoded RabbitMQ config via the RMQ Tile. They had assumed that the tuple "{verify, verify_peer}" was set because this was in their encoded config. As it turned out, this supplied config does not override the defaults of the tile. They had attempted to use the management API to view all ssl_options, but this and several other options were not displayed. I suggested that they use rabbitmqctl eval 'application:get_env(rabbit, ssl_options).' as a workaround. That being said, I think just the SSL options are ok, but I guess the more information that we could show, the better. I think there is a fair amount of leeway for you to decide what is best. |
Thanks, will experiment to see what makes sense, perhaps having both TCP and SSL options while filtering defaults out would be good enough. |
BTW - It was a default of the tile that was not being overridden which may or may not be a RabbitMQ default (to make things even more confusing). |
I have opened two PRs with a proposal for changes. This requires adding a field to a Mnesia table though; I'm not sure what's the procedure/policy regarding upgrades yet. Output looks like this: "listeners": [
{
"node": "rabbit@localhost",
"protocol": "amqp",
"ip_address": "::",
"port": 5672,
"socket_opts": {
"backlog": 128,
"nodelay": true,
"linger": [
true,
0
],
"exit_on_close": false
}
},
{
"node": "rabbit@localhost",
"protocol": "amqp/ssl",
"ip_address": "::",
"port": 5671,
"socket_opts": {
"backlog": 128,
"nodelay": true,
"linger": [
true,
0
],
"exit_on_close": false,
"versions": [
"tlsv1.2",
"tlsv1.1",
"tlsv1"
],
"cacertfile": "/home/essen/rabbitmq/umbrella-master/deps/rabbitmq_test/certs/testca/cacert.pem",
"certfile": "/home/essen/rabbitmq/umbrella-master/deps/rabbitmq_test/certs/server/cert.pem",
"keyfile": "/home/essen/rabbitmq/umbrella-master/deps/rabbitmq_test/certs/server/key.pem"
}
},
{
"node": "rabbit@localhost",
"protocol": "clustering",
"ip_address": "::",
"port": 25672,
"socket_opts": []
}
], |
There are schema upgrade functions but we cannot ship changes that alter schema in |
Thought so. No problem then, will switch to master. :-) Thanks. |
I have pushed the same for master. I will however do a few more tests to make sure I didn't miss anything. |
The PRs add socket options to the
Also of note is that the PRs add more than just SSL information; they add all the socket options that were configured. One could therefore see the |
@essen lets add listener information to Another question: we should check if STOMP, MQTT, and their WebSockets counterparts need updating for this. |
Currently the broker doesn't start for me even after doing full clean and wiping RabbitMQ database directory:
Could be something on my end, too. |
I managed to get past the above but now on the first HTTP API request after startup I'm getting
and port |
Didn't touch that so that's weird. I'll do a clean fetch and see if I can reproduce. |
I think you still have web dispatch on stable, because there's no such thing as a loop fun anymore on master, see https://github.com/rabbitmq/rabbitmq-web-dispatch/blob/master/src/rabbit_web_dispatch_sup.erl#L78 (and no mention of "loop" at all even). |
@essen you are right, I will give it another shot in a bit. |
Using /api/overview or /api/nodes, it would be useful to see all ssl_options reported. In previous versions, we saw something like the following reported:
{"node":"rabbit@localhost","description":"RabbitMQ Management","path":"/","port":"15672","ssl":"true","ssl_opts":{"cacertfile":"/etc/rabbitmq/ca.pem","certfile":"/etc/rabbitmq/cert.pem","keyfile":"/etc/rabbitmq/key.pem"}}
Our configuration also specified verify, fail_if_no_peer_cert, versions ,.... As a result, we don't know what Rabbit does if any of these were overridden from command line.
I tested with both 3.5.7 and 3.6.1 and don't see any ssl_options reported at all.
The text was updated successfully, but these errors were encountered: