应用场景
对于大多数数据库而言,最好的运行方式就是讲所有数据都加载到内存中,之后的查询操作完全基于内存数据来实现,但这在实际的情况下并不多见,多数情况下只有部分数据可以被加载到内存中,在Redis中,有一个重要的概念,那就是key一般不会被交换,如果你的数据库中存在大量key,那么这种场景就不适合使用虚拟内存,如果恰恰相反,你的数据库中只包含少量key,而每一个key所包含的value很大,那么这就非常适合使用虚拟内存了。为了实现较少的key,我们可以将原先的key-value形式变为Hash形式。
配置虚拟内存
在配置文件中添加以下配置项,我们可以让Redis在启动时开启虚拟内存功能。
vm-enabled yes
我们可以为Redis配置最大可用虚拟字节数,当内存中的数据大于这个数,就有部分数据将会被换出。Redis所采用的交换策略是最近最久未使用。
vm-max-memory 1000000
将内存中的数据传送到磁盘上,我们需要使用到交换文件,我们可以对交换文件配置分页,同时我们可以为其指定分页大小。
vm-pages 134217728
vm-page-size 32
通过下面的配置,我们可以设置交换文件在进行IO操作时所能使用的最大线程数,如果这个数为0,则表示以同步的方式执行操作。
vm-max-threads 4