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

[经验分享] redis 安装简介

[复制链接]
发表于 2018-11-5 12:55:26 | 显示全部楼层 |阅读模式
  Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库。
  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可以做很多内部复杂性很强的事情。 同时,在磁盘格式方面他们是紧凑的以追加的方式产生的,因为他们并不需要进行随机访问。
  第一部分:安装redis
  希望将redis安装到此目录 :/usr/local/redis
$ mkdir /usr/local/redis  
$ cd /usr/local/src
  
$ yum install gcc
  
$ wget http://redis.googlecode.com/files/redis-2.6.14.tar.gz
  
$ tar xzf redis-2.6.14.tar.gz
  
$ ln -s redis-2.6.14 redis #建立一个链接
  
$ cd redis
  
$ make PREFIX=/usr/local/redis install #安装到指定目录中
wget http://download.redis.io/releases/redis-3.0.0.tar.gz  
编译源程序
  
tar zxvf redis-3.0.0.tar.gz
  
cd redis-3.0.0 makecd src
  
make install
  

  

  

  
创建redis目录,移动文件,为了便于管理
  
mkdir -p /usr/local/redis/bin
  
mkdir -p /usr/local/redis/etc
  
mv /src/redis-3.0.0/redis.conf /usr/local/redis/etc
  
cd /src/redis-3.0.0/src
  
mv mkreleasehdr.sh redis-benchmark redis-check-aof redis-check-dump redis-cli redis-server /usr/local/redis/bin
启动redis服务(redis服务端的默认连接端口是6379)  
/usr/local/redis/bin/redis-server
  
/usr/local/redis/etc/redis.conf
  
默认情况下,redis不是在后台运行的,我们需要把开启的redis后台运行
  
vi /usr/local/redis/etc/redis.conf
  
将daemonize的值改为yes
  
查看是否启动
  
ps -ef | grep redis
  
查看是否占用6379端口号
  
netstat -tunpl | grep 6379
  
再启动redis
  
/usr/local/redis/bin/redis-server /usr/local/redis/etc/redis.conf
  
客户端连接
  
/usr/local/redis/bin/redis-cli
  
退出客户端
  
exit
  
或者
  
quit
  
再或者Ctrl+C
  

  

  

  
停止redis
  
/usr/local/redis/bin/redis-cli shutdown
  
或者
  
pkill redis-server
redis的一些配置  
daemonize如果需要在后台运行,把该项改为yes
  
pidfile配置多个pid的地质,默认在/var/ren/redis.pid
  
bind绑定ip,设置后只接受来自该ip的请求
  
port监听端口,默认为6379
  
timeout设置客户端连接时的超时时间,单位为秒
  
loglevel分为4级,debug、verbose、notice、warning
  
logfile配置log文件地址 databases 设置数据库的个数,默认使用的数据库为0
  
save设置redis进行数据库镜像的频率
  
rdbcompression在进行镜像备份时,是否进行压缩
  
Dbfilename镜像备份文件的文件名
  
Dir数据库镜像备份的文件放置路径
  
Slaveof设置数据库为其他数据库的从数据库
  
Masteauth主数据库连接需要的密码验证
  
Requirepass设置登陆时需要的使用的密码
  
Maxclients限制同时连接的客户数量
  
Maxmemory设置redis能够使用的最大内存
  
Appendonly开启append only模式
  
Appendfsync设置对appendonly.aof文件同步的频率
  
vm-enabled是否开启虚拟内存支持
  
vm-swap-file设置虚拟内存的交换文件路径
  
vm-max-memory设置redis使用的最大物理内存大小
  
vm-page-size设置虚拟内存的页大小
  
vm-pages设置交换文件的总的page数量
  
vm-max-threads设置VMIO同时使用的线程数量
  
Glueoutputbuf设置在向客户端应答时,是否把较小的包合并为一个包发送,默认为开启
  
hash-max-zipmap-entries设置hash的临界值
  
