设为首页 收藏本站
查看: 920|回复: 0

[经验分享] Redis的下载、安装

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2017-2-27 09:37:30 | 显示全部楼层 |阅读模式

前提:环境材料准备



    CentOS Linux release 7.2.1511 (Core)

    redis-3.2.8.tar.gz

1.下载(Download)、解压(extract)、完整性检查(How to verify files for integrity)

    Redis uses a standard practice for its versioning: major.minor.patchlevel. Redis使用标准做法进行版本控制:主版本号.次版本号.修订版本号 An even minor marks a stable release, like 1.2, 2.0, 2.2, 2.4, 2.6, 2.8. 偶数次版本号表示一个稳定的发行版,如1.2,2.0,2.2,2.4,2.6,2.8。 Odd minors are used for unstable releases, for example 2.9.x releases are the unstable versions of what will be Redis 3.0 once stable.奇数次版本号被用于表示不稳定版本,例如2.9.x版本是不稳定版本,一旦稳定就是3.0

完整性:与 redis-hashes 对照

$ wget http://download.redis.io/releases/redis-3.2.8.tar.gz$ sha1sum redis-3.2.8.tar.gz6780d1abb66f33a97aad0edbe020403d0a15b67f  redis-3.2.8.tar.gz
$ tar zxvf  redis-3.2.8.tar.gz
$ cd redis-3.2.8

2. 编译(compile)、安装 (Installing)

In order to install Redis binaries into /usr/local/bin just use:

% make install

You can use make PREFIX=/some/other/directory install if you wish to use a different destination. 如果你想安装二进制命令到不同的目录

Make install will just install binaries in your system, but will not configure init scripts and configuration files in the appropriate place. This is not needed if you want just to play a bit with Redis, but if you are installing it the proper way for a production system, we have a script doing this for Ubuntu and Debian systems:

Make install在系统中只会安装二进制文件,但不会在适当的位置配置init脚本和配置文件。 如果你只想玩一点Redis,这不是必需的。但如果你正在为生产系统安装它找一个更合适的方式, 针对Ubuntu和Debian系统,我们有一个脚本做这些:

% cd utils% ./install_server.sh

The script will ask you a few questions and will setup everything you need to run Redis properly as a background daemon that will start again on system reboots.

You'll be able to stop and start Redis using the script named /etc/init.d/redis_<portnumber>, for instance /etc/init.d/redis_6379.

# cd redis-3.2.8
# make PREFIX=/usr/local/redis install

Hint: It's a good idea to run 'make test' ;)
# make test...
...

\o/ All tests passed without errors!

Cleanup: may take some time... OK

# mkdir -pv /usr/local/redis/{etc,log,lib}mkdir: created directory ‘/usr/local/redis/etc’mkdir: created directory ‘/usr/local/redis/log’

# cd utils
# ./install_server.shWelcome to the redis service installer
This script will help you easily set up a running redis server

Please select the redis port for this instance: [6379]
Selecting default: 6379
Please select the redis config file name [/etc/redis/6379.conf] /usr/local/redis/etc/6379.confPlease select the redis log file name [/var/log/redis_6379.log] /usr/local/redis/log/redis_6379.logPlease select the data directory for this instance [/var/lib/redis/6379] /usr/local/redis/lib/6379
Please select the redis executable path [] /usr/local/redis/bin/redis-server
Selected config:
Port           : 6379
Config file    : /usr/local/redis/etc/6379.confLog file       : /usr/local/redis/log/redis_6379.logData dir       : /usr/local/redis/lib/6379
Executable     : /usr/local/redis/bin/redis-serverCli Executable : /usr/local/redis/bin/redis-cliIs this ok? Then press ENTER to go on or Ctrl-C to abort.
Copied /tmp/6379.conf => /etc/init.d/redis_6379
Installing service...
Successfully added to chkconfig!
Successfully added to runlevels 345!
Starting Redis server...
Installation successful!

# ps aux | grep redis
root      58811  0.2  0.1 136912  7524 ?        Ssl  18:31   0:00 /usr/local/redis/bin/redis-server 127.0.0.1:6379


# The binaries that are now compiled are available in the src directory.
现在被编译的二进制文件在src目录中。
# cd src/
# md5sum redis*
3c507af948c7bc80cb92c66a5ed17bc1  redisassert.hd7fcdd079f9fb025e5e380603dfecf4b  redis-benchmark
4230b5d20e23fc25411d99cc56429692  redis-benchmark.c
fd9d73aeb32a609957b77edb83e82fa9  redis-benchmark.o
d575a6cc0bc896a722a4d70cbe1352c2  redis-check-aof
991bf6ef06e1fc4d0a66a48c1505e498  redis-check-aof.c
2bdfdbbb16ec9c227128d6c239a5706c  redis-check-aof.o
1e3f0c6d96b88dcdca1b4d35d169b52f  redis-check-rdb
34cbd2a2be9ecf8ab21e65ca9095cc67  redis-check-rdb.c
3068ffe1e036d12b8df0d9f28290f972  redis-check-rdb.o
4e45e24376159a1121a54e9e5eee3f2f  redis-cli2a2af684a4e598d024f1c606a5c7913e  redis-cli.c
9494101d9b9c68866ec95f8921574dcf  redis-cli.o
1e3f0c6d96b88dcdca1b4d35d169b52f  redis-sentinel  * 二者相同
1e3f0c6d96b88dcdca1b4d35d169b52f  redis-server    *
70b2284c8833a8773e26abe6ba7797c3  redis-trib.rb

