centOS 7安装Redis

1. 安装tcl支持

yum install tcl
注意:能联网;可能需要root 权限,在前面加上sudo 即可。完成后会出现如下:



2. 安装redis我们以最新的4.0.2为例 

可以指定文件下载存储的目录,需要安装好

wget http://download.redis.io/releases/redis-4.0.2.tar.gz
tar xzf redis-4.0.2.tar.gz
cd redis-4.0.2
make
make test
make install


测试通过后安装,安装后会自动把redis-server,redis-cli,redis-benchmark,redis-check-aof,redis-check-dump复制到/usr/local/bin目录下。

3. 编辑redis.conf文件

vim redis.conf

修改以下参数

daemonize  yes    #后台运行

bind  0.0.0.0         #监听所以IP

pidfile  /var/run/redis.pid

logfile  "/usr/redis/bin/redis.log"       #redis.log需要先创建

cp redis.conf /etc

复制redis.conf到/etc目录下


运行

转到redis解压目录,直接输入命令 redis-server


4. 以服务方式运行

创建服务文件 vim /etc/systemd/system/redis.service, 设置启动位置,代码如下:

[unit]
Description=The redis-server Process Manager
After=syslog.target network.target remote-fs.target nss-lookup.target

[Service]
Type=forking
PIDFile=/var/run/redis.pid
ExecStart=/usr/redis/bin/redis-server /usr/redis/bin/redis.conf
ExecReload=/bin/kill -s HUP $MAINPID
ExecStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true

[Install]
WantedBy=multi-user.target

重新加载控制命令 systemctl daemon-reload 就可以控制redis服务了,

主要命令有systemctl start/stop/restart/status redis

重启生效命令 systemctl enable redis.service


5. 测试




遇到的问题如下:

问题1: make 时出现 gcc 没安装的情况,就去安装gcc就好了。我安装过程中出现 [Errno 256] No more mirrors to try

解决办法:可以参考我的这篇文章  yum install gcc 时遇到[Errno 256] No more mirrors to try


问题2:make 的时候出现错误 zmalloc.h:50:31: fatal error: jemalloc/jemalloc.h: No such file or directory 

解决办法: make MALLOC = libc

原因:

在README 有这个一段话。

Allocator
———

Selecting a non-default memory allocator when building Redis is done by setting
the `MALLOC` environment variable. Redis is compiled and linked against libc
malloc by default, with the exception of jemalloc being the default on Linux
systems. This default was picked because jemalloc has proven to have fewer
fragmentation problems than libc malloc.

To force compiling against libc malloc, use:

% make MALLOC=libc

To compile against jemalloc on Mac OS X systems, use:

% make MALLOC=jemalloc

说关于分配器allocator, 如果有MALLOC 这个 环境变量, 会有用这个环境变量的 去建立Redis。

而且libc 并不是默认的 分配器, 默认的是 jemalloc, 因为 jemalloc 被证明 有更少的 fragmentation problems 比libc。

但是如果你又没有jemalloc 而只有 libc 当然 make 出错。 所以加这么一个参数

运行结果如下图:




参考一    参考二

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值