Early Access Node Site CLI Reference
Objective
Specific Customer Edge (CE) serviceability tools, like the debug log bundle and Site CLI Commands, will be available as Early Access within the site's Tools
tab (Multi-Cloud Network Connect
> Overview
> Infrastructure
> Sites
) with the September 24, 2024, release.
Prerequisites
-
Ensure that the CE Site is running the September 24, 2024, release or higher.
-
Ensure that the user is part of the following API groups:
User Role | Requirement |
---|---|
F5xc-site-management-standard-user | Read-only Site CLI commands. |
F5xc-site-management-monitor-user | Debug log bundle |
F5xc-site-management-standard-admin | Read/write Site CLI commands. |
Debug log bundle
The Debug log bundle command includes all the diagnostic information to help F5 Technical Support investigate the root cause of an issue. Before this early access, this debug log bundle was only available to collect on a node-by-node basis. Customers had to identify the node in question and then navigate to the UI or SSH to the node to collect this information. With the Debug log bundle early access, customers can now collect a support bundle collection across all the nodes, or select nodes in a site directly from the Console without the need to identify the node IP addresses and connect to them on a node-by-node basis.
data:image/s3,"s3://crabby-images/e3243/e3243edcd3a694628df3b7cd432b0de87c358bd6" alt="Figure: Debug log bundle"
Figure: Debug log bundle
Site CLI Commands
Site CLI Commands allow you to debug and troubleshoot network issues, view forward state of the CE nodes, view BGP route information exchanged with external BGP endpoints, and run familiar Linux utility tools (like ip
and netstat
) directly from the Site Console to improve CE Site serviceability.
This functionality is available on a per-node basis as mode serviceability commands. You must log in to each node individually to run the commands. With this feature, a select set of commands are now directly available from Distributed Cloud Services Console, simplifying CE serviceability needs.
As part of Early Access, a select few commands are made available for you, with a plan to expose a broader set of commands for General Availability (GA) in the future.
Here is a list of commands that are now available as part of the Early Access that you can run directly from the Distributed Cloud Services Console by selecting a node from a site:
Network Troubleshooting Commands
IPsec Tunnel
- Tunnel status commands: These commands can be executed to collect detailed status of the IPsec tunnels established between a Customer Edge and Regional Edges.
ipsec-status
ipsec-statusall
data:image/s3,"s3://crabby-images/6e89c/6e89ceda136fa9b8a0e9de4c711c6a2b145d37d2" alt="Figure: Command"
Figure: Command
Sample output:
data:image/s3,"s3://crabby-images/2af3e/2af3ec2e53f3348bf7caba093a54f0fadb23fe0b" alt="Figure: Command Output"
Figure: Command Output
Output interpretation:
For a given node, ipsec-status
and ipsec-statusall
list out all IPsec tunnel associations and endpoints.
NTP Sources
-
Network connectivity commands: Standard Linux
ip
andnetstat
utility commands can check L2/L3 network state and connections of CE interfaces. -
chronyc-sources
: Displays the status of all NTP time sources.
data:image/s3,"s3://crabby-images/14f1c/14f1c1fa42909cd6a46752e75c9a46dfce43820e" alt="Figure: Command"
Figure: Command
Sample output:
data:image/s3,"s3://crabby-images/83c52/83c52717751d602efd4a8f6e4080820e51fa8e41" alt="Figure: Command Output"
Figure: Command Output
Output interpretation:
For a given node, chronyc-sources
lists out all NTP sources and time synchronization status.
Network Statistics
netstat
: Information about network connections.
data:image/s3,"s3://crabby-images/af2a9/af2a90a04ff2e8df74748ab20cddfbc5bf9af0a1" alt="Figure: Command"
Figure: Command
Sample output:
data:image/s3,"s3://crabby-images/13f97/13f97258a9009358f62d19d2ad907a663de8831d" alt="Figure: Command Output"
Figure: Command Output
Output interpretation:
The output is similar to the netstat
Linux utility. For a given CE node, the output lists all the active TCP/UDP connections, among other things.
IP Addresses and Links
ip
command options include:<link>
: Information about network interfaces.addr
: Information about network interfaces.route
: Node route information.neighbor
: IP neighbor information.ip-link-show
: Information about all the virtual interfaces of the node forwarding state.
data:image/s3,"s3://crabby-images/800bc/800bcd8a192a9d87d28d9c8b3da814a0af612bb7" alt="Figure: Command"
Figure: Command
Sample output:
data:image/s3,"s3://crabby-images/1f48e/1f48e509c71b261b7f392cba42f63c393c91368e" alt="Figure: Command Output"
Figure: Command Output
Output interpretation:
The output is similar to the Linux ip
utility. The ip link
command output includes all the ip
link layer information for all IP links for a given node.
Curl
CE site reachability to external F5 cloud endpoints: These commands can be used from the node (host) or from a system container, like Vega, to check reachability and domain resolution. This is especially useful as you check reachability to F5 published public domains needed for healthy CE Site operation:
curl-host
: Command options include-v <host-name>
. For example, gcr.io or cloud.f5.com.curl-vega
: Command options include-v <host-name>
. For example, gcr.io or cloud.f5.com.
data:image/s3,"s3://crabby-images/a2c0f/a2c0feb6a94ad182b10ea576cdf4a30f89b43d07" alt="Figure: Command"
Figure: Command
Sample output:
data:image/s3,"s3://crabby-images/81b24/81b249a9edf4ab7544b968f6e4b3f402e9756053" alt="Figure: Command Output"
Figure: Command Output
Output interpretation:
The command outputs the status of the curl
response from the node/host perspective, while the curl-vega
command outputs the same from the CE system software standpoint. These reachability checks help ensure DNS resolution and verify HTTP connectivity to domains of interest.
Network connections from the CE Site nodes can be verified by running the familiar netstat
utility against any of the nodes in a site.
Forward State
Forward state commands: The CE Site node's forwarding state, such as active flows (flow-l
), route (rt
), next hop (nh
) information, and drops statistics (dropstats
) can provide a plethora of information to help troubleshoot connectivity issues in a self-service manner.
See below for details of each of the commands in sequence and how to interpret the output to help aid with the troubleshooting as well as feed the next command inputs based on the previous command output.
flow-l
: Dumps the entire flow table for all flows seen by the node across all interfaces and route tables.
data:image/s3,"s3://crabby-images/aa2e4/aa2e49b4fbb9405f1f2c1d6a22c9c99b7af6dbb1" alt="Figure: Command"
Figure: Command
Sample output:
data:image/s3,"s3://crabby-images/7ba9c/7ba9c47d79c15bf93ffc69bdba63f69cfa688416" alt="Figure: Command Output"
Figure: Command Output
Output interpretation:
Above is a snipped output of the flow-l
command output showing a flow with a source IP port of 10.1.20.10:3503 with destination IP port of 10.1.20.4:18093. Additionally, Proto(V) indicates that this is a TCP flow (protocol 6), and it belongs to VRF 9. Armed with VRF information, you can get additional information about the next hop for a given route using rt
commands.
flow-l-match
: Dumps the exact match flow entry from the CE node's forwarding state.
data:image/s3,"s3://crabby-images/254ff/254ff1e106e471b2d2695733f13384dd990087b9" alt="Figure: Command"
Figure: Command
Sample output:
data:image/s3,"s3://crabby-images/0edae/0edaef8e9026727aae245d4a5ba7d6e53ee80624" alt="Figure: Command Output"
Figure: Command Output
Output interpretation:
For a given IP and port combination, as an input from the user, the matching flow information is provided as a response and the corresponding information, such as VRF, flow index, and more.
Route
rt
: Route commands:<--dump> <VRF>
: Dumps the entire route table for a given VRF for IPv4 (inet) family.<--dump> <VRF> <--family inet6>
: Dumps the entire route table for a given VRF for IPv6 (inet6) family.<--get> <route> <--family inet> <--vrf> <vrf-id>
data:image/s3,"s3://crabby-images/3278d/3278dfff001e82e084d1181c0549caaca30b90e3" alt="Figure: Command"
Figure: Command
Sample output:
data:image/s3,"s3://crabby-images/35ed2/35ed203fc65cda52d58cb973ff6985eaa59c2375" alt="Figure: Command Output"
Figure: Command Output
Output interpretation:
The output above is a snipped output of rt
command output showing a flow with a source IP port of 10.1.20.10:3503 with destination IP port of 10.1.20.4:18093. Additionally, Proto(V) indicates that this is a TCP flow (protocol 6), and it belongs to VRF 9. Armed with VRF information, you can get additional information about the next hop for a given route.
Next Hop
nh
: Next Hop (NH) commands:< --list>
: Lists all the next hops programmed on the nodes.<--get> <nh-id>
data:image/s3,"s3://crabby-images/3ba07/3ba07a39f5f96058d6e045564d021e508aa75971" alt="Figure: Command"
Figure: Command
Sample output:
data:image/s3,"s3://crabby-images/735ae/735ae2c069b369ca00d52893ba84d57d4c29968e" alt="Figure: Command Output"
Figure: Command Output
Output interpretation:
The command output above indicates that it is a "resolve" type next hop, and the outgoing interface ID is indicated where the traffic will egress.
Virtual Interface
vif
commands:<--list>
: List all virtual interfaces (VIF) on the node part of the SDN routing stack.
data:image/s3,"s3://crabby-images/3f0b1/3f0b144fa02499bfbe1372be0a7777d8205691a6" alt="Figure: Command"
Figure: Command
Sample output:
data:image/s3,"s3://crabby-images/d4268/d426806fd5b6fb8be9dc9e2a3aa19e07d1f04339" alt="Figure: Command Output"
Figure: Command Output
Output interpretation:
The command above lists out all the virtual interfaces on the node part of the SDN routing stack. Each of the interfaces has information around L2 address information and statistics. As seen in the sample output above, there is information about the parent interface, TX and RX statistics, and VRF this VIF belongs to.
Dropped Packet Statistics
dropstats-non-zero
: List of all non-zero counter stats key of the forwarding state.
data:image/s3,"s3://crabby-images/ba214/ba21468d05957cd414d80b0ff999649f80b83c07" alt="Figure: Command"
Figure: Command
Sample output:
data:image/s3,"s3://crabby-images/18250/18250dec64602534a35fe108dbd0776f8a42845d" alt="Figure: Command Output"
Figure: Command Output
Output interpretation:
The non-zero counter statistics show dropped packet statistics and the counter against which the packets were dropped.
dropstats
: List of all counter statistics key of the forwarding state.
data:image/s3,"s3://crabby-images/e1e5b/e1e5b76ace6f79a920e1a0b34e4e839bc2277ad4" alt="Figure: Command"
Figure: Command
Sample output:
data:image/s3,"s3://crabby-images/7e163/7e163405789c12e23263926817b5cff2a78add92" alt="Figure: Command Output"
Figure: Command Output
Output interpretation:
Output represents packet forwarding state packet drop statistics against each of the categories. The output is similar to dropstats-non-zero
, except that it presents all counters (both zero and non-zero).
BGP
BGP Commands: CE Site nodes establish BGP sessions toward external BGP speakers for L3 reachability toward external destinations, origins, and more. The following commands can be run to check BGP state information:
show-ip-bgp
show-ip-bgp-neighbors
show-ip-bgp-advertised-route
show-ip-bgp-summary
System Troubleshooting Commands
F5 Distributed Cloud Services Customer Edge (CE) is a Kubernetes-based integrated software stack, which is managed centrally via the SaaS Console and can be instantiated in any of the customer environments – public clouds, on-premises data centers, remote branches, or even at the edge. Customer Edge software running on the CE nodes can run self-diagnosis on the overall system health, reachability to endpoints for health operations, and more. System Troubleshooting commands allow customers to review the system’s self-diagnosis information using health
and diagnosis
commands.
Customer Edge software running on the CE nodes can be invoked to run a self-diagnosis of the system. This can be done by running health
or diagnosis
Site CLI commands.
Health
health
: No command options available.
data:image/s3,"s3://crabby-images/2a190/2a190679e943b276cc02b2a41e1bf6f2c8b7c874" alt="Figure: Command"
Figure: Command
Sample output:
data:image/s3,"s3://crabby-images/b86b6/b86b625200a095f92034632e2826cc35dbade12a" alt="Figure: Command Output"
Figure: Command Output
Output interpretation:
The health
command provides an overall summary of the Customer Edge site registration state with F5 SaaS platform, an inventory of discovered resource information, like CPU, memory, network, and more.
Diagnosis
diagnosis
: No command options available.
data:image/s3,"s3://crabby-images/808c0/808c01af16022d1c91cea6d5474b0de7f2ed209f" alt="Figure: Command"
Figure: Command
Sample output:
data:image/s3,"s3://crabby-images/3b665/3b6650f97f662adbdedd60ad23abaaac69edbf0c" alt="Figure: Command Output"
Figure: Command Output
Output interpretation:
The diagnosis
command collects detailed health checks on the overall system state, health state of all the services in the system, reachability and domain resolution checks for public endpoints that are needed for healthy operation of customer edges.
System Services Health
F5 Distributed Cloud Services Customer Edge (CE) is a Kubernetes-based integrated software services stack. The following commands can be run to fetch detailed information about the container images for the container runtime, specific resource (for example, pod, container, or image), and list of all containers managed by the container runtime or container logs.
These are advanced pieces of information that F5 support teams may ask customers to collect in certain scenarios.
crictl-images
: No command options available.docker-images
: No command options available.
data:image/s3,"s3://crabby-images/a0f03/a0f0393c199eba45b0bee8e5d4735ddea196e23c" alt="Figure: Command"
Figure: Command
Sample output:
data:image/s3,"s3://crabby-images/eafd4/eafd4b691e12bc575860948ac5f6a9e0918e67fb" alt="Figure: Command Output"
Figure: Command Output
Output interpretation:
The command output provides detailed information about a specific resource (for example, a pod, container, or image) managed by the container runtime.
crictl-ps
: No command options available.crictl-ps-a
: No command options available.docker-ps
: No command options available.docker-ps-a
: No command options available.
data:image/s3,"s3://crabby-images/2e8d1/2e8d13fe4ab58b117e56af84ca2106df26d18546" alt="Figure: Command"
Figure: Command
Sample output:
data:image/s3,"s3://crabby-images/ab977/ab977387b3484fb5af4f52771b27283284ff41f2" alt="Figure: Command Output"
Figure: Command Output
Output interpretation:
The ps
outputs all running containers, while the ps-a
command lists all containers running and stopped or exited containers. Capture the container ID from the output to inspect details of the container using either crictl-inspect
or docker-inspect
.
crictl-inspect
: The option<container-id>
provides information about a specific container ID.docker-inspect
: The option<container-id>
provides information about a specific container ID.
data:image/s3,"s3://crabby-images/dc9c1/dc9c1c97e3248eaca03e370878732695999d2d93" alt="Figure: Command"
Figure: Command
Sample output:
data:image/s3,"s3://crabby-images/ed338/ed338490f9da8d392ffd4b430f603fa56bbd8c6c" alt="Figure: Command Output"
Figure: Command Output
Output interpretation:
Outputs detailed information about a specific resource (for example, pod, container, or image) in JSON format.
crictl-logs
: The option<container-id>
provides information about a specific container ID for which logs need to be retrieved.docker-logs
: The option<container-id>
provides information about a specific container ID for which logs need to be retrieved.
data:image/s3,"s3://crabby-images/329eb/329eb6bcf8d62a26f67a9f56d0cccc04941f3e52" alt="Figure: Command"
Figure: Command
Sample output:
data:image/s3,"s3://crabby-images/e1d33/e1d335788f5fadd7968fab4ba071a13689fa72c0" alt="Figure: Command Output"
Figure: Command Output
Output interpretation:
Given a container ID, this command retrieves logs from a specific container managed by the container runtime.
journalctl
: The command option includes <-u> <service-name> <-n> <number-of-lines>
.
data:image/s3,"s3://crabby-images/a40e8/a40e8076725bc0451a3b432e9c3d9bcb1c17137b" alt="Figure: Command"
Figure: Command
Sample output:
data:image/s3,"s3://crabby-images/1727e/1727e430ec3e9da4a8a6f31afe5cbe129f2ca251" alt="Figure: Command Output"
Figure: Command Output
Output interpretation:
For a given service, the log information is printed with specified number lines to aid in troubleshooting system service-related errors.
Known Caveats
Debug log bundle
collection is not supported for CE sites running as pos(s) on k8s sites.
On this page:
- Objective
- Prerequisites
- Debug log bundle
- Site CLI Commands
- Network Troubleshooting Commands
- IPsec Tunnel
- NTP Sources
- Network Statistics
- IP Addresses and Links
- Curl
- Forward State
- Route
- Next Hop
- Virtual Interface
- Dropped Packet Statistics
- BGP
- System Troubleshooting Commands
- Health
- Diagnosis
- System Services Health
- Known Caveats