벤치마킹 작업을하기 전에 리눅스 커널이 버퍼와 캐시를 위해 소비하는 메모리 (RAM)를 어떻게 확보 할 수 있습니까?
이것은 대부분 벤치마킹에 유용합니다. 버퍼와 캐시를 비우면 성능이 저하 됩니다! 버퍼와 캐시를 비우는 것이 긍정적이라고 생각했기 때문에 여기에 있다면 Linux로 가서 내 RAM을 먹었습니다! . 간단한 이야기 : 사용 가능한 메모리는 사용되지 않습니다. 메모리는 메모리를 낭비 합니다.
벤치마킹 작업을하기 전에 리눅스 커널이 버퍼와 캐시를 위해 소비하는 메모리 (RAM)를 어떻게 확보 할 수 있습니까?
이것은 대부분 벤치마킹에 유용합니다. 버퍼와 캐시를 비우면 성능이 저하 됩니다! 버퍼와 캐시를 비우는 것이 긍정적이라고 생각했기 때문에 여기에 있다면 Linux로 가서 내 RAM을 먹었습니다! . 간단한 이야기 : 사용 가능한 메모리는 사용되지 않습니다. 메모리는 메모리를 낭비 합니다.
답변:
비우기를 원한다면이 일련의 명령을 사용할 수 있습니다.
# free && sync && echo 3 > /proc/sys/vm/drop_caches && free
total used free shared buffers cached
Mem: 1018916 980832 38084 0 46924 355764
-/+ buffers/cache: 578144 440772
Swap: 2064376 128 2064248
total used free shared buffers cached
Mem: 1018916 685008 333908 0 224 108252
-/+ buffers/cache: 576532 442384
Swap: 2064376 128 2064248
숫자 인수를 위의 명령으로 변경하여 캐시 된 항목의 다양한 측면을 삭제하도록 Linux 커널에 신호를 보낼 수 있습니다.
페이지 캐시를 비우려면 :
# echo 1 > /proc/sys/vm/drop_caches
덴 트리와 아이 노드를 해제하려면 :
# echo 2 > /proc/sys/vm/drop_caches
페이지 캐시, 덴 트리 및 inode를 비우려면 다음을 수행하십시오.
# echo 3 > /proc/sys/vm/drop_caches
위의 내용은 루트로 실행됩니다. 이를 사용 sudo
하여 구문을 작성하려는 경우 구문을 다음과 같이 약간 변경해야합니다.
$ sudo sh -c 'echo 1 >/proc/sys/vm/drop_caches'
$ sudo sh -c 'echo 2 >/proc/sys/vm/drop_caches'
$ sudo sh -c 'echo 3 >/proc/sys/vm/drop_caches'
참고 : 위 명령의 난해한 버전이 있습니다.
$ echo "echo 1 > /proc/sys/vm/drop_caches" | sudo sh
구문이 왜 바뀌 었습니까? /bin/echo
프로그램 때문에에, 루트로 실행되고 sudo
있지만, 루트 전용 파일로 에코의 출력을 리디렉션있어 쉘은 여전히으로 실행됩니다. 현재 쉘은 시작 하기 전에 리디렉션 을 수행sudo
합니다.
linux-ftools
버퍼 및 캐시의 내용을 분석하고 싶은지 살펴보십시오 . 특히 어떤 파일이 현재 캐시되고 있는지 확인하려면
이 도구를 사용하면 give 디렉토리 내에서 어떤 파일이 캐시되는지 확인할 수 있습니다.
fincore [options] files...
--pages=false Do not print pages
--summarize When comparing multiple files, print a summary report
--only-cached Only print stats for files that are actually in cache.
예를 들면 다음과 /var/lib/mysql/blogindex
같습니다.
root@xxxxxx:/var/lib/mysql/blogindex# fincore --pages=false --summarize --only-cached *
stats for CLUSTER_LOG_2010_05_21.MYI: file size=93840384 , total pages=22910 , cached pages=1 , cached size=4096, cached perc=0.004365
stats for CLUSTER_LOG_2010_05_22.MYI: file size=417792 , total pages=102 , cached pages=1 , cached size=4096, cached perc=0.980392
stats for CLUSTER_LOG_2010_05_23.MYI: file size=826368 , total pages=201 , cached pages=1 , cached size=4096, cached perc=0.497512
stats for CLUSTER_LOG_2010_05_24.MYI: file size=192512 , total pages=47 , cached pages=1 , cached size=4096, cached perc=2.127660
stats for CLUSTER_LOG_2010_06_03.MYI: file size=345088 , total pages=84 , cached pages=43 , cached size=176128, cached perc=51.190476
stats for CLUSTER_LOG_2010_06_04.MYD: file size=1478552 , total pages=360 , cached pages=97 , cached size=397312, cached perc=26.944444
stats for CLUSTER_LOG_2010_06_04.MYI: file size=205824 , total pages=50 , cached pages=29 , cached size=118784, cached perc=58.000000
stats for COMMENT_CONTENT_2010_06_03.MYI: file size=100051968 , total pages=24426 , cached pages=10253 , cached size=41996288, cached perc=41.975764
stats for COMMENT_CONTENT_2010_06_04.MYD: file size=716369644 , total pages=174894 , cached pages=79821 , cached size=326946816, cached perc=45.639645
stats for COMMENT_CONTENT_2010_06_04.MYI: file size=56832000 , total pages=13875 , cached pages=5365 , cached size=21975040, cached perc=38.666667
stats for FEED_CONTENT_2010_06_03.MYI: file size=1001518080 , total pages=244511 , cached pages=98975 , cached size=405401600, cached perc=40.478751
stats for FEED_CONTENT_2010_06_04.MYD: file size=9206385684 , total pages=2247652 , cached pages=1018661 , cached size=4172435456, cached perc=45.321117
stats for FEED_CONTENT_2010_06_04.MYI: file size=638005248 , total pages=155763 , cached pages=52912 , cached size=216727552, cached perc=33.969556
stats for FEED_CONTENT_2010_06_04.frm: file size=9840 , total pages=2 , cached pages=3 , cached size=12288, cached perc=150.000000
stats for PERMALINK_CONTENT_2010_06_03.MYI: file size=1035290624 , total pages=252756 , cached pages=108563 , cached size=444674048, cached perc=42.951700
stats for PERMALINK_CONTENT_2010_06_04.MYD: file size=55619712720 , total pages=13579031 , cached pages=6590322 , cached size=26993958912, cached perc=48.533080
stats for PERMALINK_CONTENT_2010_06_04.MYI: file size=659397632 , total pages=160985 , cached pages=54304 , cached size=222429184, cached perc=33.732335
stats for PERMALINK_CONTENT_2010_06_04.frm: file size=10156 , total pages=2 , cached pages=3 , cached size=12288, cached perc=150.000000
---
total cached size: 32847278080
위의 출력으로 현재 캐시중인 * .MYD, * .MYI 및 * .frm 파일이 여러 개 있음을 알 수 있습니다.
스왑을 지우려면 다음 명령을 사용할 수 있습니다.
$ free
total used free shared buffers cached
Mem: 7987492 7298164 689328 0 30416 457936
-/+ buffers/cache: 6809812 1177680
Swap: 5963772 609452 5354320
그런 다음이 명령을 사용하여 스왑을 비활성화하십시오.
$ swapoff -a
이제 비어 있는지 확인할 수 있습니다.
$ free
total used free shared buffers cached
Mem: 7987492 7777912 209580 0 39332 489864
-/+ buffers/cache: 7248716 738776
Swap: 0 0 0
다시 활성화하려면 다음을 수행하십시오.
$ swapon -a
이제 다시 확인하십시오 free
.
$ free
total used free shared buffers cached
Mem: 7987492 7785572 201920 0 41556 491508
-/+ buffers/cache: 7252508 734984
Swap: 5963772 0 5963772
tee
루트로 쓰는 것을 좋아 합니다 :echo 3 | sudo tee /proc/sys/vm/drop-caches