# tree /usr/local/redis/
/usr/local/redis/
├── bin
│   ├── redis-benchmark
│   ├── redis-check-aof
│   ├── redis-check-rdb
│   ├── redis-cli│   ├── redis-sentinel -> redis-server  # 两者相同
│   └── redis-server
├── etc
│   └── 6379.conf├── lib
└── log

3. 修改SysV服务脚本

# cat /etc/init.d/redis_6379 #!/bin/sh#Configurations injected by install_server below....EXEC=/usr/local/redis/bin/redis-server
CLIEXEC=/usr/local/redis/bin/redis-cli
PIDFILE=/var/run/redis_6379.pid
CONF="/usr/local/redis/etc/6379.conf"REDISPORT="6379"################ SysV Init Information# chkconfig: - 30 50# description: redis_6379 is the redis daemon.### BEGIN INIT INFO# Provides: redis_6379# Required-Start: $network $local_fs $remote_fs# Required-Stop: $network $local_fs $remote_fs# Default-Start: 2 3 4 5# Default-Stop: 0 1 6# Should-Start: $syslog $named# Should-Stop: $syslog $named# Short-Description: start and stop redis_6379# Description: Redis daemon### END INIT INFOcase "$1" in
    start)        if [ -f $PIDFILE ]        then
            echo "$PIDFILE exists, process is already running or crashed"
        else
            echo "Starting Redis server..."
            $EXEC $CONF
        fi
        ;;
    stop)        if [ ! -f $PIDFILE ]        then
            echo "$PIDFILE does not exist, process is not running"
        else
            PID=$(cat $PIDFILE)            echo "Stopping ..."
            $CLIEXEC -p $REDISPORT shutdown            while [ -x /proc/${PID} ]            do
                echo "Waiting for Redis to shutdown ..."
                sleep 1
            done
            echo "Redis stopped"
        fi
        ;;
    status)
        PID=$(cat $PIDFILE 2> /dev/null)  # 原为PID=$(cat $PIDFILE) stop之后,文件不存在,抛出异常
        if [ -z ${PID} ]  # 原为if [ ! -x /proc/${PID} ] PID即使为空,但/proc仍然存在,最后还是会回到running状态
        then
            echo 'Redis is not running'
        else
            echo "Redis is running ($PID)"
        fi
        ;;
    restart)        $0 stop        $0 start
        ;;
    *)        echo "Please use start, stop, restart or status as first argument"
        ;;esac

4. 连接测试

(magedu) [iyunv@Webserver utils]# redis-cli -h localhost -p 6379localhost:6379> ping
PONG
localhost:6379> set foo bar
OK
localhost:6379> get foo"bar"localhost:6379> ping 'zcy'"zcy"

5. 关闭服务

# netstat -tlnp | grep 6379 127.0.0.1:6379          0.0.0.0:*               LISTEN      67387/redis-server  
# pkill -u root redis   # 方法1# netstat -tlnp | grep 6379# service redis_6379 statusRedis is not running# service redis_6379 stoppid does not exist, process is not running# service redis_6379 startStarting Redis server...# redis-cli -h localhost -p 6379 get foo"bar"# redis-cli -h localhost -p 6379 shutdown  #方法2 : 服务脚本用的是这一种。# service redis_6379 statusRedis is not running#无论哪种方式关闭服务,都会产生如下日志71428:M 25 Feb 22:06:09.131 # User requested shutdown...  关闭用户的请求71428:M 25 Feb 22:06:09.131 * Saving the final RDB snapshot before exiting. 在关闭之前保存最后的RDB快照71428:M 25 Feb 22:06:09.142 * DB saved on disk  DB保存到磁盘上71428:M 25 Feb 22:06:09.142 * Removing the pid file.   移除PID文件71428:M 25 Feb 22:06:09.142 # Redis is now ready to exit, bye bye.. pkill ,kill 默认发送信号15 SINTERM
产生日志:67387:signal-handler (1488031433) Received SIGTERM scheduling shutdown... 接收到终止信号安排关闭...





运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-347743-1-1.html 上篇帖子: Redis高级特性介绍及实例分析 下篇帖子: redis基础篇
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表