I noticed yesterday that my DigitalOcean monthly spend was a little more than I was expecting, turns out I have launched the wrong instance size when I last rebuilt my machine, so to save myself a few dollars a month I migrated the instance to a fresh server with a lower spec.

By default DigitalOcean servers do not come with swap enabled, because of this you run the risk of oomkiller killing processes to try and keep the server accessible. Luckily as all DigitalOcean servers are SSD backed and come with a decent amount of disk space so enabling swap isn’t an issue;

fallocate -l 4G /swapfile
chmod 600 /swapfile
mkswap /swapfile
swapon /swapfile
echo “/swapfile none swap sw 0 0” >> /etc/fstab

as you can see the server now has a 1GB of RAM and 4GB of swap;

[root@server ~]# swapon -s
Filename Type Size Used Priority /swapfile file 4194300 96460 -1 
root@server ~]# free -m
total used free shared buffers cached Mem: 
994 919 74 3 2 55
-/+ buffers/cache: 860 133
Swap: 4095 94 4001

There are also a few other settings you can tune to help with performance;

sysctl vm.swappiness=10
sysctl vm.vfs_cache_pressure=50
echo “## Make Swap betterer” >> /etc/sysctl.conf
echo “vm.swappiness = 10” >> /etc/sysctl.conf
echo “vm.vfs_cache_pressure = 50” >> /etc/sysctl.conf

These two options do the following;

  • swappiness — this control is used to define how aggressively the kernel swaps out anonymous memory relative to pagecache and other caches. Increasing the value increases the amount of swapping.
  • vfs_cache_pressure — this variable controls the tendency of the kernel to reclaim the memory which is used for caching of VFS caches, versus pagecache and swap. Increasing this value increases the rate at which VFS caches are reclaimed.
[root@server ~]# sysctl vm.swappiness
vm.swappiness = 10
[root@server ~]# sysctl vm.vfs_cache_pressure
vm.vfs_cache_pressure = 50
[root@server ~]#

This will hopefully save me a little money and make sure that things like MySQL don’t randomly get killed 🙂