Hey Listee's
I have a CentOS server with 2GB of ram and a swap drive of 4GB;
swapon -a shows my swap drive as 4GB with only about 350 bytes in use (which is fine as my server idles with about 350-400MB ram usage so no swap should be in use. However my one and only swap drive had a priority of -1. I had read that the swap drive priority doesn't matter too much because I only have one swap drive so the kernel hasn't got to make a choice but also that after a certain kernel version (which is think was like 1.3.x?) it didn't even use the priority value and my kernel is newer (I have 2.6.18-128.1.6.e15).
Basically I have read difference things from difference source on the old interwebwrok and seek clarification. In the confusion I set my swap drive priority from -1 to 1 because I thought that if the drive priority were a negative value it might not actually use the swap drive. Ultimately I can't tell because there currently isn't enough memory usage demand on the server.
On a side note: I'm a reformed Windows admin and have seen the light and am moving each server one at a time over to Linux so I am used to poor memory management and needing massive page files. Realistically the swap drive shouldn't been in use but I am just worried then when this server goes live it will hit 2GB of ram usage and the swap won't kick in. Is there anyway I can check?
Thanks for reading.
Regards, James ;)
-----BEGIN GEEK CODE BLOCK----- Version: 3.1 GIT/MU/U dpu s: a--> C++>$ U+> L++> B-> P+> E?> W+++>$ N K W++ O M++>$ V- PS+++ PE++ Y+ PGP t 5 X+ R- tv+ b+> DI D+++ G+ e(+++++) h--(++) r++ z++ ------END GEEK CODE BLOCK------
James Bensley wrote:
Hey Listee's
I have a CentOS server with 2GB of ram and a swap drive of 4GB;
swapon -a shows my swap drive as 4GB with only about 350 bytes in use (which is fine as my server idles with about 350-400MB ram usage so no swap should be in use. However my one and only swap drive had a priority of -1. I had read that the swap drive priority doesn't matter too much because I only have one swap drive so the kernel hasn't got to make a choice but also that after a certain kernel version (which is think was like 1.3.x?) it didn't even use the priority value and my kernel is newer (I have 2.6.18-128.1.6.e15).
Basically I have read difference things from difference source on the old interwebwrok and seek clarification. In the confusion I set my swap drive priority from -1 to 1 because I thought that if the drive priority were a negative value it might not actually use the swap drive. Ultimately I can't tell because there currently isn't enough memory usage demand on the server.
On a side note: I'm a reformed Windows admin and have seen the light and am moving each server one at a time over to Linux so I am used to poor memory management and needing massive page files. Realistically the swap drive shouldn't been in use but I am just worried then when this server goes live it will hit 2GB of ram usage and the swap won't kick in. Is there anyway I can check?
If your system starts to swap, it really needs more memory. Otherwise you're just fine. Swap is only a last resort.
Don't worry about it.
Glenn
James Bensley wrote:
Basically I have read difference things from difference source on the old interwebwrok and seek clarification. In the confusion I set my swap drive priority from -1 to 1 because I thought that if the drive priority were a negative value it might not actually use the swap drive. Ultimately I can't tell because there currently isn't enough memory usage demand on the server.
If you only have one swap area (this sounds like it), you don't need to worry about priorities at all. Only when more than one swap area comes into play, then the kernel decides by priority which swap areas should be used over other ones (ie, have the swap on fast disks have a high priority and the swap on slower disks a lower priority). If you have two swap aread with the same priority, they will be used in a round-robin fashion.
See man 2 swapon for an explanation.
On a side note: I'm a reformed Windows admin and have seen the light and am moving each server one at a time over to Linux so I am used to poor memory management and needing massive page files. Realistically the swap drive shouldn't been in use but I am just worried then when this server goes live it will hit 2GB of ram usage and the swap won't kick in. Is there anyway I can check?
It will kick in, regardless of priority.
But probably someone will come up with a small c program which eats all available memory :)
Regards,
Ralph
It will kick in, regardless of priority.
But probably someone will come up with a small c program which eats all available memory :)
Regards,
Ralph
I would be interested in such a program if anyone has one or a mega bash script that can achive the same?
If your system starts to swap, it really needs more memory. Otherwise you're just fine. Swap is only a last resort.
Don't worry about it.
Glenn
Agreed however I am also setting up some virtual machines so physical RAM expansion won't be an option but extra swap space will be. Obviously the server won't be running constantly in the swap drive its is simply a reserve for those "just in case" moments, obviously I plan on designing the system to have plenty of physical RAM with swap as a back up but we must be prepared so in such cases I need to test it some how?
Thanks for the input guys its greatly appreciated; now to find a memory chewing, number crunching, infinite loop beast!
James ;)
-----BEGIN GEEK CODE BLOCK----- Version: 3.1 GIT/MU/U dpu s: a--> C++>$ U+> L++> B-> P+> E?> W+++>$ N K W++ O M++>$ V- PS+++ PE++ Y+ PGP t 5 X+ R- tv+ b+> DI D+++ G+ e(+++++) h--(++) r++ z++ ------END GEEK CODE BLOCK------
From: James Bensley jwbensley@gmail.com
But probably someone will come up with a small c program which eats all available memory :)
I would be interested in such a program if anyone has one or a mega bash script that can achive the same?
Quick, dirty and unoptimized (and barely tested, might not work past 4GB)... ^_^
- - - - - -8<- - - - - - - - - - - -8<- - - - - - - - - - - -8<- - - - - - #include <stdio.h> #include <stdlib.h>
int main(int argc, char *argv[]) {
FILE *fs; int i; long j; int mem_total; int mem_free; int mem_buffered; int mem_cached; int mem_to_fill; char *megabuff[1024];
fs = fopen("/proc/meminfo", "r"); fscanf(fs, "%*s %d %*s\n", &mem_total); fscanf(fs, "%*s %d %*s\n", &mem_free); fscanf(fs, "%*s %d %*s\n", &mem_buffered); fscanf(fs, "%*s %d %*s\n", &mem_cached); fclose(fs);
mem_to_fill = (mem_free+mem_buffered+mem_cached+1024)*sizeof(char); printf("Filling %dKB...\n", mem_to_fill); for (i=0; i<1024; i++) { if ((megabuff[i] = malloc(mem_to_fill)) == NULL) { fprintf(stderr, "malloc error..."); } else { for (j=0; j<mem_to_fill; j++) { megabuff[i][j] = '1'; } } } for (i=0; i<1024; i++) { free(megabuff[i]); } }
- - - - - -8<- - - - - - - - - - - -8<- - - - - - - - - - - -8<- - - - - -
Then swapoff /dev/..; swapon /dev/... to clean...
JD
James Bensley wrote:
It will kick in, regardless of priority.
But probably someone will come up with a small c program which eats all available memory :)
Regards,
Ralph
I would be interested in such a program if anyone has one or a mega bash script that can achive the same?
cat /proc/meminfo says it all, but if you really want to test this can do the job:
[nthierry@tryo tmp]$ cat totalMem.c #include <stdlib.h> #include <stdio.h>
int main(void) { int size = 0 ; while(1) { if (malloc(1024*1024*sizeof(char))) size++ ; else { printf("Total available memory: %d Mb\n", size) ; exit(0) ; } } }
[nthierry@tryo tmp]$ gcc -W -Wall totalMem.c [nthierry@tryo tmp]$ su - [root@tryo tmp]# echo 2 > /proc/sys/vm/overcommit_memory [root@tryo tmp]# echo 100 > /proc/sys/vm/overcommit_ratio [NOTE: the previous 2 commands must be run as root, and disable the memory overcommit mode. See man malloc (under BUGS) and man proc (search for overcommit) for details.] [root@tryo tmp]# swapoff -a [root@tryo tmp]# ./a.out Total available memory: 1487 Mb [root@tryo tmp]# swapon -a [root@tryo tmp]# ./a.out Total available memory: 2056 Mb
This system has 600 Mb swap space and 2 Gb of RAM of which ~500 Mb are currently used by other processes. So it works, and shows that the swap is indeed available.
When satisfied restore the vm settings [root@tryo tmp]# echo 50 > /proc/sys/vm/overcommit_ratio [root@tryo tmp]# echo 0 > /proc/sys/vm/overcommit_memory