swap faq

11:55:00 PM 0 Comments


SwapFaq



Introduction


  • This FAQ is aimed at Linux novices.

  • People
    always wonder how much swap they should create at install time, or
    after installing they may think, "have I made a large enough swap?
    Should I reinstall with a larger swap?"
  • This FAQ will tell you how much swap you need and how to add more swap after installation.
  • You
    will be given very simple answers (to prevent losing too much time
    reading this FAQ) and some explanations that may help you form your own
    opinion. For a more detailed explanation of memory and swap, see here.


How much swap do I need?


  • If you have n MB of RAM, you need between n and 2*n MB of swap.
  • If you have a large enough disk, use 2*n MB swap.


What is swap for?


  • As we'll see, there are basically four different purposes for swap:
    • Some programs are very memory-consuming.
    • Extra memory can come in handy.
    • Optimizing memory usage.
    • Hibernation (suspend-to-disk)
  • To begin, it's worth mentioning that computers have changed a lot since swap was first used:
    • At
      first, swap was needed to extend real memory capacity. Users would
      utilize swap so that available memory would be the addition of both RAM
      space and swap space.
    • Nowadays, RAM is often big enough that computers may not require swap.
  • Some programs are very memory-consuming:

    • Sometimes, a large program (like OpenOffice, Neverwinter Nights, or a video editor) make the entire system need extra memory.

    • In these cases, swap will be used to help the system handle any extra load.
  • Extra memory might come in handy:

    • Unforeseeable
      events can and will happen (a program going crazy, some action needing
      much more space than you thought, or any other unpredictable
      combination of events).
    • In these cases, swap can give you an extra delay to figure out what happened, or to finish what you are working on.
  • Swap can optimize memory usage:

    • Hard
      drives are considerably slower than RAM. So, when you need a file (be
      it a data file - like a video, executables - like Firefox, or
      libraries), the Linux kernel reads the file into RAM and keeps it
      there, so that the next time you need it, it's already in RAM and data
      access is much faster (thousands of times faster). The portions of RAM
      that accelerate disk read are called "cached memory." They make a huge difference in terms of responsiveness.

    • The
      Linux kernel automatically moves RAM reserved by programs - but not
      really used in swap - so that it can serve the better purpose of
      extending cached memory.
  • Hibernation needs swap

    • The
      hibernation feature (suspend-to-disk) writes out the contents of RAM to
      the swap partition before turning off the machine. Therefore, your swap
      partition should be at least as big as your RAM size. The hibernation
      implementation currently used in Ubuntu, swsusp, needs a swap or suspend partition. It cannot use a swap file on an active file system.


Should I reinstall with more swap?


  • Definitely not.
  • With the 2.6 kernel, "a swap file is just as fast as a swap partition."(Wikipedia:Paging, LKML).


How do I add more swap?


  • Usually,
    people associate swap with a swap partition, perhaps because they were
    asked to create a swap partition at install time. In fact, any file can
    be used as a swapping device, be it a partition or a conventional file.
    If you're considering responsiveness, my advice is to add more RAM.
    Swapping to a partition or a file won't change anything.
  • We will add more swap by adding a swap file.
  • Adding more swap is a four-step process :

    • a- Creating a file the size you want.
    • b- Formatting that file to create a swapping device.
    • c- Adding the swap to the running system.
    • d- Making the change permanent.
  • We will consider (as an example) a 512 Mb swap need.

  • a- Creating a file the size you want:

    • We will create a /mnt/512Mb.swap swap file.

      sudo dd if=/dev/zero of=/mnt/512Mb.swap bs=1M count=512
      • What's important here is count=512, which means we want our file to contain 512 blocks of bs=1M, which means block size = 1 MegaBytes.

      • Be careful *not* to do this dd of=/mnt/512Mb.swap bs=1M seek=512 count=0

        • Though the file grows to 512Mb immediately, it will have holes that makes it unusable.
  • b- Formatting that file to create a swapping device:

    sudo mkswap /mnt/512Mb.swap
  • c- Adding the swap to the running system:

    sudo swapon /mnt/512Mb.swap
    • You can see with "cat /proc/meminfo" that your additional swap is now available.

  • d- Making the change permanent:

    • edit your /etc/fstab:

      gksudo gedit /etc/fstab
    • and add this line at the end of the file:

      /mnt/512Mb.swap  none  swap  sw  0 0
    • save and reboot


Example of making a swap file


This is an example of making and using a swap file on a computer with no swap partition.

user@computer:~$ sudo dd if=/dev/zero of=/mnt/512Mb.swap bs=1M count=512
Password:
512+0 records in
512+0 records out
536870912 bytes (537 MB) copied, 35.3802 seconds, 15.2 MB/s
user@computer:~$ sudo mkswap /mnt/512Mb.swap
Setting up swapspace version 1, size = 536866 kB
no label, UUID=dd6a01c8-93f0-41e0-9b7a-306956d8821b
user@computer:~$ sudo swapon /mnt/512Mb.swap
user@computer:~$ cat /proc/meminfo
MemTotal: 499496 kB
MemFree: 9156 kB
Buffers: 4748 kB
Cached: 233140 kB
SwapCached: 724 kB
Active: 254432 kB
Inactive: 157920 kB
HighTotal: 0 kB
HighFree: 0 kB
LowTotal: 499496 kB
LowFree: 9156 kB
SwapTotal: 524280 kB
SwapFree: 523556 kB
Dirty: 128 kB
Writeback: 0 kB
Mapped: 243420 kB
Slab: 20672 kB
CommitLimit: 774028 kB
Committed_AS: 648680 kB
PageTables: 2224 kB
VmallocTotal: 524280 kB
VmallocUsed: 5708 kB
VmallocChunk: 518176 kB
user@computer:~$ gksudo gedit /etc/fstab
user@computer:~$ free
total used free shared buffers cached
Mem: 499496 479488 20008 0 8256 215892
-/+ buffers/cache: 255340 244156
Swap: 524280 3856 520424
#####Then, after running a few more programs...
user@computer:~$ free
total used free shared buffers cached
Mem: 499496 492768 6728 0 1240 142336
-/+ buffers/cache: 349192 150304
Swap: 524280 53384 470896

#####Next, reboot to make sure it will work consistently.
user@computer:~$ free
total used free shared buffers cached
Mem: 499496 493136 6360 0 7528 174700
-/+ buffers/cache: 310908 188588
Swap: 524280 17148 507132
#####I followed the instructions to the letter, and it worked :-)


Priority of swap containers


  • The Linux kernel assigns priorities to all swap containers. You can see them by

cat /proc/swaps
  • Priorities can be changed by using the swapon command or defined in /etc/fstab. Consult the manual page of swapon for more info

man swapon


Performance tuning with ''swappiness''


The swappiness
parameter controls the tendency of the kernel to move processes out of
physical memory and onto the swap disk. Because disks are much slower
than RAM, this can lead to slower response times for system and
applications if processes are too aggressively moved out of memory.

  • swappiness can have a value of between 0 and 100

  • swappiness=0 tells the kernel to avoid swapping processes out of physical memory for as long as possible

  • swappiness=100 tells the kernel to aggressively swap processes out of physical memory and move them to swap cache

  • Ubuntu uses a default setting of swappiness=60

Reducing the default value of swappiness will probably improve overall performance for a typical Ubuntu desktop installation. A value of swappiness=10 is recommended, but feel free to experiment. Note: Ubuntu server installations have different performance requirements to desktop systems, and the default value of 60 is likely more suitable.


How to check the swappiness value


  • cat /proc/sys/vm/swappiness


How to change the swappiness value


  • A temporary change (lost on reboot) with a swappiness value of 10 can be made with:

    sudo sysctl vm.swappiness=10

    To make a change permanent, edit the configuration file with your favorite editor:

    gksudo gedit /etc/sysctl.conf

    Search for vm.swappiness and change its value as desired. If vm.swappiness does not exist, add it to the end of the file like so:

    vm.swappiness=10
    Save the file and reboot.


Troubleshooting


Note:this regards mainly swap on hard disk partitions, but it could help you anyway. Also replace /dev/hda8 with your configuration.

Help! The swap is not being used! When I issue the free command, it shows something like this:

tom@tom:~$ free
total used free shared buffers cached
Mem: 515980 448664 67316 0 17872 246348
-/+ buffers/cache: 184444 331536
Swap: 674688 0 674688
  • 1-
    First try, if it is because the system cannot use swap or because it
    just does not need it. Start many memory consuming applications (e.g.
    Gimp, web browsers, OpenOffice etc) and then issue the free command again. Is swap being used now?

  • 2- See if there is a swap partition at all:

    sudo fdisk -l

You should be able to see something like this in the output

/dev/hda8            4787        4870      674698+  82  Linux swap / Solaris

If
not, you either need to create a swapfile (see above for instructions)
or create a swap partition. In order to do that, you can:

  • boot
    from your Ubuntu install CD (rather than using the expert bot option),
    create a swap partiton out of the free space on your hard disk and then
    interrupt your installation
  • or just use cfdisk (lookup its man page for more info).

However, let us suppose you have a swap partition. There are several ways of enabling it.

  • 2.1- First make sure you have something like this

    /dev/hda8       none            swap    sw              0       0

in /etc/fstab. It enables swap on boot.

  • 2.2- Then try to disable all swap, recreate it, then re-enable it

    swapoff -a
    /sbin/mkswap /dev/hda8
    swapon -a
  • 2.3 Some people also reported this to help:
    • 1) cfdisk : erase the old swap partition and recreate a new one
    • 2) reboot (mandatory)
    • 3) mkswap /dev/hda8
    • 4) swapon -a


Author



About the document


  • TODO :

    • Determine the more standard emplacement for swap files (FHS).
    • Add power suspend considerations.
    • Add how to add the swap file to make Ubuntu hibernate to it
  • 15/05/2005, 01:42
    • First version.

Some say he’s half man half fish, others say he’s more of a seventy/thirty split. Either way he’s a fishy bastard.