zoukankan      html  css  js  c++  java
  • centos7 安装redis 6.0.3

    简介
    Redis,全称 Remote Dictionary Server(远程字典服务器) ,全开源基于C语言开发,是高性能的(key/value)分布式内存数据库,基于内存运行并支持持久化的NoSQL数据库,是当前最热门的NoSQL数据库之一,也被人们称为数据结构服务器。

    环境准备

    操作系统

    [root@had-test ~]# cat /etc/redhat-release
    CentOS Linux release 7.5.1804 (Core)

    redis6版本的下载连接: http://download.redis.io/releases/redis-6.0.3.tar.gz

    创建redis目录,将redis的安装包下载到这个 目录

    [root@had-test ~]# cd /opt/
    [root@had-test opt]# mkdir redis  #将redis的安装包下载到这个目录

    安装依赖

    yum -y install  gcc   gcc-c++ make  tcl  #测试需要依赖tcl

    编译安装需要gcc5.3以上,可以用gcc -v 命令查看当前版本号,使用下面的命令升级到gcc9.1:


    yum -y install centos-release-scl
    yum -y install devtoolset-9-gcc devtoolset-9-gcc-c++ devtoolset-9-binutils
    #scl命令启用只是临时的,新开的会话默认还是原gcc版本。
    scl enable devtoolset-9 bash
    #如果要长期使用gcc 9.1的话执行下面的命令即可:

    echo -e " source /opt/rh/devtoolset-9/enable" >>/etc/profile

    编译安装

    [root@redis-1 redis]# tar xf redis-6.0.3.tar.gz
    [root@redis-1 redis]# ls
    redis-6.0.3  redis-6.0.3.tar.gz
    [root@redis-1 redis]# mv redis-6.0.3 redis
    [root@redis-1 redis]# ls
    redis  redis-6.0.3.tar.gz
    [root@redis-1 redis]# cd redis/
    [root@redis-1 redis]# make

    [root@redis-1 redis]#make install PREFIX=/opt/redis6 #安装指定目录

    #如果编译出错之后再编译可以先执行命令删除之前的编译文件

    make distclean

    编译完了可以执行命令测试

    make test

    配置启动

    进入到安装的目录/opt/redis6下 将源码中的redis.conf文件 复制到redis6的bin目录下并修改配置

    mkdir /opt/redis6/data

    cp /opt/redis/redis/redis.conf /opt//redis6/bin/

    vim /opt/redis6/bin/redis.conf
    #daemonize no 改为yes,开启后台运行,默认是前台运行
    daemonize yes
    #把这一行注释,监听所有IP
    #bind 127.0.0.1
    #protected-mode yes 如果改为no,则是关闭保护模式,这种模式下不能配置系统服务,建议还是开启
    protected-mode yes
    #requirpass,保护模式开启的时候要配置密码或者bind ip
    requirepass 123456
    #修改本参数,指定数据目录
    dir /opt/redis6/data
    #修改本参数,指定日志目录
    logfile /opt//redis6/redis_6379.log

    启动redis

    编写启动脚本

    vim /lib/systemd/system/redis.service

    [Unit]
    Description=Redis
    After=network.target
    [Service]
    Type=forking
    PIDFile=/var/run/redis_6379.pid
    ExecStart=/opt/redis6/bin/redis-server /opt/redis6/bin/redis.conf
    ExecReload=/bin/kill -s HUP $MAINPID
    ExecStop=/bin/kill -s QUIT $MAINPID
    PrivateTmp=true
    [Install]
    WantedBy=multi-user.target

    使用systemctl命令
    # 重载服务
    systemctl daemon-reload
    # 开机自启
    systemctl enable redis
    # 启动
    systemctl start redis
    # 重启
    systemctl restart redis    
    # 停止
    systemctl stop redis
    # 查看状态
    systemctl status redis
    # 关闭开机启动
    systemctl disable redis

    使用Redis Desktop Manager连接Redis


    下载安装redis desktop manager:
    Github: https://github.com/uglide/RedisDesktopManager
    官网: https://redisdesktop.com/
    配置防火墙,嫌麻烦直接关闭即可:
    #查看防火墙状态
    systemctl status firewalld
    #关闭防火墙
    service firewalld stop
    #开启防火墙
    service firewalld start
    #单独开6379端口
    firewall-cmd --permanent --add-port=6379
    tcpfirewall-cmd --reload
    由于上面的配置我们已经开启了所有IP的监听,因此可以直接连接:
    关闭保护模式且无密码模式:

    开启保护模式设置密码,以systemctl命令启动和开机自启:

    注:redis6之后支持多线程,使用redis6的io多线程的好处?

    1,reddis6把多线程用在哪里?

    redis运行的瓶颈,通常不在cpu,而在内存和网络I/O

    Redis 6 对多线程的启用,主要用在处理网络I/O,

    流程就是:把监听到的网络的事件,分发给work thread做处理,

    在处理完之后,由主线程负责执行。

    说明:这是我们要注意的地方:

    redis6对于命令的执行仍然是由主线程执行,

    也就是象以前使用的原子性的命令如rpush/lua脚本仍然具有原子性,

    不会因为多线程的引入也失效。

    2,性能提升显著:

     Redis读写网络的 read/write 系统调用在 执行期间占用了大部分 CPU 时间,

     所以把网络读写做成多线程的方式对性能会有很大提升,

     根据测试,在 4个线程 IO 时,性能相比单线程提高一倍,

     是redis6中的最可观的性能提升

    3.什么情况适宜启用io多线程?

    来自官方配置文件的说明:

    默认情况多线程是disabled,当server有至少4个核心或更多时可以启用,

    至少留下一个备用的核心。

    当设置为多于8个线程时,不会用明显的性能提升

    建议当确实遇到性能问题时而且redis的实例能占用cpu时间的一大部分时

    再启用threaded I/O,这样会比较有效,

    否则没有启用这个功能的必要。

    下面是多线程的配置方法:

    配置指令一

    #io-threads: 启用的io线程数量

    io-threads 4

    这个值设置为多少?

    根据配置文件的说明:

    如果你的server有4个核心,尝试把这个值设置为3

    如果有8个核心,尝试把这个值设置为6

    但这个值不建议超过8

    配置指令二:

    #读请求也使用io线程

    io-threads-do-reads yes

    设置为yes即可,配置文件中的说明:

    当I/O threads被启用时,线程仅用于写,

    如果需要把读数据和协议解析也启用线程,

    则需要把io-threads-do-reads也设置为yes

    作者认为对读请求启用io-threads得到的帮助不算太多

    redis配置多线程注意事项

    1.在redis运行时通过config set 来使用线程的配置指令不会生效,

       当SSL启用时,多线程也不会生效

    2,如果使用redis-benchmark测试redis的速度 ,

       需要确认redis-benchmark是多线程模式,

       使用 --threads选项来匹配redis的线程数量,

       否则不会看到性能有明显提升

  • 相关阅读:
    用Python作GIS:择菜篇
    【嵌入式开发技术之串口】Linux下串口主机程序
    1033,2052 是什么意思?
    Telnet协议详解
    生活情景英语:英语国家生存英语精选
    windows下搭建iphone开发环境
    开公司的流程
    解决某物流企业二维码打印问题
    数字黑洞
    InnoSetup 打包代码 检测.netFramework
  • 原文地址:https://www.cnblogs.com/cx850116/p/15072054.html
Copyright © 2011-2022 走看看