Activerehashing重置hash,默认为开启
  注意上面的最后一行,我们通过PREFIX指定了安装的目录。如果make失败,一般是你们系统中还未安装gcc,那么可以通过yum安装:
  在安装redis成功后,你将可以在/usr/local/redis看到一个bin的目录,里面包括了以下文件:
  redis-benchmark  redis-check-aof  redis-check-dump  redis-cli  redis-server
  第二部分:将redis做成一个服务
  1.复制脚本到/etc/rc.d/init.d目录
  ps: /etc/rc.d/init.d/目录下的脚本就类似与windows中的注册表,在系统启动的时候某些指定脚本将被执行
  按以上步骤安装Redis时,其服务脚本位于:
  /usr/local/src/redis/utils/redis_init_script
  必须将其复制到/etc/rc.d/init.d的目录下:
  cp /usr/local/src/redis/utils/redis_init_script /etc/rc.d/init.d/redis
  将redis_init_script复制到/etc/rc.d/init.d/,同时易名为redis。
  如果这时添加注册服务:
  chkconfig --add redis
  将报以下错误:
  redis服务不支持chkconfig
  为此,我们需要更改redis脚本。
  2.更改redis脚本
  打开使用vi打开脚本,查看脚本信息:
  vim /etc/rc.d/init.d/redis
#!/bin/sh  
#chkconfig: 2345 80 90
  
# Simple Redis init.d script conceived to work on Linux systems
  
# as it does use of the /proc filesystem.
  

  
REDISPORT=6379
  
EXEC=/usr/local/redis/bin/redis-server
  
CLIEXEC=/usr/local/redis/bin/redis-cli
  

  
PIDFILE=/var/run/redis_${REDISPORT}.pid
  
CONF="/etc/redis/${REDISPORT}.conf"
  

  
case "$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
  
        ;;
  
    *)
  
        echo "Please use start or stop as first argument"
  
        ;;
  
esac
  和原配置文件相比:
  1.原文件是没有以下第2行的内容的,
  #chkconfig: 2345 80 90
  2.原文件EXEC、CLIEXEC参数,也是有所更改。
EXEC=/usr/local/redis/bin/redis-server  
CLIEXEC=/usr/local/redis/bin/redis-cli
  3.redis开启的命令,以后台运行的方式执行。
  $EXEC $CONF &
  ps:注意后面的那个“&”,即是将服务转到后面运行的意思,否则启动服务时,Redis服务将
  占据在前台,占用了主用户界面,造成其它的命令执行不了。
  4.将redis配置文件拷贝到/etc/redis/${REDISPORT}.conf
  mkdir /etc/redis
  cp /usr/local/src/redis/redis.conf /etc/redis/6379.conf
  这样,redis服务脚本指定的CONF就存在了。默认情况下,Redis未启用认证,可以通过开启6379.conf的requirepass 指定一个验证密码。
  以上操作完成后,即可注册yedis服务:
  chkconfig --add redis
  3.启动redis服务
  service redis start
  第三,将Redis的命令所在目录添加到系统参数PATH中
  修改profile文件:
  vi /etc/profile
  在最后行追加:
  export PATH="$PATH:/usr/local/redis/bin"
  然后马上应用这个文件:
  . /etc/profile
  这样就可以直接调用redis-cli的命令了,如下所示:
$ redis-cli  
redis 127.0.0.1:6379> auth superman
  
OK
  
redis 127.0.0.1:6379> ping
  
PONG
  
redis 127.0.0.1:6379>
  至此,redis 就成功安装了。
  Redis源码无外部依赖,故编译安装非常方便,从官网下载最新稳定版的源码后,解压后make即可。
  编译好的bin文件位于在源码的src目录下,均以redis-xxx命名。其中:
  可执行的2进制文件共有5个:
  a.redis-benchmark    # 性能测试工具
  b.redis-check-aof      # aof文件修复工具
  c.redis-check-dump  # rdb文件修复工具
  d.redis-cli                   # 命令行交互工具
  e.redis-server            # redis server
  conf文件两个:
  a.redis.conf                # redis server的配置文件
  b.sentinel.conf           # redis sentinel配置文件,用于监控



运维网声明 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-631148-1-1.html 上篇帖子: Redis安装教程 下篇帖子: python学习笔记-Day12-- memcached / redis / rabbitMQ / sqlalchemy
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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