traffic_ctl¶
Synopsis¶
traffic_ctl [OPTIONS] SUBCOMMAND [OPTIONS]
Note
traffic_ctl uses a JSONRPC protocol to communicate with traffic_server.
Description¶
traffic_ctl is used to display, manipulate and configure a running Traffic Server. traffic_ctl includes a number of subcommands that control different aspects of Traffic Server:
- traffic_ctl config
Manipulate and display configuration records
- traffic_ctl metric
Manipulate performance and status metrics
- traffic_ctl server
Stop, restart and examine the server
- traffic_ctl storage
Manipulate cache storage
- traffic_ctl plugin
Interact with plugins.
- traffic_ctl host
Manipulate host status. parents for now but will be expanded to origins.
- traffic_ctl rpc
Interact directly with the JSONRPC 2.0 server in Traffic Server
Options¶
- --debug¶
Enable debugging output.
- -V, --version¶
Print version information and exit.
- -f, --format¶
Specify the output print style.
Options
Description
json
It will show the response message formatted to JSON. This is ideal if you want to redirect the stdout to a different source. It will only stream the json response, no other messages. This option only applies to the RPC request or response.
rpc
Show the JSONRPC request and response + the default output. This option only applies to the RPC request or response.
In case of a record request(config)
--records
overrides this flag.Example:
$ traffic_ctl config get variable --format rpc --> {request} <-- {response} variable 1234
$ traffic_ctl config get variable --format json {response}
There will be no print out beside the json response. This is ideal to redirect to a file.
- --records¶
Option available only for records request.
- --run-root¶
Path to the runroot file.
Subcommands¶
traffic_ctl alarm¶
Warning
Option not available in the JSONRPC 2.0 version.
traffic_ctl config¶
Manipulate configuration records.
- --records¶
Display the config output in YAML format. This out can be used directly into ATS if needed.
- --default¶
Include the default value alonside with the current value. This can be used in combination with
--records
$ traffic_ctl config match proxy.config.diags.debug --records --default records: diags: debug: client_ip: "null" # default: null enabled: 1 # default: 0 tags: quic # default: http|dns throttling_interval_msec: 0 # default: 0
- defaults [--records]¶
-
Display the default values for all configuration records. The
--records
flag has the same behavior astraffic_ctl config get --records
.
- describe RECORD [RECORD...]¶
-
Display all the known information about a configuration record. This includes the current and default values, the data type, the record class and syntax checking expression.
- diff [--records]¶
-
Display configuration records that have non-default values. The
--records
flag has the same behavior astraffic_ctl config get --records
.
- get [--records, --default] RECORD [RECORD...]¶
Display the current value of a configuration record.
- --records¶
If this flag is provided,
traffic_ctl config get
will emit results in internal ats variable format.The option –cold is available to get the values from a file.
- match [--records, --default] REGEX [REGEX...]¶
-
Display the current values of all configuration variables whose names match the given regular expression. The
--records
flag has the same behavior as traffic_ctl config get –records.
- reload¶
-
Initiate a Traffic Server configuration reload. Use this command to update the running configuration after any configuration file modification. If no configuration files have been modified since the previous configuration load, this command is a no-op.
The timestamp of the last reconfiguration event (in seconds since epoch) is published in the proxy.process.proxy.reconfigure_time metric.
- set RECORD VALUE¶
-
Set the named configuration record to the specified value. Refer to the
records.yaml
documentation for a list of the configuration variables you can specify. Note that this is not a synchronous operation.Supports the following options.
- --cold, -c [filename]¶
This option indicates to traffic_ctl that the action should be performed on a configuration file instead of using the ATS RPC facility to store the new value. traffic_ctl will save the value in the passed filename, if no filename passed, then the sysconfig
records.yaml
will be attempted to be used.ATS supports parsing multiple documents from the same YAML stream, so if you attempt to set a variable on a document with none, one or multiple documents then a new document will be appended. In case you want to modify an existing field then -u option should be passed, so the latest(top to bottom) field will be modified, if there is no variable already set in any of the documents, then the new variable will be set in the latest document of the stream.
Specifying the file name is not needed as traffic_ctl will try to use the build(or the runroot if used) information to figure out the path to the records.yaml.
If the file exists and is empty a new document will be created. If a file does not exist, an attempt to create a new file will be done.
This option(only for the config file changes) lets you use the prefix proxy.config. or ts. for variable names, either would work. If different prefix name is prepend, then traffic_ctl will work away using the provided variable name, this may not be what is intended so, make sure you use the right prefixes.
Appending a new field in a records.yaml file.
$ traffic_ctl config set proxy.config.diags.debug.enabled 1 -c records.yaml $ cat records.yaml records: ... # Document modified by traffic_ctl Mon Feb 13 23:07:15 2023 # --- records: diags: debug: enabled: 1Note
The following options are only considered if
--cold, -c
is used, ignored otherwise.
- --update -u¶
Update latest field present. If there is no variable already set in any of the documents, then the new variable will be set in the latest document.
- --type, -t int | float | str¶
Inject a tag information on the modified/new field, this is useful when you set a non registered record inside ATS.
$ traffic_ctl config set ts.some.plugin.config.max 100 -t int -c records.yaml $ cat records.yaml ... # Document modified by traffic_ctl Mon Feb 13 23:07:15 2023 # --- records: some: plugin: config: max: !<tag:yaml.org,2002:int> 100
- status¶
-
Display detailed status about the Traffic Server configuration system. This includes version information, whether the internal configuration store is current and whether any daemon processes should be restarted.
- registry¶
filemanager.get_files_registry
Display information about the registered files in Traffic Server. This includes the full file path, config record name, parent config (if any) if needs root access and if the file is required in Traffic Server.
traffic_ctl metric¶
- get METRIC [METRIC...]¶
-
Display the current value of the specified statistics.
- match REGEX [REGEX...]¶
-
Display the current values of all statistics whose names match the given regular expression.
- describe RECORD [RECORD...]¶
-
Display all the known information about a metric record.
- monitor [-i, -c] METRIC [METRIC...]¶
Display the current value of the specified metric(s) using an interval time and a count value. Use
-i
to set the interval time between requests, and-c
to set the number of requests the program will send in total per metric. The program will terminate execution after requesting <count> metrics. Ifcount=0
is passed orcount
is not specified then the program should be terminated by SIGINT. Note that the metric will display + or - depending on the value of the last metric and the current being shown, if current is greater, then + will be added beside the metric value, - if the last value is less than current, and no symbol is the same.Example:
$ traffic_ctl metric monitor proxy.process.eventloop.time.min.10s -i 2 -c 10 proxy.process.eventloop.time.min.10s: 4025085 proxy.process.eventloop.time.min.10s: 4025085 proxy.process.eventloop.time.min.10s: 4025085 proxy.process.eventloop.time.min.10s: 4025085 proxy.process.eventloop.time.min.10s: 4011194 - proxy.process.eventloop.time.min.10s: 4011194 proxy.process.eventloop.time.min.10s: 4011194 proxy.process.eventloop.time.min.10s: 4011194 proxy.process.eventloop.time.min.10s: 4011194 proxy.process.eventloop.time.min.10s: 4018669 + --- metric monitor statistics(10) --- ┌ proxy.process.eventloop.time.min.10s └─ min/avg/max = 4011194/4017498/4025085
traffic_ctl server¶
- drain¶
-
Drop the number of active client connections.
- status¶
Option not yet available
- debug enable¶
Enables diagnostic messages at runtime. This is equivalent to manually setting the below records but this is done in one go.
Note that if you just set this to enable, the
proxy.config.diags.debug.enabled
will be set to1
unless you specify the--client_ip,-c
option.proxy.config.diags.debug.enabled
proxy.config.diags.debug.client_ip
Enables logging for diagnostic messages. See
proxy.config.diags.debug.enabled
for information.- --tags, -t tags¶
This string should contain an anchored regular expression that filters the messages based on the debug tag tag. Please refer to
proxy.config.diags.debug.tags
for more information- --client_ip, -c ip¶
Please see
proxy.config.diags.debug.client_ip
for information.
- debug disable¶
Disables logging for diagnostic messages. Equivalent to set
proxy.config.diags.debug.enabled
to0
.Example:
$ traffic_ctl server debug enable --tags "quic|quiche" ■ TS Runtime debug set to »ON(1)« - tags »"quic|quiche"«, client_ip »unchanged«
traffic_ctl storage¶
- offline PATH [PATH ...]¶
admin_storage_set_device_offline
Mark a cache storage device as offline. The storage is identified by PATH which must match exactly a path specified in
storage.config
. This removes the storage from the cache and redirects requests that would have used this storage to other storage. This has exactly the same effect as a disk failure for that storage. This does not persist across restarts of the traffic_server process.
- status PATH [PATH ...]¶
admin_storage_get_device_status
Show the storage configuration status.
traffic_ctl plugin¶
- msg TAG DATA¶
-
Send a message to plugins. All plugins that have hooked the
TSLifecycleHookID::TS_LIFECYCLE_MSG_HOOK
will receive a callback for that hook. The TAG and DATA will be available to the plugin hook processing. It is expected that plugins will use TAG to select relevant messages and determine the format of the DATA.
traffic_ctl host¶
A record to track status is created for each host. The name is the host fqdn. The value of the record when retrieved, is a serialized string representation of the status. This contains the overall status and the status for each reason. The records may be viewed using the traffic_ctl host status command.
- --time count¶
Set the duration of an operation to
count
seconds. A value of0
means no duration, the condition persists until explicitly changed. The default is0
if an operation requires a time and none is provided by this option.
- --reason active | local | manual¶
Sets the reason for the operation.
active
Set the active health check reason.
local
Set the local health check reason.
manual
Set the administrative reason. This is the default reason if a reason is needed and not provided by this option.
Internally the reason can be
self_detect
ifproxy.config.http.parent_proxy.self_detect
is set to the value 2 (the default). This is used to prevent parent selection from creating a loop by selecting itself as the upstream by marking this reason as “down” in that case.Note
The up / down status values are independent, and a host is consider available if and only if all of the statuses are “up”.
- status HOSTNAME [HOSTNAME ...]¶
-
Get the current status of the specified hosts with respect to their use as targets for parent selection. If the HOSTNAME arguments are omitted, all host records available are returned.
- down HOSTNAME [HOSTNAME ...]¶
-
Marks the listed hosts as down so that they will not be chosen as a next hop parent. If
--time
is included the host is marked down for the specified number of seconds after which the host will automatically be marked up. A host is not marked up until all reason codes are cleared by marking up the host for the specified reason code.
- up HOSTNAME [HOSTNAME ...]¶
-
Marks the listed hosts as up so that they will be available for use as a next hop parent. Use
--reason
to mark the host reason code. The ‘self_detect’ is an internal reason code used by parent selection to mark down a parent when it is identified as itself andSupports
--reason
.
traffic_ctl rpc¶
A mechanism to interact directly with the Traffic Server JSONRPC 2.0 endpoint. This means that this is not tied to any particular API but rather to the rpc endpoint, so you can directly send requests and receive responses from the server.
- file¶
Reads a file or a set of files from the disc, use the content of the files as message(s) to the JSONRPC 2.0 endpoint. All jsonrpc messages will be validated before sending them. If the file contains invalid json|yaml format the message will not be send, in case of a set of files, if a particular file is not a proper json/yaml format then that particular file will be skipped.
Example:
traffic_ctl rpc file jsonrpc_cmd1.json jsonrpc_cmd2.yaml
- get-api¶
-
Request the entire admin api. This will retrieve all the registered methods and notifications on the server side.
Example:
$ traffic_ctl rpc get-api Methods: - admin_host_set_status - admin_server_stop_drain - admin_server_start_drain - admin_plugin_send_basic_msg - admin_lookup_records - admin_config_set_records - admin_storage_get_device_status - admin_storage_set_device_offline - admin_config_reload - show_registered_handlers Notifications: - some_registered_notification_handler
- input¶
Input mode, traffic_ctl will provide a control input from a stream buffer. Once the content is written the terminal traffic_ctl will wait for the user to press Control-D to send the request to the rpc endpoint. This feature allows you to directly interact with the jsonrpc endpoint and test your API easily and without the need to know the low level implementation details of the transport layer. traffic_ctl will validate the input format, not the message content. The message content will be validated by the server. See example input_example_2.
- --raw, -r¶
No json/yaml parse validation will take place, the input content will be directly send to the server.
Example:
$ traffic_ctl rpc input >> Ctrl-D to fire the request { "id":"86e59b43-185b-4a0b-b1c1-babb1a3d5401", "jsonrpc":"2.0", "method":"admin_lookup_records", "params":[ { "record_name":"proxy.config.diags.debug.tags", "rec_types":[ "1", "16" ] } ] } <pressed Ctrl-D> <-- Server's response. { "jsonrpc":"2.0", "result":{ "recordList":[ { "record":{ "record_name":"proxy.config.diags.debug.tags", "record_type":"3", "version":"0", "raw_stat_block":"0", "order":"423", "config_meta":{ "access_type":"0", "update_status":"0", "update_type":"1", "checktype":"0", "source":"3", "check_expr":"null" }, "record_class":"1", "overridable":"false", "data_type":"STRING", "current_value":"rpc", "default_value":"http|dns" } } ] }, "id":"86e59b43-185b-4a0b-b1c1-babb1a3d5401" }
Example 2:
You can see a valid json
{}
but an invalid JSONRPC 2.0 message. In this case the server is responding.$ traffic_ctl rpc input >> Ctrl-D to fire the request {} <pressed Ctrl-D> < -- Server's response { "jsonrpc":"2.0", "error":{ "code":-32600, "message":"Invalid Request" } }
- invoke¶
Invoke a remote call by using the method name as parameter. This could be a handy option if you are developing a new handler or you just don’t want to expose the method in traffic_ctl, for instance when implementing a custom handler inside a proprietary plugin.
- --params, -p¶
Parameters to be passed in the request, YAML or JSON format are accepted. If JSON is passed as param it should not be mixed with YAML. It’s important that you follow the JSONRPC 2.0 Protocol specs. If the passed param does not follows the specs the server will reject the request.
Example 1:
Call a jsonrpc method with no parameter.
$ traffic_ctl rpc invoke some_jsonrpc_handler --> {"id": "0dbab88d-b78f-4ebf-8aa3-f100031711a5", "jsonrpc": "2.0", "method": "some_jsonrpc_handler"} <-- { response }
Example 2:
Call a jsonrpc method with parameters.
$ traffic_ctl rpc invoke reload_files_from_folder --params 'filenames: ["file1", "file2"]' 'folder: "/path/to/folder"' --> {"id": "9ac68652-5133-4d5f-8260-421baca4c67f", "jsonrpc": "2.0", "method": "reload_files_from_folder", "params": {"filenames": ["file1", "file2"], "folder": "/path/to/folder"}} <-- { response }
Examples¶
Mark down a host with traffic_ctl and view the associated host stats:
.. code-block:: bash
# traffic_ctl host down cdn-cache-02.foo.com --reason manual
# traffic_ctl metric match host_status
proxy.process.host_status.cdn-cache-01.foo.com HOST_STATUS_DOWN,ACTIVE:UP:0:0,LOCAL:UP:0:0,MANUAL:DOWN:1556896844:0,SELF_DETECT:UP:0
proxy.process.host_status.cdn-cache-02.foo.com HOST_STATUS_UP,ACTIVE:UP:0:0,LOCAL:UP:0:0,MANUAL:UP:0:0,SELF_DETECT:UP:0
proxy.process.host_status.cdn-cache-origin-01.foo.com HOST_STATUS_UP,ACTIVE:UP:0:0,LOCAL:UP:0:0,MANUAL:UP:0:0,SELF_DETECT:UP:0
In the example above, ‘cdn-cache-01.foo.com’ is unavailable, HOST_STATUS_DOWN and was marked down for the manual reason, MANUAL:DOWN:1556896844:0, at the time indicated by the UNIX time stamp 1556896844. To make the host available, one would have to clear the manual reason using:
# traffic_ctl host up cdn-cache-01.foo.com --reason manual
Configure Traffic Server to insert Via
header in the response to the client
# traffic_ctl config set proxy.config.http.insert_response_via_str 1 # traffic_ctl config reload
Autest¶
Runroot needs to be configured in order to let traffic_ctl know where to find the socket. This is done by default and there is no change you have to do to interact with it, but make sure that you are not overriding the dump_runroot=False when creating the ATS Process, otherwise the runroot.yaml will not be set.
See also¶
records.yaml(5), storage.config(5), Configuration, JSONRPC 2.0 Protocol