相关文章

更多

最近更新

更多

SSDB 常见问题解决方案

2019-05-03 22:07|来源: 网路

问: 这里没有我想问的问题和答案, 我应该怎么办?

答: 我推荐所有人通过学习文档和使用自己大脑思考来回答自己的问题.

如果你经过学习文档, 并且进行充分思考后, 仍然无法得到答案, 你可以到 Github 上提 issue.

注意, 作为一个技术产品的用户, 一个互联网工作者, 甚至是一个程序员, 你应该学会基本的提问技能. 如果你的提问没有得到回答, 那么责任不在被问者, 而在于你自己, 你自己没有像个正常的技术人那样正确地提问.


问: 为什么我在本机可以访问 SSDB 服务器, 在其它机器却不能呢? 提示 Connection refused.

答: 默认的配置文件基于安全考虑, 只开放给本机访问. 如果你想开放给网络上的其它 IP 访问, 请按文档修改配置.


问: 为什么并发数上不去? 服务器报错 Too many open files, 客户端报错 Connection reset by peer.

答: 请参考文档 进行配置.


问: 我把一个, 两个, 或者所有的 key 都删除了, 为什么 SSDB 占用的内存和磁盘空间并没有释放?

答: SSDB 有自己策略来决定何时释放或者是否释放内存和硬盘占用, 你不能要求 SSDB 立即或者在未来某个时间, 或者基于某个条件 释放这些空间. 而且, 即使数据库清空了, SSDB 仍然会保留一些信息, 因此仍然占用部分硬盘空间. 你不应该关心这个问题.


问: 为什么 SSDB 偶尔会使用 100% CPU?

答: SSDB 偶尔使用 100% CPU 是完全正常的, 请不要大惊小怪. 这是因为 SSDB/LevelDB 在进行数据库整理(Compaction)操作, 持续的时间一般随着数据变大而变长, 一般只持续数秒.


问: 为什么 SSDB 偶尔会使用较多磁盘 IO?

答: SSDB 偶尔使用较多磁盘 IO 是完全正常的, 请不要大惊小怪. 这是因为 SSDB/LevelDB 在进行数据库整理(Compaction)操作, 持续的时间一般随着数据变大而变长, 一般只持续数秒.


问: 为什么 SSDB 偶尔会使用较多内存空间, 然后又降下来?

答: SSDB 使用的内存空间是变动的, 可能忽高忽低. 使用的内存空间的上限在文档 中有描述.


问: Compaction 时服务会有稍微变慢, 我能设定 Compaction 执行的时间吗?

答: 很遗憾, 你不能设定 Compaction 在何时执行, SSDB/LevelDB 有自己策略和机制, 决定何时应该进行 Compaction. 根据大多数用户的使用反馈, Compaction 对服务没有任何影响.


问: 我原来的配置文件中没有打开压缩选项(compression: no), 我能中途把 compression 改为 yes 吗?

答: 是的, 你可以在任何时候修改 compression 选项, 只要你重启 ssdb-server, 新的修改就能生效. 更改后, 原来的数据依然兼容, 不会有任何问题.


问: 我开启了压缩选项, 但 SSDB 的硬盘占用并没有变小, 这是怎么回事?

答: 无论你开启或者关闭压缩选项, 只要重启后, 新的选项就已经生效了. 但是, 新的选项不一定立即影响原来的旧数据, SSDB 会在合适的时候将新选项应用于旧数据, 你无法控制这一点.


问: 有命令可以知道 SSDB 中存储的 key 总数吗?

答: 如果你想统计的是 KV 的数量, 那么, 在一开始时, 你就要把所有 KV 都放在同一个 HASH 中, 然后通过 hsize 命令就可以得到 key 的数量了. 如果一开始你没有这么做, 或者你想统计 KV 以外的数量, 那么答案很简单 - 没有这样的单个命令(除非你自己写脚本遍历统计).


问: SSDB 支持 key 查找吗? 支持通配符 模糊查找吗?

答: SSDB 支持, 且支持前缀查找, 也就是类似a这样的查找, 而不支持 aa 或者其它的模糊查找. 具体用法请参见命令:scanhlistkeyshkeyshscanzlistzkeyszscanqlist 的文档.

注意, 这些命令都要求你省略  号!


问: SSDB 不支持 sets 集合吗? Redis 的 sadd, sdiff 等求交集, 并集命令我都用不了了?

答: SSDB 不支持 sets, 以后也不太可能支持, 因为有替代方案. 你可以用 hash 来替代 sets, 因为一个 hash 的 key 是唯一的, 可以实现集合的特性. 至于交集, 并集等操作, 你只能自己实现. 例如, 求交集, 你可以遍历第一个 hash 的 key, 然后和第二个 hash 对比, 把结果存入第三个 hash.


