ssdb使用笔记
ssdb是一款类似于redis的nosql数据库,不过redis是基于内存的,服务器比较昂贵,ssdb则是基于硬盘存储的,很容易扩展,对于一些对速度要求不是太高的应用,还是不错的选择。
先记录一个比较坑的东西,具体的用法以后补充。
ssdb删除数据的时候有很多中方法:
flushdb 删除整个数据库中的所有数据
qclear 删除列表类型的数据
hclear 删除hash类型的数据
zclear 删除有序集合类型的梳理
del 删除字符串类型的数据
不过,ssdb在删除数据的时候并不会立刻释放磁盘的空间,用作者的话说就是ssdb会在合适的时候去释放,这就会造成不知不觉中ssdb占用的磁盘空间越来越大,还不知道什么时候才会被释放,如果不及时处理的话,服务器卡死是很正常的事情,经过不断的寻找,终于被我发现了一个命令 compact , 这个命令会自动去释放应该被释放的磁盘空间,不过在使用的时候会造成ssdb卡慢,并且 compact 命令的执行速度也不快,但总算是可以立刻释放了,不用再担心服务器被撑爆。
需要注意的是如果服务器已经快被撑爆了,那么你在执行 compact 的时候ssdb是有可能崩溃的,而且执行一次 compact 并不会释放所有应该释放的空间,可能需要多次执行才行。
还有一个比较坑的东西就是在删除数据的时候,会造成服务阻塞,其他任何写命令都执行不了,可读不可写。。。而且删除的超级慢。。。
下面简单介绍一下ssdb的用法。
一、服务器搭建
环境为Mac
首先到 https://github.com/ideawu/ssdb 查看官方文档,下载安装包
wget https://github.com/ideawu/ssdb/archive/master.zip
unzip master.zip
cd ssdb-master
make
make的时候报了个错:ERROR! autoconf required! install autoconf first
于是安装 autoconf
brew install autoconf
安装完成后继续编译
make && make install
没有报错,继续,下面启动ssdb服务,加-d参数为deamon模式 服务后台运行 推荐使用
./ssdb-server -d ./ssdb.conf
或者
./ssdb-server ./ssdb.conf
然后可以使用下面的命令连接到ssdb数据库,进行操作
./tools/ssdb-cli -h localhost -p 8888
使用在命令行客户端中执行info命令结果如下:
关闭数据库
./ssdb-server ./ssdb.conf -s stop
PS: ssdb服务在启动的时候会在 var 目录下生成一个ssdb.pid文件,当ssdb由于意外关闭的时候这个文件不会被删除,因此当重新启动ssdb服务的时候,会报下面的错误:
Fatal error!
Pidfile ./var/ssdb.pid already exists!
Kill the running process before you run this command,
or use '-s restart' option to restart the server.
此时你可以手动删除var/ssdb.pid文件,然后启动ssdb服务,或者在启动ssdb服务的时候使用如下命令
./ssdb-server -d ./ssdb.conf -s restart
-s 参数支持三个选项 stop, start , restart, 默认情况下可不加 -s 参数,此时默认为start选项
!!! PS 当ssdb由于某个特别耗时操作卡死的时候,如果想停止命令的执行,目前我只知道重启这个办法。但是ssdb重启使用 restart 特别慢,所以可以使用kill -9 杀掉进程,然后再启动。。 不知道会有啥不良影响,我试了一次,还没发现问题。
二、数据库操作
ssdb中的数据类型分为4中,字符串类型、列表类型、哈希类型、有序集合类型。
这四种数据类型的操作命令一般都以固定的字母开头:
s 字符串类型
q 列表类型
h 哈希类型
z 有序集合类型
(1)首先,我们最关心的一般是数据库中存在着哪些键,在redis中,使用keys命令可以查看当前数据库中的所有键,但ssdb中却没有这样功能的命令,这可能会让让用惯了redis的同学感觉有点别扭。
在ssdb中查看存在的键是分类型用不同的命令的:
keys 字符串类型
qlist 列表类型
hlist 哈希类型
zlist 有序集合类型
这四个命令的参数和用法都一样,例如
前两个参数用于确定键的范围,a、z 即筛选键名首字母在a-z之间的键,若为''、'' 则不限制范围,最后一个参数用来限制返回的键的最大个数,为必需参数。
可以转载,但请注明出处,做人要厚道一点,谢谢
ssdb使用笔记的更多相关文章
- SSDB 使用笔记
1. SSDB中scan key_start key_end limit ,key_start 和 key_end 是指字母的顺序,不是数字. 2. 进入客户端:./ssdb-cli -p 8888
- SSDB数据库笔记
目录 环境 配置文件 启动服务器 客户端 SSDB:一个高性能的支持丰富数据结构的 NoSQL 数据库, 用于替代 Redis. 参考文献: SSDB官网 环境 win10 下 wsl 环境 ubun ...
- 基于C语言的ssdb笔记 ----hashmap的简单实例
ssdb支持 zset, map/hash, list, kv 数据结构,同redis差不多.下面是关于ssdb hsahmap的使用笔记 1.ssdb hashmap的命令 1.hset name ...
- Golang 学习笔记 目录总结
- 基础: 下载安装 声明变量的方法 数据的三种基础类型:bool,数字,string 数据类型:数组和切片 数据类型:Maps 条件判断以及循环 函数 包管理 package 指针 结构体 - 初步 ...
- git-简单流程(学习笔记)
这是阅读廖雪峰的官方网站的笔记,用于自己以后回看 1.进入项目文件夹 初始化一个Git仓库,使用git init命令. 添加文件到Git仓库,分两步: 第一步,使用命令git add <file ...
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- SQL Server技术内幕笔记合集
SQL Server技术内幕笔记合集 发这一篇文章主要是方便大家找到我的笔记入口,方便大家o(∩_∩)o Microsoft SQL Server 6.5 技术内幕 笔记http://www.cnbl ...
- PHP-自定义模板-学习笔记
1. 开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2. 整体架构图 ...
- PHP-会员登录与注册例子解析-学习笔记
1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...
随机推荐
- 知识驱动对话-Learning to Select Knowledge for Response Generation in Dialog Systems-阅读笔记
今日看了一篇文章<Learning to Select Knowledge for Response Generation in Dialog Systems>,以知识信息.对话目标.对话 ...
- 存储空间消耗磁盘比较 int varchar date
小结: 1.日期类型按照date存储节省空间,仅3字节,而按照字符串型char 8字节 20190316 , varchar 20190316 9字节: 2.对于小于32768的整数,按照smal ...
- 用CMD命令进行关机/重启
用CMD命令进行关机/重启 - WingsBlog https://www.wusiwei.com/post-185.html [实用]CMD关机.重启命令 - Kevin.Chen - 专注前行 - ...
- 2016年蓝桥杯省赛A组c++第5题(计算机组成原理)
/* 下面的代码把一个整数的二进制表示的最右边的连续的1全部变成0 如果最后一位是0,则原数字保持不变. 如果采用代码中的测试数据,应该输出: 0000000000000000000000000110 ...
- 图->存储结构->邻接多重表
文字描述 邻接多重表是无向图的另一种链式存储结构. 虽然邻接表是无向图的一种很有效的存储结构,在邻接表中容易求得顶点和边的各种信息. 但是,在邻接表中每一条边(vi,vj)有两个结点,分别在第i个和第 ...
- 【python基础】hmac
[微语]不应当急于求成,应当去熟悉自己的研究对象,锲而不舍,时间会成全一切.凡事开始最难:然而最难的是何以善终 通过哈希算法,我们可以验证一段数据是否有效,方法就是对比该数据的哈希值,例如,判断用户口 ...
- 如何监控 Java 垃圾回收机制: jps、jstack、jmap、jhat、jstat
一.MinorGC 一个新对象会被放到eden空间,当eden空间满了的时候,MinorGC就会执行,任何存活的对象,都从eden空间复制到to survivor空间,任何在from survivor ...
- Redis所支持的数据结构
1.启动Redis2.Redis所支持的数据结构 2.1.Redis常用操作 2.2.String类型及操作 2.3.Hash类型及操作 2.4.List类型及操作 2.5.Set类型及操作 2.6. ...
- UPDATE 时主键冲突引发的思考【转】
假设有一个表,结构如下: root::> create table t1 ( -> id int unsigned not null auto_increment, ', -> pr ...
- MySQL 5.5 服务器变量详解(二)
innodb_adaptive_flushing={ON|OFF} 设定是否允许MySQL服务器根据工作负载动态调整刷写InnoDB buffer pool中的脏页的速率.动态调整刷写速率的目的在于避 ...