CentOS:Redis安装

安装 tcl

先装好 tcl,不然 redis 的 make test 不会通过。也可以先安装 redis 再回过头来装 tcl

1、下载 tcl 安装包

访问 Tcl - Browse /Tcl at SourceForge.net,选择你想要的版本进行下载

2、安装

tar xvzf tcl8.6.1-src.tar.gz
cd tcl8.6.1/unix/
./configure
make
make test
http://download.redis.io/releases/redis-2.8.10.tar.gz     
Tcl - Browse /Tcl/8.6.1 at SourceForge.net
​
# 关闭 
/usr/local/redis/redis-cli -h 127.0.0.1 -p 6379 shutdown

1、安装Redis

cd /home/defonds/redis
tar xvzf redis-2.8.10.tar.gz
cd redis-2.8.10
make
mkdir /usr/local/redis
make PREFIX=/usr/local/redis install
mkdir /usr/local/redis/etc
mkdir /usr/local/redis/var/
cp redis.conf /usr/local/redis/etc/6379.conf

如果在执行 make 的时候遇到以下错误(比如作者的 32 位的 CentOS5.5 就碰到了):

zmalloc.o: In function `zmalloc_used_memory':

/home/defonds/redis/redis-2.8.10/src/zmalloc.c:223: undefined reference to `__sync_add_and_fetch_4'

collect2: ld returned 1 exit status

make[1]: *** [redis-server] Error 1

make[1]: Leaving directory `/home/defonds/redis/redis-2.8.10/src'

make: *** [all] Error 2

在执行 make 时加上参数 CFLAGS="-march=i686" 就可以了:

make CFLAGS="-march=i686"

 2、配置 Redis

 对默认 /usr/local/redis/etc/6379.conf 进行稍微调整。注意这个配置禁用了自动保存功能,SAVE 和 BGSAVE 带来的 I/0 和内存消耗是不容忽视的,我们让应用或者用户自行提交保存。

daemonize yes  
pidfile /usr/local/redis/var/6379.pid  
logfile /usr/local/redis/var/6379.log  
databases 2  
dbfilename 6379.rdb  
dir /usr/local/redis/var  
appendfsync no  
  • daemonize:是否以后台daemon方式运行

  • pidfile:pid文件位置

  • port:监听的端口号

  • timeout:请求超时时间

  • loglevel:log信息级别

  • logfile:log文件位置

  • databases:开启数据库的数量

  • save * *:保存快照的频率,第一个*表示多长时间,第三个*表示执行多少次写操作。在一定时间内执行一定数量的写操作时,自动保存快照。可设置多个条件。

  • rdbcompression:是否使用压缩

  • dbfilename:数据快照文件名(只是文件名,不包括目录)

  • dir:数据快照的保存目录(这个是目录)

  • appendonly:是否开启appendonlylog,开启的话每次写操作会记一条log,这会提高数据抗风险能力,但影响效率。

  • appendfsync:appendonlylog如何同步到磁盘(三个选项,分别是每次写都强制调用fsync、每秒启用一次fsync、不调用fsync等待系统自己同步)

下面是一个略做修改后的配置文件内容:

daemonize yes
pidfile /usr/local/redis/var/redis.pid
port 6379
timeout 300
loglevel debug
logfile /usr/local/redis/var/redis.log
databases 16
save 900 1
save 300 10
save 60 10000
rdbcompression yes
dbfilename dump.rdb
dir /usr/local/redis/var/
appendonly no
appendfsync always
glueoutputbuf yes
shareobjects no
shareobjectspoolsize 1024

 3、运行和检测

安装、配置完以后,可以启动 redis 了:

cd /usr/local/redis
nice -n -10 bin/redis-server etc/6379.conf

这时,服务应该运行起来了。我们可以通过这两种方式进行检查:

ps aux | grep redis
bin/redis-cli INFO

第二种方式的打印结果:

# bin/redis-cli INFO

# Server

redis_version:2.8.10

redis_git_sha1:00000000

redis_git_dirty:0

redis_build_id:d911badb15bd35b1

redis_mode:standalone

os:Linux 2.6.18-194.el5 i686

arch_bits:32

multiplexing_api:epoll

gcc_version:4.1.2

process_id:17537

run_id:0258835fab4aa7235c861a7ff812c197b3674003

tcp_port:6379

uptime_in_seconds:33

uptime_in_days:0

hz:10

lru_clock:9976904

config_file:/usr/local/redis/etc/6379.conf

# Clients

connected_clients:1

client_longest_output_list:0

client_biggest_input_buf:0

blocked_clients:0

# Memory

used_memory:629768

used_memory_human:615.01K

used_memory_rss:1617920

used_memory_peak:629768

used_memory_peak_human:615.01K

used_memory_lua:22528

mem_fragmentation_ratio:2.57

mem_allocator:jemalloc-3.2.0

# Persistence

loading:0

rdb_changes_since_last_save:0

rdb_bgsave_in_progress:0

rdb_last_save_time:1402485799

rdb_last_bgsave_status:ok

rdb_last_bgsave_time_sec:-1

rdb_current_bgsave_time_sec:-1

aof_enabled:0

aof_rewrite_in_progress:0

aof_rewrite_scheduled:0

aof_last_rewrite_time_sec:-1

aof_current_rewrite_time_sec:-1

aof_last_bgrewrite_status:ok

aof_last_write_status:ok

# Stats

total_connections_received:1

total_commands_processed:0

instantaneous_ops_per_sec:0

rejected_connections:0

sync_full:0

sync_partial_ok:0

sync_partial_err:0

expired_keys:0

evicted_keys:0

keyspace_hits:0

keyspace_misses:0

pubsub_channels:0

pubsub_patterns:0

latest_fork_usec:0

# Replication

role:master

connected_slaves:0

master_repl_offset:0

repl_backlog_active:0

repl_backlog_size:1048576

repl_backlog_first_byte_offset:0

repl_backlog_histlen:0

# CPU

used_cpu_sys:0.01

used_cpu_user:0.00

used_cpu_sys_children:0.00

used_cpu_user_children:0.00

# Keyspace

最后对 redis 进行检测。redis-benchmark 运行了一套 redis 命令,只需要 GET 和 SET 就足以测试主机硬件和编译器了:

cd /usr/local/redis/bin
./redis-benchmark -t GET,SET

 打印结果:

# ./redis-benchmark -t GET,SET

====== SET ======

  10000 requests completed in 0.66 seconds

  50 parallel clients

  3 bytes payload

  keep alive: 1

30.00% <= 1 milliseconds

61.02% <= 2 milliseconds

92.35% <= 3 milliseconds

99.01% <= 4 milliseconds

99.80% <= 5 milliseconds

100.00% <= 8 milliseconds

15082.96 requests per second

====== GET ======

  10000 requests completed in 0.64 seconds

  50 parallel clients

  3 bytes payload

  keep alive: 1

31.43% <= 1 milliseconds

63.78% <= 2 milliseconds

94.87% <= 3 milliseconds

98.69% <= 4 milliseconds

99.33% <= 5 milliseconds

99.73% <= 7 milliseconds

99.80% <= 8 milliseconds

99.93% <= 9 milliseconds

100.00% <= 9 milliseconds

15552.10 requests per second

  当然,也可以添加 -q 对输出结果进行精简:

./redis-benchmark -q -t GET,SET

   打印结果:

# ./redis-benchmark -q -t GET,SET
SET: 14204.55 requests per second
GET: 14245.01 requests per second
  • 56
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值