问: 我用 Twemproxy 配置 SSDB 做负载均衡和集群, 但是当我用 ssdb-cli 连接 Twemproxy 时, 会报错, 为什么?

答: 因为 Twemproxy 不支持 SSDB 网络协议, 所以, 你只能使用 redis-cli 连接 Twemproxy. 注意, 你可以用 ssdb-cli 或者 redis-cli 连接 SSDB, 那是因为 SSDB 支持两种协议, 而 Twemproxy 只支持一种.


问: 如何在一台机器上部署多个 SSDB 实例?

答: 每一个实例使用不同的配置文件进行启动, 而且, 配置文件里的 work_dir server.port 不能相同, 也就是每个实例的数据库存储路径, 以及监听端口. 如果 pidfile logger.output 使用的是绝对路径, 也要保证不能相同, 如果是相对路径, 由不需要, 因为默认跟随 work_dir 而不同了.


相关问答

更多
  • 问一下电脑公司的人啊!!!!!!!!!!!!或把机器还原~~~~~~~~~~~
  • 呵呵。这个问题不能在问问上面做系统的讲解,说出来话可就长了,如果楼主真想问个所以然的话还不如自己去上电脑补习班之类的。平时有急事儿还是可以到这上面来集思广益的。 还有一句话叫做:“外事不决问谷歌,内事不决问百度,房事不决问天涯”呵呵
  • 第一次把自己编译的驱动模块加载进开发板,就出现问题,还好没花费多长时间,下面列举出现的问题及解决方案 1:出现insmod: error inserting 'hello.ko': -1 Invalid module format 法一(网上的):是因为内核模块生成的环境与运行的环境不一致,用linux-2.6.27内核源代码生成的模块,可能就不能在linux-2.6.32.2内核的linux环境下加载,需要在linux-2.6.27内核的linux环境下加载。 a.执行 uname -r //查看内核版本 ...
  • 在centos 7上使用python3.5, 系统本身带有python2.7, 自己没有将默认的python从2.7链接为3.5。 然后安装python3使用的包: ssdb, 安装方式 pip3 install ssdb,或者 直接下载包源文件,进入文件内,安装 python3 setup.py install 。
  • 优点:SSDB 对内存的需求小,是个较便宜的方案。 不差钱的话,Redis 在性能、稳定性和社区上都更加优秀 缺点:SSDB 实现很低效,主要是依赖 leveldb 会按 key 来排序的特性 Redis 测试时数据量小,只读写了内存的可能性
  • 没有这个单词,根据您的拼写来看,考虑应是:stab. stab 英[stæb] 美[stæb] vt. 刺; 刺; 将…刺入; 对…做出刺或戳的动作; vi. 刺伤; 戳; 用或似用带尖的武器刺; n. 尝试; 用或似用带尖武器刺的伤口; 突发的一阵; [例句]Somebody stabbed him in the stomach 有人朝他肚子上捅了一刀。 [其他] 第三人称单数:stabs 复数:stabs 现在分词:stabbing过去式:stabbed 过去分词:stabbed
  • 额,说一下个人意见:mongodb,一般用来存储比较大的数据,一般都是实时的,缓存成html没多大意义 memacahe 确实是缓存到内存的,但是不是一直在内存中,会通过机制存储到磁盘中,生成一个文档,可是设置隔多少时间存储一次
  • return (Long) getHibernateTemplate().save(); 上面那个是Spring集成的hibernate。。。 如果是纯hibernate的话就是session.save(pojo)....返回的是一个Serializable的对象,可强转成Long或者Integer等封装类,需手动转换成基本类型如int,long等
  • 可以使用一些/etc/security/console.apps/目录下为用户配置的程序. 这个目录中包括允许控制台用户使用/sbin和/usr/sbin中的某些应用程序的配置文件. 这些配置文件和它们所设置的应用程序享有相同名称. 控制台用户可以使用的一组重要应用程序程序包括三个可以用来关闭或重新启动系统的程序: /sbin/halt /sbin/reboot /sbin/poweroff 因为这些都是支持PAM的应用程序,因此需要时都可以调用pam_console.so 模块.
  • 那么,为什么不添加这个标题呢? 只需一行代码:) 您可以运行自己的服务器,将请求转发给该服务(nginx可以轻松地执行此操作, 请查看 )。 简而言之: frontend app -> your proxy with CORS headers (like nginx) -> api service So, why just not add this header? Just one line of code :) You may run your own server which will forward ...