a7115e22f7
This is an interim commit of the changes for secure oslo-messaging.rpc. In this commit we introduce the code for serializers that will encrypt all traffic being sent on oslo_messaging.rpc. Each guest communicates with the control plane with traffic encrypted using a per-instance key. This includes both traffic from the taskmanager to the guest as well as the guest and the conductor. Per-instance keys are stored in the infrastructure database. These keys are further encrypted in the database. Tests that got annoyed have been placated. Upgrade related changes have been proposed. If an instance has no key, no encryption is performed. If the guest gets no key, it won't encrypt, just pass through. When an instance is upgraded, keys are added. The output of the trove show command (and the show API) have been augmented to show which instances are using secure RPC communication ** if the requestor is an administrator **. A simple caching mechanism for encryption keys has been proposed; this will avoid the frequent database access to get the encryption keys. For Ocata, to handle the upgrade case, None as an encryption_key is a valid one, and is therefore not cached. This is why we can't use something like lrucache. A brief writeup has been included in dev docs (dev/secure_oslo_messaging.rst) which shows how the feature can be used and would help the documentation team write up the documentation for this capability. Change-Id: Iad03f190c99039fd34cbfb0e6aade23de8654b28 DocImpact: see dev/secure_oslo_messaging.rst Blueprint: secure-oslo-messaging-messages Related: If0146f08b3c5ad49a277963fcc685f5192d92edb Related: I04cb76793cbb8b7e404841e9bb864fda93d06504
85 lines
2.6 KiB
JSON
85 lines
2.6 KiB
JSON
{
|
|
"instance": {
|
|
"created": "2014-10-30T12:30:00",
|
|
"datastore": {
|
|
"type": "mysql",
|
|
"version": "5.5"
|
|
},
|
|
"deleted": false,
|
|
"deleted_at": null,
|
|
"encrypted_rpc_messaging": true,
|
|
"flavor": {
|
|
"id": "3",
|
|
"links": [
|
|
{
|
|
"href": "https://troveapi.org/v1.0/1234/flavors/3",
|
|
"rel": "self"
|
|
},
|
|
{
|
|
"href": "https://troveapi.org/flavors/3",
|
|
"rel": "bookmark"
|
|
}
|
|
]
|
|
},
|
|
"guest_status": {
|
|
"state_description": "running"
|
|
},
|
|
"hostname": "e09ad9a3f73309469cf1f43d11e79549caf9acf2.troveexampledb.com",
|
|
"id": "44b277eb-39be-4921-be31-3d61b43651d7",
|
|
"links": [
|
|
{
|
|
"href": "https://troveapi.org/v1.0/1234/instances/44b277eb-39be-4921-be31-3d61b43651d7",
|
|
"rel": "self"
|
|
},
|
|
{
|
|
"href": "https://troveapi.org/instances/44b277eb-39be-4921-be31-3d61b43651d7",
|
|
"rel": "bookmark"
|
|
}
|
|
],
|
|
"name": "json_rack_instance",
|
|
"region": "RegionOne",
|
|
"root_enabled": "2014-10-30T12:30:00",
|
|
"root_enabled_by": "3000",
|
|
"server": {
|
|
"addresses": {
|
|
"private": [
|
|
{
|
|
"addr": "123.123.123.123"
|
|
}
|
|
]
|
|
},
|
|
"deleted": false,
|
|
"deleted_at": null,
|
|
"host": "hostname_1",
|
|
"id": "44b277eb-39be-4921-be31-3d61b43651d7",
|
|
"local_id": 0,
|
|
"name": "44b277eb-39be-4921-be31-3d61b43651d7-lay",
|
|
"status": "ACTIVE",
|
|
"tenant_id": "3000"
|
|
},
|
|
"server_id": "44b277eb-39be-4921-be31-3d61b43651d7",
|
|
"service_status": "ACTIVE",
|
|
"status": "ACTIVE",
|
|
"task_description": "No tasks for the instance.",
|
|
"tenant_id": "3000",
|
|
"updated": "2014-10-30T12:30:00",
|
|
"volume": {
|
|
"attachments": [
|
|
{
|
|
"device": "vdb",
|
|
"server_id": "44b277eb-39be-4921-be31-3d61b43651d7"
|
|
}
|
|
],
|
|
"availability_zone": "fake-availability-zone",
|
|
"created_at": "2001-01-01-12:30:30",
|
|
"id": "VOL_44b277eb-39be-4921-be31-3d61b43651d7",
|
|
"size": 4,
|
|
"status": "in-use",
|
|
"total": 4.0,
|
|
"used": 0.16
|
|
},
|
|
"volume_id": "VOL_44b277eb-39be-4921-be31-3d61b43651d7"
|
|
}
|
|
}
|
|
|