熱點推薦:
您现在的位置: 電腦知識網 >> 編程 >> Oracle >> 正文

如何通過RamDisk的方法加速小型數據庫的訪問速度

2013-11-13 15:29:59  來源: Oracle 

  RamDisk簡介
  本文首先介紹了如何在rh系統上創建一個RamDisk然後介紹了如何通過將數據庫內容存放到RamDisk中的方法來加速對數據庫的訪問
  
  什麼是RamDisk?一個RamDisk是分配作為一個分區的內存塊或者說將內存模擬為硬盤空間從而可以想對待硬盤空間一樣在其上保存文件為什麼會要使用RamDisk呢?主要是為了提高速度若事先知道特定的文件將被高頻率訪問通過將文件存放在內存裡就可以提高性能例如web服務器就可以采用這種方式來加快訪問速度下面是一些可能會對加深對RamDisk的理解的資源鏈接
  
  
  
  /usr/src/linux/Documentation/RamDisktxt
  如何使用RamDisk
  使用RamDisk是非常簡單的首先RH的缺省安裝本身就有對RamDisk的支持你所要作的就是格式化一個RamDisk然後加載(mount)其到目錄結構下即可通過命令ls al /dev/ram*可以查看系統可以利用的RamDisk的數目這些RamDisk並不起作用除非設置以後下面是一個非常簡單的使用RamDisk的例子
  
  # create a mount point:
  mkdir /tmp/RamDisk
  # create a filesystem:
  mkefs /dev/ram
  # mount the RamDisk:
  mount /dev/ram /tmp/RamDisk
  
  這三個命令分別為RamDisk創建一個目錄格式化它(創建文件系統)最後加載該文件系統到/tmp/RamDisk下面就可以對待該目錄為一個分區使用若格式化失敗則說明你的系統內核沒有對RamDisk的支持則需要重新編譯內核RamDisk支持的內核開關是CONFIG_BLK_DEV_RAM
  
  缺省的RamDisk的大小為 Mb=在創建randisk文件系統時可以得到RamDisk大小的信息
  
  mkefs Jan for EXT FS b //
  Linux ext filesystem format
  Filesystem label=
   inodes blocks
   blocks (%) reserved for the super user
  First data block=
  Block size= (log=)
  Fragment size= (log=)
   block group
   blocks per group fragments per group
   inodes per group
  
  運行命令df k /dev/ram可以查看可以真正使用的RamDisk的空間大小(因為創建文件系統時會占用一些空間)
  
  >df k /dev/ram
  Filesystem kblocks Used Available Use% Mounted on
  /dev/ram % /tmp/RamDisk
  需要注意的是當你的系統重新啟動以後RamDisk中的數據會丟失所以如果RamDisk中的數據被修改了必須將其備份到別的目錄下
  
  改變RamDisk的大小
  為了使用RamDisk可以通過將對RamDisk的支持編譯進入內核中或者編譯為模塊的方式在需要時將其加載編譯為模塊的方式可以在加載模塊時動態決定RamDisk的大小
  
  當RamDisk被編譯進入內核改變RamDisk的大小的方法為在nf中田加內容 RamDisk_size= (or RamDisk= for old kernels)然後運行lilo命令重新啟動機器這樣下次加載RamDisk以後大小就變為M
  
  boot=/dev/hda
  map=/boot/map
  install=/boot/bootb
  prompt
  timeout=
  image=/boot/vmlinuz
  label=linux
  root=/dev/hda
  readonly
  RamDisk_size=
  
  當編譯RamDisk支持為模塊形式可以在加載時決定RamDisk的大小可以通過雜/etc/confmodule中添
  
  options rd rd_size=
  
  或者在動態加載是通過命令行的形式傳入
  
  insmod rd rd_size=
  
  下面是關於如何使用模塊的一個例子
  
  卸載前面加載的文件系統umount /tmp/RamDisk
  卸載模塊rmmod rd
  加載RamDisk模塊並設置大小為Minsmod rd rd_size=
  創建一個文件系統mkefs /dev/ram
  加載RamDisk的文件系統mount /dev/ram /tmp/RamDisk
  在web服務器中使用RamDisk的例子
  
  這裡舉一個在web服務器中使用三個RamDisk的例子這裡要確保web服務器的所有內容不超過M(包括CGI的內容)
  
  首先對web服務器的root目錄下的內容備份到其他地方然後重新創建www的根目錄
  
  mv /home/httpd/ /home/httpd_real
  mkdir /home/httpd
  mkdir /home/httpd/cgibin
  mkdir /home/httpd/html
  mkdir /home/httpd/icons
  
  然後在/etc/rcd/initd/中添加如下啟動執行信息
  
  ### Make the RamDisk partitions
  /sbin/mkfs t ext /dev/ram
  /sbin/mkfs t ext /dev/ram
  /sbin/mkfs t ext /dev/ram
  
  ### Mount the RamDisks to their appropriate places
  
  mount /dev/ram /home/httpd/cgibin
  mount /dev/ram /home/httpd/icons
  mount /dev/ram /home/httpd/html
  
  ### Copying real directory to RamDisks (the
  ### data on the RamDisks is lost after a reboot)
  tar C /home/| tar C /home/httpd x
  
  ### After this you can start the webserver
  
  注
  切記若RamDisk中的數據被修改並且做的修改都是有意義的則需要對RamDisk中的數據做備份
  你可以啟動一個cron任務來完成這個工作每10分鐘檢查一次看是否有數據被修改若有則對數據進行備份
  RamDisk的一個應用是使用/tmp做為RamDisk若系統中有很多程序使用RamDisk則可以很明顯地加快系統速度而且每次系統重新啟動這些暫時數據都會丟失
  通過RamDisk加速小型數據庫的訪問速度
  
  如果將將PostgreSQL數據庫服務器文件加載到內存中就可以加快數據庫訪問速度
  
  在/test目錄下加載RamDisk
  一在/test目錄下設置RamDisk
  mkdir p /Test
  mkfs t ext /dev/ram
  mount /dev/ram /Test
  這時候你將擁有一個4M大小的RamDisk根據需要你可以更改你的RamDisk的大小
  二為PostgreSQL設置RamDisk
  
  理想狀態下你將擁有兩個數據庫服務器一個是可以進行修改的另外一個是存放在RamDisk中的拷貝為了達到這個目的需要使用命令 pg_dumppg_dumpall
  
  注這裡假設已經在nf中設置RamDisk的大小使其大於數據庫服務器的大小如果你希望了解合適的大小可以使用命令cd /var/lib/pgsql; du
  
  然後
  
  ### Stop the current postgresql server
  /etc/rcd/initd/postgres stop
  ### rename the current directory
  mv /var/lib/pgsql /var/lib/pgsql_main
  #### Create a directory to have our RamDisk on
  mkdir p /var/lib/pgsql_memory
  #### change the ownership of the new directory to postgres or whatever
  #### the actual owner is
  chown postgres /var/lib/pgsql_memory
  #### Make an alias or link to the original name /var/lib/pgsql
  ln s /var/lib/pgsql_memory /var/lib/pgsql
  
  #### Format the RamDisk
  mkfs t ext /dev/ram
  #### Mount the RamDisk to the postgresql directory
  mount /dev/ram /var/lib/pgsql_memory
  
  #### Copy everything from the main directory into the RamDisk
  tar C /var/lib/pgsql_main cp | tar C /var/lib/pgsql_memory xp
  ### Start the current postgresql server
  /etc/rcd/initd/postgres start
  
  經過測試發現在RamDisk中的PostgreSQL的性能提升最高達到%左右需要的時候可以將其他的應用放置在RamDisk中以提升效率如ldap服務器等
  
  

From:http://tw.wingwit.com/Article/program/Oracle/201311/16820.html
    推薦文章
    Copyright © 2005-2013 電腦知識網 Computer Knowledge   All rights reserved.