Skip to content
Youngho Chaa cha cha
TwitterHomepage

Installing ClamAV on a Linux VM

azure devops, terraform2 min read

Do I need to install anti-virus software on Linux?

While it's true that Linux distributions are less susceptible to viruses and malware than Windows systems, it's not completely immune. Linux is often safer due to its smaller user base, its open-source nature, and the way privileges work, limiting the ability of malware to cause damage.

In my case, it was more for a compliance reason though. All our VMs on Google cloud should have an Antivirus software installed.

What is ClamAV?

ClamAV is a popular open-source antivirus software toolkit that is used to detect various types of malicious software, including viruses, trojans, and malware. It was originally designed especially for scanning emails at mail gateways, but it can be used in a variety of contexts. Yet it has command-line interface, allowing it to be integrated into scripts and automated workflows and with its scanning capabilities, it fits for our purpose.

ClamAV components

  • clamd or clamav-daemon: Daemon that loads the virus database definitions into memory
  • clamav-freshclam: Daemon that periodically checks for virus database definition updates, downloads, and installation
  • clamdscan: You can scan the filesystem with this utility

Memory requirement

clamd daemon consumes around 1GB of memory regardless of whether it is actively scanning or not. So the machine needs at least 1.5GB RAM. Our VMs were originally provisioned with 0.6GB memory with the machine type of f1-micro on Google Cloud.

Then clamav-freshclam failed to start with a message:

freshclam database load killed by signal 9

I updated the terraform and re-provisioned the machine with 2GB RAM with the machine type of e2-small and it started working.

resource "google_compute_instance" "bastion_instance" {
project = local.service_project_id
name = "gke-bastion${var.name_suffix}"
description = md5(local.bastion_cloud_init)
machine_type = "e2-small"
zone = local.host_network_zone_a
...

Install ClamAV

The existing terraform script already uses cloud-init, so I added my script to the yaml file.

runcmd:
- [apt-get, update]
- [apt-get, 'install', -y, clamav, clamav-daemon, clamav-freshclam]
- [systemctl, stop, clamav-freshclam]
- [freshclam]
- [systemctl, start, clamav-freshclam]
- [systemctl, enable, clamav-daemon]
- [systemctl, start, clamav-daemon]

The reason the script stops clamav-freshclam deamon and do freshclam manually was because clamav-deamon often failed to start due to the race condition: clamav-daemon starts before clamav-freshclam finishes downloading the AV database.

References

© 2024 by Youngho Chaa cha cha. All rights reserved.
Theme by LekoArts