您的位置:首页 > 数据库 > Redis

玩玩Linux云主机-安装redis,redis学习,Ubuntu 安装redis 配置文件路径

2016-12-07 18:48 633 查看
redis开源免费的高性能的key-value数据库 http://www.redis.net.cn/tutorial/3502.html (redis中文网)

Redis 与其他 key - value 缓存产品有以下三个特点:

Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用。

Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。

Redis支持数据的备份,即master-slave模式的数据备份。(主从数据库,集群的时候使用)

Redis 优势

性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。

丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。

原子 – Redis的所有操作都是原子性的,同时Redis还支持对几个操作全部完成后的原子性执行。

丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。

Redis与其他key-value存储有什么不同?

Redis有着更为复杂的数据结构并且提供对他们的原子性操作,这是一个不同于其他数据库的进化路径。Redis的数据类型都是基于基本数据结构的同时对程序员透明,无需进行额外的抽象。

Redis运行在内存中但是可以持久化到磁盘,所以在对不同数据集进行高速读写时需要权衡内存,应为数据量不能大于硬件内存。在内存数据库方面的另一个优点是, 相比在磁盘上相同的复杂的数据结构,在内存中操作起来非常简单,这样Redis可以做很多内部复杂性很强的事情。 同时,在磁盘格式方面他们是紧凑的以追加的方式产生的,因为他们并不需要进行随机访问。

笔者的服务器是Ubuntu14.04 所以安装非常的简单

apt-get install redis-server




5. 启动redis服务器

redis-server
no config file specified, using the default config.
In order to specify a config file use redis-server /path/to/redis.conf
WARNING overcommit_memory is set to 0! Background save may fail under low memory condition. To fix this issue add 'vm.overcommit_memory = 1' to /etc/sysctl.conf and then reboot or run the command 'sysctl vm.overcommit_memory=1' for this to take effect.
The server is now ready to accept connections on port 6379




这里没有设置配置文件跟在后面,使用的是默认的配置

6. 打开终端,简单的使用一下子,操作数据库信息

redis-cli




7. 查看一下运行的情况



8.刚刚安装完了之后笔者退出之后,发现再次登录的时候,redis还是开启的,证明啊,在自动启动的服务里面,以及配置文件在哪里的?

配置文件的路径一般都是在/etc目录下面的

配置文件的路径: /etc/redis/redis.conf
redis服务路径: /etc/init.d/redis-server
这个服务的路径之前在mysql安装的时候遇到了吧!


看看截图



这个下图就是可以很清楚的知道了当前的环境下的一些服务!具体我也不是太清楚。



9. 启动服务之后呢,我们可以操作数据之外,还可以设置配置,除了直接的处理/etc/redis/redis.conf之外呢,我们还可以直接在命令行下进行操作,下面就跟着教程演示一下子。

CONFIG 命令查看或设置配置项。
CONFIG get * 所有的
CONFIG get XXX
CONFIG set XXX YYY (设置XXX = YYY)


笔者就是用 get *



