2019-12-06 16:14:56 +00:00
|
|
|
---
|
2020-09-01 15:14:13 +00:00
|
|
|
layout: commands
|
2020-04-07 18:55:19 +00:00
|
|
|
page_title: 'Commands: Namespace Write'
|
2023-01-26 18:42:13 +00:00
|
|
|
description: |
|
|
|
|
The `consul namespace write` command creates or updates a namespace's configuration in Consul Enterprise.
|
2019-12-06 16:14:56 +00:00
|
|
|
---
|
|
|
|
|
|
|
|
# Consul Namespace Write
|
|
|
|
|
|
|
|
Command: `consul namespace write`
|
|
|
|
|
2023-01-25 16:52:43 +00:00
|
|
|
Corresponding HTTP API Endpoint: [\[PUT\] /v1/namespace/:name](/consul/api-docs/namespaces#update-a-namespace)
|
2022-01-10 17:40:11 +00:00
|
|
|
|
2020-04-23 22:13:18 +00:00
|
|
|
<EnterpriseAlert />
|
|
|
|
|
2020-03-16 13:42:39 +00:00
|
|
|
This `namespace write` command creates or updates a namespace's configuration from its full definition. This was added in Consul Enterprise 1.7.0.
|
2019-12-06 16:14:56 +00:00
|
|
|
|
2023-01-25 16:52:43 +00:00
|
|
|
The table below shows this command's [required ACLs](/consul/api-docs/api-structure#authentication). Configuration of
|
|
|
|
[blocking queries](/consul/api-docs/features/blocking) and [agent caching](/consul/api-docs/features/caching)
|
2022-01-11 14:41:54 +00:00
|
|
|
are not supported from commands, but may be from the corresponding HTTP endpoint.
|
|
|
|
|
|
|
|
| ACL Required |
|
|
|
|
| ---------------- |
|
|
|
|
| `operator:write` |
|
|
|
|
|
2019-12-06 16:14:56 +00:00
|
|
|
## Usage
|
|
|
|
|
|
|
|
Usage: `consul namespace write <namespace definition>`
|
|
|
|
|
|
|
|
The `<namespace definition>` must either be a file path or `-` to indicate that
|
|
|
|
the definition should be read from stdin. The definition can be in either JSON
|
2023-01-25 16:52:43 +00:00
|
|
|
or HCL format. See [here](/consul/docs/enterprise/namespaces#namespace-definition) for a description of the namespace definition.
|
2019-12-06 16:14:56 +00:00
|
|
|
|
|
|
|
#### Command Options
|
|
|
|
|
2020-04-07 18:55:19 +00:00
|
|
|
- `-format=<string>` - How to output the results. The choices are: pretty or json
|
2019-12-06 16:14:56 +00:00
|
|
|
|
2020-04-07 18:55:19 +00:00
|
|
|
- `-meta` - Indicates that namespace metadata such as the raft indices should be
|
2019-12-06 16:14:56 +00:00
|
|
|
shown for the namespace
|
2020-04-07 18:55:19 +00:00
|
|
|
|
2022-07-27 06:17:11 +00:00
|
|
|
#### API Options
|
|
|
|
|
|
|
|
@include 'http_api_partition_options.mdx'
|
|
|
|
|
|
|
|
@include 'http_api_options_client.mdx'
|
|
|
|
|
|
|
|
@include 'http_api_options_server.mdx'
|
|
|
|
|
2019-12-06 16:14:56 +00:00
|
|
|
## Examples
|
|
|
|
|
|
|
|
Create a new Namespace:
|
|
|
|
|
2020-05-19 18:32:38 +00:00
|
|
|
```shell-session
|
2019-12-06 16:14:56 +00:00
|
|
|
$ consul namespace write - <<< 'Name = "team-1"'
|
|
|
|
Name: team-1
|
|
|
|
Description:
|
|
|
|
```
|
|
|
|
|
|
|
|
Showing Raft Metadata:
|
|
|
|
|
2020-05-19 18:32:38 +00:00
|
|
|
```shell-session
|
2019-12-06 16:14:56 +00:00
|
|
|
$ consul namespace write -meta - <<< 'Name = "team-1"'
|
|
|
|
Name: team-1
|
|
|
|
Description:
|
|
|
|
Create Index: 339
|
|
|
|
Modify Index: 344
|
|
|
|
```
|
|
|
|
|
|
|
|
JSON Format:
|
|
|
|
|
2020-05-19 18:32:38 +00:00
|
|
|
```shell-session
|
2019-12-06 16:14:56 +00:00
|
|
|
$ cat ns.hcl
|
|
|
|
Name = "foo"
|
|
|
|
Description = "Example Namespace"
|
|
|
|
Meta {
|
|
|
|
team-id = "574407f3-8b26-4c84-8e51-028bb8cbdd37"
|
|
|
|
}
|
|
|
|
$ consul namespace write -format=json ns.hcl
|
|
|
|
{
|
|
|
|
"Name": "foo",
|
|
|
|
"Description": "Example Namespace",
|
|
|
|
"Meta": {
|
|
|
|
"team-id": "574407f3-8b26-4c84-8e51-028bb8cbdd37"
|
|
|
|
},
|
|
|
|
"CreateIndex": 352,
|
|
|
|
"ModifyIndex": 352
|
|
|
|
}
|
|
|
|
```
|