CentOS 6.5下Redis安装详细步骤

时间:2022-03-13 15:25:49

http://www.codeceo.com/article/centos-redis-setup.html

Redis简介:

Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持。

redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set –有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。

安装环境:

CentOS 6.5

Redis 2.8.13

下载安装:

下载文件到 /opt/ 目录下

wget http://download.redis.io/releases/redis-2.8.13.tar.gz

解压文件

tar zxvf redis-2.8.13.tar.gz

切换目录到 redis-2.8.13 目录下

cd redis-2.8.13

执行make命令,最后几行的输出结果

Hint: To run ‘make test’ is a good ideaCentOS 6.5下Redis安装详细步骤
make[1]: Leaving directory `/opt/redis-2.8.13/src’

执行安装命令

make install

提示:

cd src && make install
make[1]: Entering directory `/opt/redis-2.8.13/src'

Hint: To run '
make test' is a good idea
CentOS 6.5下Redis安装详细步骤

INSTALL install
INSTALL install
INSTALL install
INSTALL install
INSTALL install
make[1]: Leaving directory `/opt/redis-2.8.13/src'

根据提示,执行:cd src && make install

提示:

Hint: To run 'make test' is a good idea CentOS 6.5下Redis安装详细步骤 

INSTALL install
INSTALL install
INSTALL install
INSTALL install
INSTALL instal

按照提示执行:make test

提示:

You need tcl 8.5 or newer in order to run the Redis test
make: *** [test] Error 1

解决方法参考:http://www.linuxfromscratch.org/blfs/view/cvs/general/tcl.html

也可以使用:yum install tcl 命令安装

后来经搜索发现不需要安装,直接到src目录下执行 ./redis-server 就可以

CentOS 6.5下Redis安装详细步骤

可以使用类似 ./redis-server /path/to/redis.conf 命令指定配置文件;

Server started, Redis version 2.8.13
The server is now ready to accept connections on port 6379

服务启动成功,服务已经在6379端口上监听连接请求。

你可以使用内置的客户端连接Redis:http://www.redis.cn/download.html

$ src/redis-cli
redis> set foo bar
OK
redis> get foo
"bar"

注意事项:

要远程访问它,还需要开启防。

不要使用Ctrl+C,这样会使程序退出。


开启远程登录的方法:

在redis的配置文件redis.conf中,找到bind localhost注释掉。

    注释掉本机,局域网内的所有计算机都能访问。

    band localhost   只能本机访问,局域网内计算机不能访问。

    bind  局域网IP    只能局域网内IP的机器访问, 本地localhost都无法访问。

  验证方法:

  [root@mch ~]# ps -ef | grep redis
  root
2175 1 0 08:15 ? 00:00:05 /usr/local/bin/redis-server *:6379

  /usr/local/bin/redis-server *:6379 中通过"*"就可以看出此时是允许所有的ip连接登录到这台redis服务上。

   注意事项:

  今天再设置远程访问的时候,在启动Redis的时候报错:Creating Server TCP listening socket *:6379: unable to bind socket(Redis一定不能设置成后台运行,否则终端不会有任何错误显示)。

  上网搜索说各种原因的都有,有的说是Redis版本的bug(我用的版本是3.2.0),我是参考以下几篇文章解决了这个问题:

  https://github.com/antirez/redis/issues/3241

  http://blog.csdn.net/qq_25797077/article/details/51986455

  http://*.com/questions/8537254/redis-connect-to-remote-server

  我没有注释掉bind 127.0.0.1,而是将bind 127.0.0.1 改成了bind 0.0.0.0。

Redis的启动停止

edis安装配置完成后,启动过程非常简单,执行命令/usr/local/redis/bin/redis-server /usr/local/redis/etc/redis.conf即可。停止Redis的最简单的方法是在启动实例的session中,直接使用Control-C命令。当然还可以通过客户端来停止服务,如可以用shutdown来停止Redis实例,具体命令为src/redis-cli shutdown。