一、NOSQL之SSDB的安装和启动和应用示例
1. 关于SSDB数据库
ssdb是一个类似于redis的nosql数据库,但有一个很大的区别,redis是基于内存服务,服务器内存比较昂贵,而ssdb则是基于硬盘存储的,很容易扩展,并且成本要小得多,所以对于一些对速度要求不太高的应用,完全可以使用SSDB,下面这张图就显示了SSDB与REDIS的性能对比。
ssdb在删除数据的时候并不会立刻释放磁盘的空间,ssdb会在合适的时候去释放,如果想立即释放,可以使用命令compact,不过在使用的时候会造成ssdb卡慢,并且compact命令的执行速度不快。所以可以做一个定时任务在每天凌晨释放空间。
2. SSDB的安装
下面是我的安装命令,安装版本1.8.2
cd /opt/modules/download
sudo wget https://github.com/ideawu/ssdb/archive/1.8.2.tar.gz
sudo tar zxvf 1.8.2.tar.gz
cd ssdb-1.8.2
sudo mkdir /opt/modules/ssdb
sudo make install PREFIX=/opt/modules/ssdb
3. SSDB的启动和关闭
SSDB的启动和关闭和重启,SSDB默认端口是8888,这个端口一般可能都被占用了,习惯使用6399来作为SSDB的启用端口,记得更改conf的配置。
#启动ssdb
[onlinedev@BFG-OSER-4472 ssdb]$ sudo /opt/modules/ssdb/ssdb-server -d /opt/modules/ssdb/ssdb.conf
ssdb 1.8.2
Copyright (c) 2012-2014 ssdb.io
[onlinedev@BFG-OSER-4472 ssdb]$ sudo netstat -anp | grep 6399
tcp 0 0 127.0.0.1:6399 0.0.0.0:* LISTEN 24382/ssdb-server
#停止ssdb
[onlinedev@BFG-OSER-4472 ssdb]$ sudo /opt/modules/ssdb/ssdb-server -d /opt/modules/ssdb/ssdb.conf -s stop
#重启ssdb
[onlinedev@BFG-OSER-4472 ssdb]$ sudo /opt/modules/ssdb/ssdb-server -d /opt/modules/ssdb/ssdb.conf -s restart
#连接ssdb
[onlinedev@BFG-OSER-4472 ssdb]$ sudo /opt/modules/ssdb/ssdb-cli -h 127.0.0.1 -p 6399
ssdb 127.0.0.1:6399> info
version
1.8.2
links
1
total_calls
3
dbsize
0
binlogs
capacity : 10000000
min_seq : 0
max_seq : 0
key_range.kv
"" - ""
key_range.hash
"" - ""
key_range.zset
"" - ""
key_range.list
"" - ""
leveldb.stats
Compactions
Level Files Size(MB) Time(sec) Read(MB) Write(MB)
--------------------------------------------------
21 result(s) (0.000 sec)
4. SSDB的应用示例
SSDB数据库操作:ssdb中的数据类型分为4中,s字符串类型、q列表类型、h哈希类型、z有序集合类型。在redis中,使用keys命令可以查看当前数据库中的所有键,但ssdb中却没有这样功能的命令,在ssdb中查看存在的键是分类型用不同的命令的:
keys 字符串类型
qlist 列表类型
hlist 哈希类型
zlist 有序集合类型
这四个命令的参数和用法都一样,示例如下:
ssdb 127.0.0.1:6399> set yes hello
ok
(0.000 sec)
ssdb 127.0.0.1:6399> keys
client_error: wrong number of arguments
(0.000 sec)
ssdb 127.0.0.1:6399> keys "" "" 10
key
-----------------
yes
1 result(s) (0.000 sec)
ssdb 127.0.0.1:6399> set language go
ok
(0.000 sec)
ssdb 127.0.0.1:6399> keys "" "" 10
key
-----------------
language
yes
2 result(s) (0.000 sec)
ssdb 127.0.0.1:6399> keys "h" "m" 10
key
-----------------
language
1 result(s) (0.000 sec)
参数解释:前两个参数用于确定键的范围,a、z 即筛选键名首字母在a-z之间的键,若为''、'' 则不限制范围,最后一个参数用来限制返回的键的最大个数,为必需参数。
二、SSDB安装时遇到的问题:
1. 问题cannot stat `ssdb-server': No such file or directory
在安装的时候可能会遇到报错:cannot stat `ssdb-server': No such file or directory
[onliv@B4471 ssdb-1.8.2]$ sudo make install PREFIX=/opt/modules/ssdb
cp ssdb-server ssdb.conf ssdb_slave.conf /opt/modules/ssdb
cp: cannot stat `ssdb-server': No such file or directory
make: *** [install] Error 1
这个问题在上一篇文章里也没有讲明白,报错的内容是找不到ssdb-server这个文件,无法完成copy。实际这个错误的原因是如果要安装在其它的目录下,不要漏掉make这一个步骤,直接执行make install PREFIX=就会出现错误 :cp ssdb-server ssdb.conf ssdb_slave.conf /opt/modules/ssdb. 如果进行默认安装,直接sudo make install就没有问题的。
2. 安装ssdb时报错:cp: cannot stat ssdb-server: No such file or directory
今天在安装ssdb时总是报错:
mkdir -p /opt/modules/ssdb
mkdir -p /opt/modules/ssdb/_cpy_
mkdir -p /opt/modules/ssdb/deps
mkdir -p /opt/modules/ssdb/var
mkdir -p /opt/modules/ssdb/var_slave
cp ssdb-server ssdb.conf ssdb_slave.conf /opt/modules/ssdb
cp: cannot stat `ssdb-server': No such file or directory
make: *** [install] Error 1
且我把ssdb的三个版本,1.8以及1.9的两个都进行了尝试,全都是报这个错误。网上说是因为 Snappy 或者 Jemalloc 没有编译成功,进入这两个目录deps/snappy-1.1.0;deps/jemalloc-3.3.1;进行./configure和make。但也没有成功。然后我又使用yum install ssdb进行尝试未发现有安装包。一直无解。最后我尝试不指定目录安装,直接安装在其默认目录。将这句:
sudo make install PREFIX=/opt/modules/ssdb
直接替换使用
sudo make install
成功了。不知道指定了安装目录后到底出了什么问题。