-
Notifications
You must be signed in to change notification settings - Fork 11
Sharded Clusters
- /sharded_clusters POST
- /sharded_clusters/{cluster-id} POST PUT GET DELETE
- /sharded_clusters/{cluster-id}/shards POST GET
- /sharded_clusters/{cluster-id}/shards/{shard-id} GET DELETE
- /sharded_clusters/{cluster-id}/configsvrs GET
- /sharded_clusters/{cluster-id}/routers GET POST
- /sharded_clusters/{cluster-id}/routers/{router-id} DELETE
##/sharded_clusters
Methods:
- POST - Create a new ShardedCluster with a randomly-assigned id.
Shard Cluster Configuration contains:
- id - cluster name (optional)
- auth_key - authentication key (optional)
- login - username for the admin collection (optional)
- password - password (optional)
- routers - list of routers configurations (required, default: [{}])
- configsvrs - list of config servers configurations (required, default: [{}])
- members - cluster's shards (required)
- preset - configuration file on server with which to merge (optional)
- version - release to use, as defined in configuration file (optional)
The format of the configurations in the routers
and configsvrs
fields are the same as the configuration for a Server. The members
field is a list of documents that may have a shardParams
field, which similarly gives a configuration for a Server or a ReplicaSet. shardParams
may also contain a tags
list for providing shard tags.
Example:
{
"preset": "basic.json", // [optional] - configuration file on server, e.g., configurations/sh/basic.json
"version": "26-release", // [optional] - release to use, as defined in configuration file
"id":"shard_cluster_1", // [optional]
"auth_key": "secret", // [optional] - authentication key
"login": "admin", // [optional] - username for the admin collection
"password":"adminpass", // [optional] - password
"sslParams": { "sslCAFile" : "~/ca.pem" }, // [optional] - SSL options http://docs.mongodb.org/manual/administration/ssl/
"routers": [{"port":2323}, {}], // list of routers
"configsvrs": [{"port": 2315}, {}, {}], // list of config servers
"members": [ // list of members
{"id": "sh01", "shardParams":{"tags": ["tag1", "tag2"]}}, // server
{"id": "sh02", "shardParams": {"procParams": {"port":2320}, "tags": ["otherTag"]}}, // server
{"id": "sh-rs-01", "shardParams": {"id": "rs1", "tags": ["replTag"], "members": [{}, {}]}}, // replicaset
{} // server with default options
]}
If preset
is specified, parameters are first loaded from the server-side configuration file,
e.g., configurations/sh/basic.json
,
and then updated with any other supplied parameters.
The update is a deep merge so that individual leaf values can be overridden by supplied parameters.
Minimal example:
{
"preset": "basic.json", // [optional] - configuration file on server, e.g., configurations/sh/basic.json
}
In this minimal example, all parameters are supplied from the server-side configuration file.
If id
is not specified in the configuration file, a uuid is generated for the id
.
The version
field allows you to specify what release defined in the --config
file to use when starting the Server. The config file must be provided to server.py
on startup, and only releases defined within the file are valid to use. If this field is omitted, then Mongo Orchestration will choose the first release in the config file. If no config file was given, then Mongo Orchestration will start whatever binary is on the user's PATH. See also: /releases.
available response representations:
- 200 - Success.
The response body is nearly identical to that of a GET
to /sharded_clusters/{cluster-id}
.
- 500 - Error.
##/sharded_clusters/{cluster-id}
Where cluster-id
is the id of the ShardedCluster.
Methods:
- POST - Issue a command to the ShardedCluster.
The request body is of the form {"action": "<COMMAND NAME>"}
.
Currently available commands are as follows:
- reset - Ensure all shards, configsvrs, and routers are available, starting any that are not.
When the command was successful, the response body will contain a command_result
field that holds any output of the command.
-
PUT - Create a new Sharded Cluster with the given
cluster-id
.
This functions in much the same way as a POST
request to /sharded_clusters
except that the id
is given as part of the URI rather than the request body. The response from the server is identical to that of a GET
to /sharded_clusters/{cluster-id}
.
- GET - Return information about the ShardedCluster.
available response representations:
- 200 - application/json
Example:
{
"configsvrs": [
{
"hostname": "localhost:1031",
"id": "b9948e15-5c75-454c-a374-6fa5d8e5bc15",
"links": [
{
"href": "/v1/servers/b9948e15-5c75-454c-a374-6fa5d8e5bc15",
"method": "GET",
"rel": "get-server-info"
}
]
}
],
"id": "b7c7dfed-588e-4db7-b64d-763e79b63e45",
"links": [
{
"href": "/v1/sharded_clusters",
"method": "GET",
"rel": "get-sharded-clusters"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45",
"method": "GET",
"rel": "get-sharded-cluster-info"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45",
"method": "POST",
"rel": "sharded-cluster-command"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45",
"method": "DELETE",
"rel": "delete-sharded-cluster"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards",
"method": "POST",
"rel": "add-shard"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards",
"method": "GET",
"rel": "get-shards"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/configsvrs",
"method": "GET",
"rel": "get-configsvrs"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/routers",
"method": "GET",
"rel": "get-routers"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/routers",
"method": "POST",
"rel": "add-router"
},
{
"href": "/v1",
"method": "GET",
"rel": "service"
},
{
"href": "/v1/releases",
"method": "GET",
"rel": "get-releases"
},
{
"href": "/v1/sharded_clusters",
"method": "GET",
"rel": "get-sharded-clusters"
},
{
"href": "/v1/sharded_clusters",
"method": "POST",
"rel": "self"
},
{
"href": "/v1/replica_sets",
"method": "GET",
"rel": "get-replica-sets"
},
{
"href": "/v1/servers",
"method": "GET",
"rel": "get-servers"
}
],
"mongodb_uri": "mongodb://localhost:1032,localhost:1033",
"orchestration": "sharded_clusters",
"routers": [
{
"hostname": "localhost:1032",
"id": "3b2facfa-3537-48d4-b3f9-1f9171696958",
"links": [
{
"href": "/v1/servers/3b2facfa-3537-48d4-b3f9-1f9171696958",
"method": "GET",
"rel": "get-server-info"
}
]
},
{
"hostname": "localhost:1033",
"id": "4370db57-4c10-4bb2-a672-71782eff275d",
"links": [
{
"href": "/v1/servers/4370db57-4c10-4bb2-a672-71782eff275d",
"method": "GET",
"rel": "get-server-info"
}
]
}
],
"shards": [
{
"_id": "78d3152c-b0d3-4487-8fc9-12e76181b64f",
"id": "sh01",
"isServer": true,
"links": [
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards/sh01",
"method": "GET",
"rel": "get-shard-info"
},
{
"href": "/v1/servers/78d3152c-b0d3-4487-8fc9-12e76181b64f",
"method": "GET",
"rel": "get-server-info"
}
],
"tags": []
},
{
"_id": "a3a83cc7-e121-4597-bfa7-b2951fe957bb",
"id": "sh02",
"isServer": true,
"links": [
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards/sh02",
"method": "GET",
"rel": "get-shard-info"
},
{
"href": "/v1/servers/a3a83cc7-e121-4597-bfa7-b2951fe957bb",
"method": "GET",
"rel": "get-server-info"
}
],
"tags": []
}
]
}
-
404 - Returned if the ShardedCluster doesn't exist.
-
DELETE - remove Shard Cluster
All logs and data from all shards, routers, and configsvrs will be deleted as well.
available response representations:
- 204 - Returned if delete was successful.
- 404 - Returned if the ShardedCluster doesn't exist.
- 500 - Error.
Note that the response body is empty if the delete was successful.
##/sharded_clusters/{cluster-id}/shards Parameters:
- cluster-id - string contains the shard cluster id
Methods:
- POST - add shard to shard cluster
The shard will be a ReplicaSet if there are member documents provided in the members
field within the shardParams
document. Otherwise, the new shard will be a Server. Either way, a new Server or ReplicaSet will be created to become the new shard.
Example request bodies:
{} // Create a new Server as a shard.
or
{"shardParams": {"members": [{}, {}]}} // Create a ReplicaSet shard.
- 200 - The shard was created successfully.
The response body is nearly identical of that to a GET
to /sharded_clusters/{cluster-id}/shards/{shard-id}
.
-
500 - Error.
-
GET - Get information about all shards in this ShardedCluster.
available response representations:
- 200 - application/json
Example:
{
"links": [
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45",
"method": "GET",
"rel": "get-sharded-cluster-info"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards",
"method": "GET",
"rel": "self"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/configsvrs",
"method": "GET",
"rel": "get-configsvrs"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/routers",
"method": "GET",
"rel": "get-routers"
}
],
"shards": [
{
"_id": "bc40e094-5598-43b7-9142-08761f3fd3f5",
"id": "375d94cd-20f4-40a0-9362-9d167ec5e553",
"isReplicaSet": true,
"links": [
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards/375d94cd-20f4-40a0-9362-9d167ec5e553",
"method": "GET",
"rel": "get-shard-info"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards/375d94cd-20f4-40a0-9362-9d167ec5e553",
"method": "DELETE",
"rel": "delete-shard"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45",
"method": "GET",
"rel": "get-sharded-cluster-info"
},
{
"href": "/v1/replica_sets/bc40e094-5598-43b7-9142-08761f3fd3f5",
"method": "GET",
"rel": "get-replica-set-info"
}
],
"tags": []
},
{
"_id": "2a76ceba-8eec-46d3-a0fb-5187de1898a6",
"id": "86d5b873-77d0-4152-b7fb-8279a1e587c4",
"isServer": true,
"links": [
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards/86d5b873-77d0-4152-b7fb-8279a1e587c4",
"method": "GET",
"rel": "get-shard-info"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards/86d5b873-77d0-4152-b7fb-8279a1e587c4",
"method": "DELETE",
"rel": "delete-shard"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45",
"method": "GET",
"rel": "get-sharded-cluster-info"
},
{
"href": "/v1/servers/2a76ceba-8eec-46d3-a0fb-5187de1898a6",
"method": "GET",
"rel": "get-server-info"
}
],
"tags": []
},
{
"_id": "78d3152c-b0d3-4487-8fc9-12e76181b64f",
"id": "sh01",
"isServer": true,
"links": [
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards/sh01",
"method": "GET",
"rel": "get-shard-info"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards/sh01",
"method": "DELETE",
"rel": "delete-shard"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45",
"method": "GET",
"rel": "get-sharded-cluster-info"
},
{
"href": "/v1/servers/78d3152c-b0d3-4487-8fc9-12e76181b64f",
"method": "GET",
"rel": "get-server-info"
}
],
"tags": []
},
{
"_id": "a3a83cc7-e121-4597-bfa7-b2951fe957bb",
"id": "sh02",
"isServer": true,
"links": [
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards/sh02",
"method": "GET",
"rel": "get-shard-info"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards/sh02",
"method": "DELETE",
"rel": "delete-shard"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45",
"method": "GET",
"rel": "get-sharded-cluster-info"
},
{
"href": "/v1/servers/a3a83cc7-e121-4597-bfa7-b2951fe957bb",
"method": "GET",
"rel": "get-server-info"
}
],
"tags": []
}
]
}
- 404 - Returned if the ShardedCluster doesn't exist.
##/sharded_clusters/{cluster-id}/shards/{shard-id}
Where shard-id
is the id of the shard.
Methods:
-
GET - info about a shard available response representations:
-
200 - application/json
Example:
{
"_id": "2a76ceba-8eec-46d3-a0fb-5187de1898a6",
"id": "86d5b873-77d0-4152-b7fb-8279a1e587c4",
"isServer": true,
"links": [
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards/86d5b873-77d0-4152-b7fb-8279a1e587c4",
"method": "GET",
"rel": "get-shard-info"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards/86d5b873-77d0-4152-b7fb-8279a1e587c4",
"method": "DELETE",
"rel": "delete-shard"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards",
"method": "POST",
"rel": "self"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45",
"method": "GET",
"rel": "get-sharded-cluster-info"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards",
"method": "GET",
"rel": "get-shards"
},
{
"href": "/v1/servers/2a76ceba-8eec-46d3-a0fb-5187de1898a6",
"method": "GET",
"rel": "get-server-info"
}
],
"tags": []
}
or
{
"_id": "bc40e094-5598-43b7-9142-08761f3fd3f5",
"id": "375d94cd-20f4-40a0-9362-9d167ec5e553",
"isReplicaSet": true,
"links": [
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards/375d94cd-20f4-40a0-9362-9d167ec5e553",
"method": "GET",
"rel": "get-shard-info"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards/375d94cd-20f4-40a0-9362-9d167ec5e553",
"method": "DELETE",
"rel": "delete-shard"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards",
"method": "POST",
"rel": "self"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45",
"method": "GET",
"rel": "get-sharded-cluster-info"
},
{
"href": "/v1/sharded_clusters/b7c7dfed-588e-4db7-b64d-763e79b63e45/shards",
"method": "GET",
"rel": "get-shards"
},
{
"href": "/v1/replica_sets/bc40e094-5598-43b7-9142-08761f3fd3f5",
"method": "GET",
"rel": "get-replica-set-info"
}
],
"tags": []
}
-
404 - Returned if the shard doesn't exist.
-
DELETE - Remove a shard from the ShardedCluster.
available response representations:
-
204 - Success.
Note that the response body is empty if the delete was successful.
-
404 - The shard doesn't exist.
-
500 - Error.
##/sharded_clusters/{cluster-id}/configsvrs Parameters:
- cluster-id - string contains the shard cluster id
Methods:
- GET - Get information about all configsvrs in this ShardedCluster.
available response representations:
- 200 - application/json
Example:
{
"configsvrs": [
{
"hostname": "localhost:1039",
"id": "179156c7-6287-4cdf-a841-141a8b9062b8",
"links": [
{
"href": "/v1/servers/179156c7-6287-4cdf-a841-141a8b9062b8",
"method": "GET",
"rel": "get-server-info"
}
]
}
],
"links": [
{
"href": "/v1/sharded_clusters/cdbcef03-65c3-4f23-944c-25965650b335",
"method": "GET",
"rel": "get-sharded-cluster-info"
},
{
"href": "/v1/sharded_clusters/cdbcef03-65c3-4f23-944c-25965650b335/shards",
"method": "GET",
"rel": "get-shards"
},
{
"href": "/v1/sharded_clusters/cdbcef03-65c3-4f23-944c-25965650b335/configsvrs",
"method": "GET",
"rel": "self"
},
{
"href": "/v1/sharded_clusters/cdbcef03-65c3-4f23-944c-25965650b335/routers",
"method": "GET",
"rel": "get-routers"
}
]
}
##/sharded_clusters/{cluster-id}/routers
Methods:
- GET - Get information about all routers in this ShardedCluster.
available response representations:
- 200 - application/json
Example:
{
"links": [
{
"href": "/v1/sharded_clusters/cdbcef03-65c3-4f23-944c-25965650b335",
"method": "GET",
"rel": "get-sharded-cluster-info"
},
{
"href": "/v1/sharded_clusters/cdbcef03-65c3-4f23-944c-25965650b335/shards",
"method": "GET",
"rel": "get-shards"
},
{
"href": "/v1/sharded_clusters/cdbcef03-65c3-4f23-944c-25965650b335/configsvrs",
"method": "GET",
"rel": "get-configsvrs"
},
{
"href": "/v1/sharded_clusters/cdbcef03-65c3-4f23-944c-25965650b335/routers",
"method": "GET",
"rel": "self"
}
],
"routers": [
{
"hostname": "localhost:1040",
"id": "5916b40c-900d-4add-92dd-b3089e2b67f0",
"links": [
{
"href": "/v1/sharded_clusters/cdbcef03-65c3-4f23-944c-25965650b335/routers/5916b40c-900d-4add-92dd-b3089e2b67f0",
"method": "DELETE",
"rel": "delete-router"
},
{
"href": "/v1/servers/5916b40c-900d-4add-92dd-b3089e2b67f0",
"method": "GET",
"rel": "get-server-info"
}
]
},
{
"hostname": "localhost:1041",
"id": "09144605-d96c-4e26-b71d-a381c045b3c9",
"links": [
{
"href": "/v1/sharded_clusters/cdbcef03-65c3-4f23-944c-25965650b335/routers/09144605-d96c-4e26-b71d-a381c045b3c9",
"method": "DELETE",
"rel": "delete-router"
},
{
"href": "/v1/servers/09144605-d96c-4e26-b71d-a381c045b3c9",
"method": "GET",
"rel": "get-server-info"
}
]
}
]
}
- POST - Add a new router to this ShardedCluster.
Example:
{"port": 2121}
available response representations:
- 200 - Success.
Example:
{
"hostname": "localhost:2121",
"id": "0d64c331-ef05-49a4-ac01-34d32c35efe6",
"links": [
{
"href": "/v1/servers/0d64c331-ef05-49a4-ac01-34d32c35efe6",
"method": "GET",
"rel": "get-server-info"
},
{
"href": "/v1/sharded_clusters/36160d24-eec5-4009-8056-88dfcd4b346a/routers",
"method": "POST",
"rel": "self"
},
{
"href": "/v1/sharded_clusters/36160d24-eec5-4009-8056-88dfcd4b346a/routers/0d64c331-ef05-49a4-ac01-34d32c35efe6",
"method": "DELETE",
"rel": "delete-router"
},
{
"href": "/v1/sharded_clusters/36160d24-eec5-4009-8056-88dfcd4b346a",
"method": "GET",
"rel": "get-sharded-cluster-info"
},
{
"href": "/v1/sharded_clusters/36160d24-eec5-4009-8056-88dfcd4b346a/routers",
"method": "GET",
"rel": "get-routers"
}
]
}
- 500 - Error.
##/sharded_clusters/{cluster-id}/routers/{router-id}
Where router-id
is the id of the router.
Methods:
- DELETE - delete router from shard cluster
available response representations:
-
200 - Success.
Note that the response body is empty if the delete was successful.
-
500 - Error.