USAGE: unitc [options] URI
- URI specifies the target in Unit's control API, e.g.
/config
. - Configuration data is read from stdin.
- jq is used to prettify JSON output, if available.
Options | |
---|---|
filename … | Read configuration data consequently from the specified files instead of stdin. |
HTTP method | It is usually not required to specify a HTTP method. GET is used to read the configuration. PUT is used when making configuration changes unless a specific method is provided. |
INSERT |
A virtual HTTP method that prepends data when the URI specifies an existing array. The jq tool is required for this option. |
-q | --quiet |
No output to stdout. |
-y | --yaml |
Treat configuration data as YAML (converts to/from JSON as necessary). The yq tool is required for this option. |
Options are case insensitive and can appear in any order. For example, a
redundant part of the configuration can be identified by its URI, and
followed by delete
in a subsequent command.
Options may be combined. For example, edit --yaml
will open the
configuration URI in a text editor, in YAML format.
For local instances of Unit, the control socket is automatically detected. The error log is monitored; when changes occur, new log entries are shown.
Options | |
---|---|
-l | --nolog |
Do not monitor the error log after configuration changes. |
unitc /config
unitc /control/applications/my_app/restart
unitc /config < unitconf.json
echo '{"*:8080": {"pass": "routes"}}' | unitc /config/listeners
unitc /config/applications/my_app DELETE
unitc /certificates/bundle cert.pem key.pem
For remote instances of NGINX Unit, the control socket on the remote host can
be set with the $UNIT_CTRL
environment variable. The remote control socket
can be accessed over TCP or SSH, depending on the type of control socket:
ssh://[user@]remote_host[:ssh_port]/path/to/control.socket
http://remote_host:unit_control_port
Note: SSH is recommended for remote confguration. Consider the security implications of managing remote configuration over plaintext HTTP.
Options | |
---|---|
ssh://… |
Specify the remote Unix control socket on the command line. |
http://… URI |
For remote TCP control sockets, the URI may include the protocol, hostname, and port. |
unitc http://192.168.0.1:8080/status
UNIT_CTRL=http://192.168.0.1:8080 unitc /status
export UNIT_CTRL=ssh://root@unithost/var/run/control.unit.sock
unitc /config/routes
cat catchall_route.json | unitc POST /config/routes
echo '{"match":{"uri":"/wp-admin/*"},"action":{"return":403}}' | unitc INSERT /config/routes