`
isiqi
  • 浏览: 16048837 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

zz通过RamDisk加速小型数据库访问速度

阅读更多
  RamDisk简介

  本文首先介绍了如何在RedHat6.0系统上创建一个RamDisk,然后介绍了如何通过将数据库内容存放到RamDisk中的方法来加速对数据库的访问。

  什么是RamDisk?一个RamDisk是分配作为一个分区的内存块,或者说将内存模拟为硬盘空间,从而可以想对待硬盘空间一样在其上保存文件。为什么会要使用RamDisk呢?主要是为了提高速度,若事先知道特定的文件将被高频率访问,通过将文件存放在内存里就可以提高性能。例如web服务器就可以采用这种方式来加快访问速度。

  如何使用RamDisk

  使用RamDisk是非常简单的。首先,RedHat6.0的缺省安装本身就有对RamDisk的支持,你所要作的就是格式化一个RamDisk,然后加载(mount)其到目录结构下即可。通过命令"ls-al/dev/ram*"可以查看系统可以利用的RamDisk的数目。这些 RamDisk并不起作用,除非设置以后。下面是一个非常简单的使用RamDisk的例子:

    #createamountpoint:
    mkdir/tmp/RamDisk0
    #createafilesystem:
    mke2fs/dev/ram0
    #mounttheRamDisk:
    mount/dev/ram0/tmp/RamDisk0

  这三个命令分别为RamDisk创建一个目录,格式化它(创建文件系统),最后加载该文件系统到"/tmp/RamDisk0上。下面就可以对待该目录为一个分区使用。若格式化失败,则说明你的系统内核没有对RamDisk的支持,则需要重新编译内核,RamDisk支持的内核开关是: CONFIG_BLK_DEV_RAM。

  缺省的RamDisk的大小为4Mb=4096块。在创建randisk文件系统时可以得到RamDisk大小的信息:

    mke2fs1.14,9-Jan-1999forEXT2FS0.5b,95/08/09
    Linuxext2filesystemformat
    Filesystemlabel=
    1024inodes,4096blocks
    204blocks(4.98%)reservedforthesuperuser
    Firstdatablock=1
    Blocksize=1024(log=0)
    Fragmentsize=1024(log=0)
    1blockgroup
    8192blockspergroup,8192fragmentspergroup
    1024inodespergroup

  运行命令"df-k/dev/ram0"可以查看可以真正使用的RamDisk的空间大小:

    >df-k/dev/ram0
    Filesystem1k-blocksUsedAvailableUse%Mountedon
    /dev/ram039631337460%/tmp/RamDisk0

  需要注意的是当你的系统重新启动以后,RamDisk中的数据会丢失,所以如果RamDisk中的数据被修改了,必须将其备份到别的目录下。

  改变RamDisk的大小

  为了使用RamDisk,可以通过将对RamDisk的支持编译进入内核中或者编译为模块的方式,在需要时将其加载。编译为模块的方式可以在加载模块时动态决定RamDisk的大小。

  当RamDisk被编译进入内核,改变RamDisk的大小的方法为在lilo.conf中田加内容:RamDisk_size=10000 (orRamDisk=10000foroldkernels),然后运行lilo命令,重新启动机器,这样下次加载RamDisk以后,大小就变为10M:

    boot=/dev/hda
    map=/boot/map
    install=/boot/boot.b
    prompt
    timeout=50
    image=/boot/vmlinuz
    label=linux
    root=/dev/hda2
    read-only
    RamDisk_size=10000

  当编译RamDisk支持为模块形式,可以在加载时决定RamDisk的大小,可以通过杂/etc/conf.module中添:

    optionsrdrd_size=10000
 
  或者在动态加载是通过命令行的形式传入:

    insmodrdrd_size=10000

  下面是关于如何使用模块的一个例子:

  卸载前面加载的文件系统:umount/tmp/RamDisk0。

  卸载模块:rmmodrd。

  加载RamDisk模块,并设置大小为20M:insmodrdrd_size=20000。

  创建一个文件系统:mke2fs/dev/ram0

  加载RamDisk的文件系统:mount/dev/ram0/tmp/RamDisk0。
  
  在web服务器中使用RamDisk的例子:

  这里举一个在web服务器中使用三个RamDisk的例子,这里要确保web服务器的所有内容不超过9M(包括CGI的内容)。

  首先,对web服务器的root目录下的内容备份到其他地方,然后重新创建www的根目录:

    mv/home/httpd//home/httpd_real
    mkdir/home/httpd
    mkdir/home/httpd/cgi-bin
    mkdir/home/httpd/html
    mkdir/home/httpd/icons

  然后,在/etc/rc.d/init.d/httpd.init中添加如下启动执行信息:

    ###MaketheRamDiskpartitions
    /sbin/mkfs-text2/dev/ram0
    /sbin/mkfs-text2/dev/ram1
    /sbin/mkfs-text2/dev/ram2
  
    ###MounttheRamDiskstotheirappropriateplaces
  
    mount/dev/ram0/home/httpd/cgi-bin
    mount/dev/ram1/home/httpd/icons
    mount/dev/ram2/home/httpd/html
  
    ###CopyingrealdirectorytoRamDisks(the
    ###dataontheRamDisksislostafterareboot)
    tar-C/home/httpd_real-c.|tar-C/home/httpd-x
  
    ###Afterthisyoucanstarttheweb-server.

  注:切记若RamDisk中的数据被修改,并且做的修改都是有意义的,则需要对RamDisk中的数据做备份。

  你可以启动一个cron任务来完成这个工作,如:每10分钟检查一次看是否有数据被修改,若有则对数据进行备份。

  RamDisk的一个应用是使用/tmp做为RamDisk,若系统中有很多程序使用RamDisk,则可以很明显地加快系统速度,而且每次系统重新启动这些暂时数据都会丢失。

  通过RamDisk加速小型数据库的访问速度

  如果将将PostgreSQL数据库服务器文件加载到内存中就可以加快数据库访问速度。在/test目录下加载RamDisk。

  一、在/test目录下设置RamDisk

    mkdir-p/Test
    mkfs-text2/dev/ram0
    mount/dev/ram0/Test

  这时候你将拥有一个4M大小的RamDisk,根据需要你可以更改你的RamDisk的大小。

  二、为PostgreSQL设置RamDisk

  理想状态下,你将拥有两个数据库服务器。一个是可以进行修改的,另外一个是存放在RamDisk中的拷贝。为了达到这个目的,需要使用命令:"pg_dump"或"pg_dumpall"。

  注:这里假设已经在lilo.conf中设置RamDisk的大小,使其大于数据库服务器的大小。如果你希望了解合适的大小,可以使用命令"cd/var/lib/pgsql;du"。然后:

    ###Stopthecurrentpostgresqlserver
    /etc/rc.d/init.d/postgresstop
    ###renamethecurrentdirectory
    mv/var/lib/pgsql/var/lib/pgsql_main
    ####CreateadirectorytohaveourRamDiskon
    mkdir-p/var/lib/pgsql_memory
    ####changetheownershipofthenewdirectorytopostgresorwhatever
    ####theactualowneris.
    chownpostgres/var/lib/pgsql_memory
    ####Makeanaliasorlinktotheoriginalname,/var/lib/pgsql
    ln-s/var/lib/pgsql_memory/var/lib/pgsql
  
    ####FormattheRamDisk
    mkfs-text2/dev/ram0
    ####MounttheRamDisktothepostgresqldirectory
    mount/dev/ram0/var/lib/pgsql_memory
  
    ####CopyeverythingfromthemaindirectoryintotheRamDisk
    tar-C/var/lib/pgsql_main-cp.|tar-C/var/lib/pgsql_memory-xp
    ###Startthecurrentpostgresqlserver
    /etc/rc.d/init.d/postgresstart

  经过测试,发现在RamDisk中的PostgreSQL的性能提升最高达到50%左右。需要的时候,可以将其他的应用放置在RamDisk中以提升效率,如LDAP服务器等。


来源:ChinaITLab
分享到:
评论

相关推荐

    通过RamDisk加速小型数据库访问速度

    什么是RamDisk?一个RamDisk是分配作为一个分区的内存块,或者说将内存模拟为...本文首先介绍了如何在RedHat6.0系统上创建一个RamDisk,然后介绍了如何通过将数据库内容存放到RamDisk中的方法来加速对数据库的访问。

    如何提高Linux上小型数据库的速度

    对于linux操作系统,当一个文件被读取时,它将被保存在内存中直到内存空间被其 他程序要求使用。... 在数据库上使用ramdisk的好处就是可以得到高速度,简单而明快。对于那些只读的数据库来说,这可是一个非常棒的主意。

    比ramdisk提速还快的软件FancyCache

    比ramdisk提速还快的软件FancyCache超级好用。

    Primo Ramdisk Ultimate Edition5.6 完美多语言版

    Primo Ramdisk Ultimate Edition5.6 完美多语言版 win7 32位和64位都能用 ...由于物理内存的访问速度远远超过传统硬盘,因此可以极大的提高数据读写速度,从而突破硬盘瓶颈,飞速提升计算机性能。

    ramdisk

    你可以把整个应用程序都安装在RamDisk的驱动器中,然后用内存的速度运行它。使用RAM驱动器技术对于延长笔记本电脑电池使用时间也是十分有利的,因为这样做可以减少访问“耗电大户”——硬盘的次数。  近几年来,...

    Primo Ramdisk Ultimate Edition 5.5.0 真正破解版

    由于物理内存的访问速度远远超过传统硬盘,因此可以极大的提高数据读写速度,从而突破硬盘瓶颈,飞速提升计算机性能。 Primo Ramdisk 具有一系列强大的功能和选项以使性能最大化,并使软件具有广泛的应用性。Primo ...

    Primo Ramdisk RAMDISK

    Primo Ramdisk RAMDISK 服务器破解版

    primo ramdisk5.1 crack

    由于物理内存的访问速度远远超过传统硬盘,因此可以极大的提高数据读写速度,从而突破硬盘瓶颈,飞速提升计算机性能。 Primo Ramdisk 具有一系列强大的功能和选项以使性能最大化,并使软件具有广泛的应用性。Primo ...

    Dataram_RAMDisk

    Dataram RAMDisk目前是同类软件中速度最高的一个,而且是免费软件,缺点是功能还比较少,不过通过下边的设置后,基本就可以达到平时使用所需了。免费版最大支持创建4GB Ramdisk.运行期间可能会展示广告条。

    Radeon RAMDisk 4.4.0 RC36

    AMD出品的Ramdisk工具. 功能: 可将内存映射到磁盘驱动器中,访问速度相较传统硬盘(HDD,SSD)均有较大提升. 普通版本限制最大4GB,对于普通用户放一些cache已足够. 经硬盘测速,顺序读写可达5G+/s

    ramdisk-免费的ramdisk软件

    免费的ramdisk软件

    Primo Ramdisk Pro(内存虚拟硬盘软件)5.3.0简体中文版+注册机

    Primo Ramdisk 是 VSuite Ramdisk 的第二代产品。相比 VSuite Ramdisk,它实现了更多的功能,更...由于物理内存的访问速度远远超过传统硬盘,因此可以极大的提高数据读写速度,从而突破硬盘瓶颈,飞速提升计算机性能。

    VSuite Ramdisk

    VSuite Ramdisk是Romex Software开发的一款可以利用内存虚拟一个完全等效的物理硬盘。可以极大的提高读写文件的速度,并减少实际硬盘的访问,从而延长硬盘寿命。它还可以识别操作系统识别不到的内存,通过虚拟成硬盘...

    Primo Ramdisk 旗舰版 5.6

    由于物理内存的访问速度远远超过传统硬盘,因此可以极大的提高数据读写速度,从而突破硬盘瓶颈,飞速提升计算机性能。 Primo Ramdisk 具有一系列强大的功能和选项以使性能最大化,并使软件具有广泛的应用性。Primo ...

    Primo Ramdisk Server Edition(系统加速精灵)v5.6.0注册破解版

    Primo Ramdisk Server Edition(系统加速精灵)v5.6.0注册破解版智秀《少年中国强》中当上了护航大师。不仅与小选手现场互动,还

    Primo.Ramdisk.Srv.Mui.Setup.5.6.0

    Primo Ramdisk(VSuite Ramdisk II) 内存虚拟硬盘软件 使用内存模拟出超快速的硬盘,突破...由于物理内存的访问速度远远超过物理硬盘,因此虚拟硬盘具有非常高的数据读写速度,从而突破系统IO瓶颈,飞速提升计算机性能。

    VSuite Ramdisk Pro V4.6.7

    它采用独特的软件算法,高效率地将内存虚拟成物理硬盘,使得对硬盘文件的数据读写转化为对内存的数据访问,极大的提高数据访问速度,从而突破硬盘瓶颈,飞速提升计算机性能。另一方面它大大减少了对物理硬盘的访问...

    ramdisk5 by gavotte

    一般,修改设置不需要重新启动,但是,如果有其他应用程序正在访问ramdisk,会要求reboot,这时最好关闭访问ramdisk的程序,值得注意的 是ie的缓存,如果被设置到ramdisk,就会要求reboot,因为 IE缓存在登陆后就被...

    VSuite.Ramdisk

    它采用独特的软件算法,高效率地将内存虚拟成物理硬盘,使得对硬盘文件的数据读写转化为对内存的数据访问,极大的提高数据访问速度,从而突破硬盘瓶颈,飞速提升计算机性能。另一方面它大大减少了对物理硬盘的访问...

    Ramdisk 1.1.rar|Ramdisk 1.1.rar

    Ramdisk 1.1.rar

Global site tag (gtag.js) - Google Analytics