1) "dbfilename" //指定本地数据库文件名,默认值为dump.rdb
2) "dump.rdb"
3) "requirepass"
//设置Redis连接密码,如果配置了连接密码,客户端在连接Redis时需要通过AUTH <password>命令提供密码,默认关闭
//在登录的时候的时候输入密码:
// redis-cli -p 6379 -a 密码(a =auth)
4) ""
5) "masterauth"
// 当master服务设置了密码保护时,slav服务连接master的密码 这个就是权限验证
6) ""
7) "unixsocket"
8) ""
9) "logfile"
//日志记录方式,默认为标准输出,如果配置Redis为守护进程方式运行,而这里又配置为日志记录方式为标准输出
10) "/var/log/redis/redis-server.log"
11) "pidfile"
12) "/var/run/redis/redis-server.pid"
13) "maxmemory"
// 指定Redis最大内存限制,Redis在启动时会把数据加载到内存中,
//达到最大内存后,Redis会先尝试清除已到期或即将到期的Key,当此方法处理 后,
//仍然到达最大内存设置,将无法再进行写入操作,但仍然可以进行读取操作。
//Redis新的vm机制,会把Key存放内存,Value会存放在swap区
14) "0"
15) "maxmemory-samples"
16) "3"
17) "timeout"
//当 客户端闲置多长时间后关闭连接,如果指定为0,表示关闭该功能
18) "0"
19) "tcp-keepalive"
20) "0"
21) "auto-aof-rewrite-percentage"
22) "100"
23) "auto-aof-rewrite-min-size"
24) "67108864"
25) "hash-max-ziplist-entries"
26) "512"
27) "hash-max-ziplist-value"
28) "64"
29) "list-max-ziplist-entries"
30) "512"
31) "list-max-ziplist-value"
32) "64"
33) "set-max-intset-entries"
34) "512"
35) "zset-max-ziplist-entries"
36) "128"
37) "zset-max-ziplist-value"
38) "64"
39) "lua-time-limit"
40) "5000"
41) "slowlog-log-slower-than"
42) "10000"
43) "slowlog-max-len"
44) "128"
45) "port" //端口号
46) "6379"
47) "databases" //设置数据库的数量,默认数据库为0
48) "16"
49) "repl-ping-slave-period"
50) "10"
51) "repl-timeout"
52) "60"
53) "repl-backlog-size"
54) "1048576"
55) "repl-backlog-ttl"
56) "3600"
57) "maxclients"
//设置同一时间最大客户端连接数,默认无限制,Redis可以同时打开的客户端连接数为
//Redis进程可以打开的最大文件描述符数,如果设 置 maxclients 0,表示不作限制。
//当客户端连接数到达限制时,
//Redis会关闭新的连接并向客户端返回max number of clients reached错误信息
58) "3984"
59) "watchdog-period"
60) "0"
61) "slave-priority"
62) "100"
63) "min-slaves-to-write"
64) "0"
65) "min-slaves-max-lag"
66) "10"
67) "hz"
68) "10"
69) "no-appendfsync-on-rewrite"
70) "no"
71) "slave-serve-stale-data"
72) "yes"
73) "slave-read-only"
74) "yes"
75) "stop-writes-on-bgsave-error"
76) "yes"
77) "daemonize" //以守护进程的方式运行
78) "yes"
79) "rdbcompression"
//指定存储至本地数据库时是否压缩数据,默认为yes,Redis采用LZF压缩,
//如果为了节省CPU时间,可以关闭该选项,但会导致数据库文件变的巨大
80) "yes"
81) "rdbchecksum"
82) "yes"

83) "activerehashing"
// 指定是否激活重置哈希,默认为开启
84) "yes"

85) "repl-disable-tcp-nodelay"
86) "no"
87) "aof-rewrite-incremental-fsync"
88) "yes"
89) "appendonly"
//. 指定是否在每次更新操作后进行日志记录,Redis在默认情况下是异步的把数据写入磁盘,
//如果不开启,可能会在断电时导致一段时间内//的数据丢失。
//因为 redis本身同步数据文件是按上面save条件来同步的,所以有的数据会在一段时间内只存在于内存中。默认为no
// 这个和save 保存同步有关系
90) "no"
91) "dir" //指定本地数据库存放目录
92) "/var/lib/redis"

93) "maxmemory-policy"
94) "volatile-lru"

95) "appendfsync"
//之前的那个是否记录日志,这里表示记录日志的类型
// 指定更新日志条件,共有3个可选值:
//no:表示等操作系统进行数据缓存同步到磁盘(快)
//always:表示每次更新操作后手动调用fsync()将数据写到磁盘(慢,安全)
//everysec:表示每秒同步一次(折衷,默认值)
96) "everysec"

97) "save"
//指定在多长时间内,有多少次更新操作,就将数据同步到数据文件,可以多个条件配合 (让数据一致性,内存的数据和磁盘的数据)
98) "900 1 300 10 60 10000"
// 分别表示900秒(15分钟)内有1个更改,300秒(5分钟)内有10个更改以及60秒内有10000个更改。

99) "loglevel"
//日志记录级别,Redis总共支持四个级别:debug、verbose、notice、warning
100) "notice"

101) "client-output-buffer-limit"
102) "normal 0 0 0 slave 268435456 67108864 60 pubsub 33554432 8388608 60"
103) "unixsocketperm"
104) "0"

105) "slaveof"
//slave 奴隶主要指从数据库 主从数据库就是集群环境中使用的
//设置当本机为slav服务时,设置master服务的IP地址及端口,在Redis启动时,它会自动从master进行数据同步
106) ""
107) "notify-keyspace-events"
108) ""
109) "bind" //绑定的主机的ip
110) "127.0.0.1"
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: