Troubleshooting the Edge Delta Fleet on Linux
4 minute read
This page provides a walkthrough for diagnosing and resolving issues related to the Edge Delta deployment on Linux platforms. It covers viewing and verifying the fleet’s configuration, process status, and logging details for both Upstart and Systemd-based systems. It includes steps for restarting, starting, and stopping the Edge Delta process, ensuring smooth operations by checking system information through top or htop, and adjusting SELinux settings if necessary. The document also addresses advanced troubleshooting techniques such as analyzing memory limits and collecting heap dumps for performance profiling.
View the Fleet’s Configuration
Check the Fleet’s configuration file to ensure that the pipeline configuration does not contain any issues:
cat /opt/edgedelta/agent/config.yml
View the Process Configuration
Use the less command to view the configuration file.
- For Upstart-based systems such as RHEL, Amazon Linux, etc.:
less /etc/init/edgedelta.conf
- For Systemd-based systems such as Debian, Ubuntu, etc.:
less /etc/systemd/system/edgedelta.service
Get the Process Status
Use the status command to view the edgedelta process status:
- For Upstart-based systems such as RHEL, Amazon Linux, etc.:
initctl status edgedelta
- For Systemd-based systems such as Debian, Ubuntu, etc.:
systemctl status edgedelta
- For older systems with init:
sudo /etc/init.d/edgedelta status
- For older Ubuntu systems:
sudo service edgedelta status
Restart the Process
To restart the edgedelta
process use the restart command:
- For Upstart-based systems such as RHEL, Amazon Linux, etc.:
initctl restart edgedelta
- For Systemd-based systems such as Debian, Ubuntu, etc.:
systemctl restart edgedelta
To ensure the process was restarted, first capture its PID:
pgrep edgedelta
or
ps aux | grep edgedelta
Run the command to restart the process and check the PID of the process again.
Start and Stop the Process
To start or stop the edgedelta
process use one of the following commands:
- For Upstart-based systems such as RHEL, Amazon Linux, etc.:
initctl start edgedelta
initctl stop edgedelta
- For Systemd-based systems such as Debian, Ubuntu, etc.:
sytemctl start edgedelta
sytemctl stop edgedelta
Get the Process’ System Information
Information can be gathered by either using top or htop. The top command will give you an isolated view of the process:
top -p $(pgrep edgedelta)
If htop is installed:
htop
then press /
and type edgedelta
.
For Upstart-based systems such as RHEL, Amazon Linux, etc. Messages from the initialization script can give you more information. They are logged every time the system is reloaded, the process is started or restarted, and when the configuration is changed.
tail -F /var/log/messages
If there is not enough information check the log level set:
initctl log-priority
You can check available levels:
initctl log-priority help
For troubleshooting, you should use the finest level of detail:
$ initctl log-priority debug
SELinux Configuration in Enforcing Mode
If you encounter issues related to SELinux, ensure that the SELinux configuration for the Edge Delta agent is correctly set up:
sudo semanage fcontext -a -t bin_t -f f /opt/edgedelta/agent/edgedelta
sudo restorecon -v /opt/edgedelta/agent/edgedelta
sudo systemctl restart edgedelta.service
These commands ensure SELinux policies do not block the execution of the Edge Delta agent.
Restart the Operating System
For Upstart-based systems such as RHEL, Amazon Linux, etc. The operating system needs to be restarted for any change to the configuration to take effect. For Systemd-based systems such as Debian, Ubuntu, etc. use
systemctl daemon-reload
View the Agent Log File
Check the agent’s log file for any errors that may indicate an issue with the agent, configuration, or deployment settings:
cat /var/log/edgedelta/edgedelta.log
Troubleshoot Memory Limits
The edgedelta
service will restart if it reaches its memory limits.
If you notice that the service restarts frequently, then you may want to increase the limits. If you do not want to change your memory limits, then you can enable memory profiling and contact support with a heapdump from the profiler.
Run the following command for the current agent version (replace x.x.xx) to enable a more aggressive Garbage Collection and pprof profiler on port 6060. If another service uses port 6060, then you must use another port number in the bash and curl commands.
`sudo ED_API_KEY=$API_KEY ED_ENV_VARS="GOGC=30,PROFILER_PORT=6060" bash -c "$(curl -L https://release.edgedelta.com/vx.x.xx/install.sh)"`
Run the following command to obtain heapdump from the profiler. GOGC is 30. The default value is 100 for Golang. This setting will initiate a garbage collection job once the heap size has grown 30% since the last garbage collection.
curl http://localhost:6060/debug/pprof/heap --output heap