With a large number of devices, Traccar server can quickly use up disk space available on the host machine. Main causes are positions and events in the database and daily log files.
This documentation provides a guide on how to set up automated history cleanup on a Linux server with MySQL database. The benefit of our database cleanup script is that it handles data in small batches and doesn't block Traccar server from receiving and storing new data.
Create cron script file:
nano /etc/cron.daily/traccar-clear-database
With the following content
#!/bin/bash result="" while [[ "$result" != *" 0 rows affected"* ]]; do result=$(mysql -u root -proot traccar -vve "DELETE FROM tc_positions WHERE fixTime < DATE(DATE_ADD(NOW(), INTERVAL -1 YEAR)) AND id NOT IN (SELECT positionId FROM tc_devices WHERE positionid IS NOT NULL) LIMIT 10000") sleep 1 done result="" while [[ "$result" != *" 0 rows affected"* ]]; do result=$(mysql -u root -proot traccar -vve "DELETE FROM tc_events WHERE eventTime < DATE(DATE_ADD(NOW(), INTERVAL -1 YEAR)) LIMIT 10000") sleep 1 done
And make it executable:
chmod +x /etc/cron.daily/traccar-clear-database
Make sure to adjust parameters to your use case:
It is also strongly recommended to create indexes on tc_positions.fixTime and tc_events.eventTime like this:
CREATE INDEX idx_positions_fixtime ON tc_positions (fixtime); CREATE INDEX idx_events_eventtime ON tc_events (eventtime);
The following commands will set up automatic daily cleanup of the Traccar logs:
cat > /etc/cron.daily/traccar-clear-logs << EOF #!/bin/sh find /opt/traccar/logs/ -mtime +3 -type f -delete EOF chmod +x /etc/cron.daily/traccar-clear-logs
Make sure to adjust the parameter to your use case: