Troubleshooting (CLI)
EOL and Deprecation list:
- Anka Virtualization + CLI < 2.0 EOL
We recommend using our diagnostic package collection script. This script collects logs and usage statistics from the host and archives them.
bash -c "$(curl -fsSL https://raw.githubusercontent.com/veertuinc/scripts/main/generate-anka-node-diagnostics.bash)"
It is also best to run this as close to when an issue happens as several commands grab a window in time.
Once you have collected the logs, go through the below mentioned troubleshooting steps and then contact support.
Anka Virtualization
Troubleshooting Checklist
- Ensure that you’ve run
sudo anka license accept-eula
on the host. - Make sure you’ve got a valid license with
sudo anka license validate
. - Check
df -h
and other host or VM resource usage (CPU/RAM) and be sure that the host resources are not exhausted. - Check
[~]/Library/Logs/Anka/
logs for any indication of why the failure happened. See the Logs section right below this for more info. - Ensure that all components in your Anka environment can communicate. This includes connectivity between CI/CD tooling we do not support.
- Disable anti-virus and firewalls on the host.
- If a VM is failing, try manually starting it on the host and use
anka --debug . . .
when you do for verbose output. - If using the Anka Build Cloud, check under the
/var/log/veertu/
and specifically theanka_agent.ERROR
for any messages related to the problem (or at all).
Logs
Anka runs as any user on the host, so the paths and locations described below can sometimes be under$HOME
or~
.
- Anka CLI commands executed as root/sudo:
/Library/logs/Anka
- Anka CLI commands as a non-root user:
$HOME/Library/logs/Anka
The above logs are rotated at 1MB and maintains a maximum of 10 files. This is not configurable.
In these directories you will find the following logs:
anka.log
- The primary log including anka commands (Anka CLI, Anka run) STDOUT and STDERRlupd.log
- License auto-upgrade service logs; it’s rarely used and most likely not related to VMs runtime{UUID}.log
- ({UUID}
is the specific VM’s UUID) Specific VM logs; useful if VM exits abnormally or fails to start.
ARM USERS: When starting VMs with-v
, VM logs will be written toanka.log
instead of their{UUID}.log
.
If you’re using the Anka Build Cloud Controller to start and terminate VMs, you need to set an ENV so the Node Agent doesn’t delete the
{UUID}.log
on termination. This requires editing the agent’s plist:<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> <plist version="1.0"> <dict> <key>EnvironmentVariables</key> <dict> <key>ANKA_DELETE_LOGS</key> <string>0</string> </dict> <key>Label</key> <string>com.veertu.anka.cluster.agent</string> <key>ProgramArguments</key> <array> <string>/Library/Application Support/Veertu/Anka/bin/anka_agent_helper</string> <string>--controller-addr</string>
/var/log/install.log
- Install related STDOUT/ERR
Anka and Apple will also report crashes in /Library/Logs/DiagnosticReports
as .crash
or .hang
.
Build Cloud (optional)
Only relevant if you’ve joined your Node to the Build Cloud Controller & Registry.
- Logs location:
/var/log/veertu
- Format:
regd.HOSTNAME.USER.LOG.LOGTYPE.TIMESTAMP
There are 5 type of symlinks in the logs location pointing to the latest active logs. The verbosity of the logs are from highest (INFO) to the lowest (ERROR):
anka_agent.INFO
- contains all of the below except for CMD log.anka_agent.WARNING
- contains WARNNIGS & ERRORS.anka_agent.ERROR
- contains just ERRORS.anka_agent.FATAL
- only FATAL ERRORS.anka_agent.CMD
- (new in 1.20.0) contains the various anka commands the agent is executing on the host as well as the returned data.
You can also read and download the logs via the UI in the Controller dashboard. Though, only relevant if you’ve joined your Node to the Build Cloud Controller & Registry.