- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在探索将 Aerospike 作为键值数据库,并将数据存储在磁盘上以确保安全。请确认,我理解正确:
->
所有数据将只在磁盘上,“memory-size”仅用于索引(少量使用),所有数据将存储在多个 16GB 文件中(将自动创建) ,最重要的是 - 每个 read
查询都会触发从磁盘读取数据?
->
所有数据都将在磁盘上,部分在内存中,“内存大小”将充当缓存并包含 4GB 最常用的数据,所有数据将存储在多个 16GB 文件中(这将自动创建),最重要的是 - 每个 read
查询都会触发检查内存中的数据,如果丢失 -> 从磁盘读取并添加到内存?哪些数据将存储在内存中 - 最常使用的还是最近创建的?
->
所有数据将仅在内存中,我的数据限制为 4GB,不能再多了?
最佳答案
Aerospike 不会像第一代 NoSQL 数据库那样将数据移入和移出磁盘,这些数据库具有“缓存优先”架构。 Aerospike 的 hybrid memory architecture是这样的 primary index (元数据)总是在内存中。根据命名空间配置,数据完全存储在磁盘或内存中。您为每个命名空间定义存储。如果它在内存中,则所有数据和元数据都完全在内存中。如果命名空间将其数据存储在几个设备(/dev/sdb、/dev/sdc)上,则主索引(元数据)完全在内存中并且数据完全在这些 SSD 上。
(1)是硬盘上的数据,配置正确。如果您使用的是 SSD,您可能希望使用 device
而不是 file
。您的问题中有一点不正确,即 Aerospike 将首先检查 post-write-queue
在阅读。
Aerospike 确实 block writes围绕HDD和SSD的高读/低写性能进行优化。 block 的大小由 write-block-size
决定配置参数(HDD 应为 1MB)。这些记录首先被加载到一个等效大小的流式写入缓冲区中。在缓冲区被刷新到磁盘上的一个 block 后,Aerospike 不会立即删除这个内存中的副本;它仍然是写后队列 (FIFO) 的一部分。默认情况下,其中 256 个 block 在每个设备或每个文件的队列中(您可以将多个 file
行定义为存储设备)。如果您的使用模式是读取紧随写入之后,您将获得内存访问而不是磁盘访问。如果你的cache_read_pct
指标不是个位数,并且您有 DRAM 备用,您可能会受益于提高 post-write-queue
值(每个设备最多 2048 个 block )。
(2) 是内存中的命名空间,持久保存到磁盘。对于 (1) 和 (2),您可以使用 file
(用于基于文件系统的存储)或 device
(用于原始设备)。 (2) 的主索引(元数据)和存储(数据)都在内存中。所有读取和写入都来自内存,并且辅助直写进入持久性设备。
filesize
保留文件系统上持久层的大小(如果您选择使用 file
而不是 device
)。您可以有多个 file
行,每个行的大小将从开始到给定的数字 filesize
。 memory-size
是命名空间使用的最大内存量。这不是预先保留的。 Aerospike 的内存使用量会随着时间的推移而增加和减少,命名空间的最大值为其 memory-size
。
看看What's New in 3.11 ,特别是涉及内存性能改进的部分。调音partition-tree-sprigs
和 partition-tree-locks
可能会提高内存中命名空间的性能。
(3) 是一个纯粹的内存命名空间,通常用作缓存。 4G 限制会影响诸如 stop-writes-pct
之类的事情, high-water-memory-pct
因为它们被定义为该限制的百分比(请参阅 evictions, expirations, stop-writes)。
还有一个 (4) 计数器特例,称为索引数据。见 storage engine configuration recipes .
关于memory-management - Aerospike 硬盘/内存使用情况,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46445104/
I have created a hybrid activation and then setup an ssm agent on my on-premise windows system.我创
我对 python/django 编程很陌生,因为我没有编程背景。我正在在线上课,我只想确切地知道 manage.py 文件的作用。我试过用谷歌搜索它,但除了在 django-admin.py 周围放
我的 DependancyInject 存在结构问题。 情况 我正在为基于体素的游戏创建服务器;它是完全调制的,但相关模块有以下3个。 NetworkModule(发送和接收数据包)WorldModu
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 5年前关闭。 Improve thi
上 Docker正在编写的网站: The MANAGER STATUS column shows node participation in the Raft consensus: No value
我正在尝试使用发布管理作为构建版本的工具,但我很难理解码件、工具和操作之间的真正区别。有人可以分解这三个概念之间的差异以及它们如何相互配合吗? 最佳答案 由于它适用于基于代理的版本: 工具旨在提供自定
当尝试在远程环境中在 pycharm 中执行“run manage.py Task...”时,出现以下错误: ssh://vagrant@127.0.0.1:2222/home/vagrant/.vi
在过去的 48 小时里,我一直在努力解决这个问题,这让我发疯了。 我的 SDK Manager.exe 闪烁一个 cmd 屏幕并在不到一秒内关闭。 经过多方搜索,我终于在调整android.bat并以
我在 this tutorial 之后创建了以下自定义管理命令. from django.core.management.base import BaseCommand, CommandError f
我在一家拥有 2,500 多名员工和同样多的 Android 智能手机的非营利组织工作。 近年来,我们测试了许多 EMM 产品。尽管我们只需要一些非常基本的功能,除了一两个特殊功能,但没有一个能真正赢
我已经在我的网站上安装了 Google 标签管理器,但自从新版本的 Google 标签管理器以来,我无法使用预览选项。每次我点击它时,我都会看到我的网站页面打开,但随后出现以下错误:“Tag Assi
我是 django 的新手,并创建了一个与教程中描述的民意调查网站没有太大区别的应用程序。 在网站上我得到: Exception Type: TemplateSyntaxError Exception
https://cloud.google.com/deployment-manager/docs/configuration/templates/create-basic-template 我可以像这
我们正在使用 Microsoft 的发布管理将我们的 Web 应用程序部署到我们的测试环境 (QA)。它是一个直接的 MVC.Net Web 应用程序。我们的构建生成一个 web 部署包,我们有一个命
我想将 python manage.py 缩短为 ./manage.py。 这可能很简单,但我找不到答案。我在有关 django 的问题的答案之一中看到了一步一步的方法,但我没有记住。尝试在 stac
我想将 python manage.py 缩短为 ./manage.py。 这可能很简单,但我找不到答案。我在有关 django 的问题的答案之一中看到了一步一步的方法,但我没有记住。尝试在 stac
我正在使用安装了 SQL Server Data Tools 的 VS 2012。我有一个 ADO NET 源,它使用 .Net Providers\MySQL 数据提供程序,并试图将一些数据推送到
根据我从文档中阅读的内容 https://developer.android.com/topic/libraries/architecture/workmanager , 它说: The task i
这两个类显然是相关的。 SupportFragmentManager 是否用于使用 FragmentTransaction 生成的 Fragments,而“常规”FragmentManager 专门用
我有一个桌子经理(经理ID、姓名、地址、城市、电话)。如果多个经理来自同一城市,我必须显示城市、姓名和电话详细信息。我的代码是:。但这向我展示了第一行中的一个错误,即“不是按表达式分组”。请救救我!
我是一名优秀的程序员,十分优秀!