文档章节

单实例redis 的安装配置(上)

l
 linux-tao
发布于 2017/08/23 22:15
字数 1706
阅读 7
收藏 0
导读 Redis是一种高级key-value数据库。它跟memcached类似,不过数据可以持久化,而且支持的数据类型很丰富。在运维的工作中,缓存是一个非常重要的技术,静态文件的缓存我们有:nginx的缓存,squid的缓存等,数据库的缓存我们有redis和memcache等,甚至有些公司会选择做redis的集群。今天我们就来看下redis的缓存的安装和配置上,(配置与使用请查看下次分解)

redis 的介绍

Redis是一种高级key-value数据库。它跟memcached类似,不过数据可以持久化,而且支持的数据类型很丰富。有字符串,链表,集 合和有序集合。支持在服务器端计算集合的并,交和补集(difference)等,还支持多种排序功能。所以Redis也可以被看成是一个数据结构服务器。
PS:此次安装为redis储存字符串的形式,储存用户会话session。

#redis 官网:https://redis.io/
#redis 中文官网:http://www.redis.cn/
#我们选择最新稳定版本redis-3.2.9.tar.gz

安装规划

软件包保存位置:/usr/local/src
软件包编译位置:/usr/local/src/redis-x-x/
软件安装位置:/usr/local/redis/
软件命令位置:/usr/local/redis/bin
软件日志保存位置:/usr/local/reids/redis.log
软件配置文件位置:/usr/local/redis/etc/redis.conf   
软件pid文件位置:/var/run/redis.pid
软件启动服务位置:/etc/init.d/redis
软件认证需要密码

Redis 的安装

redis的准备工作,安装依赖包

Centos系列:

yum repolist
yum -y install gcc gcc-c++ make gmake cmake zlib  tcl

Ubuntu系列:

agt-get update
Agt-get install gcc gcc-c++ make zlib tcl

下载包,安装redis

cd /usr/local/src                        \\进入软件包目录(规范化)
wget http://download.redis.io/releases/redis-3.2.9.tar.gz
                                     \\下载软件包
tar -xzf redis-3.2.9.tar.gz          \\#解压并进入redis目录
cd redis-3.2.9                       \\解压并进入redis目录
#运行测试
./runtest

#预编译  编译安装
make
make test
#进入src目录安装
cd src
make PREFIX=/usr/local/redis install
PS:redis的编译安装过程漫长,在此处我们把redis编译安装到了"/usr/local/redis"目录了,默认情况下bin命令都是在"/usr/bin"下面直接可以调用redis的命令。指的安装路径后我们需要在后期添加系统环境变量。

Redis配置文件

创建redis的配置文件目录,拷贝配置文件redis.conf

mkdir -p /usr/local/redis/etc
cp /usr/local/src/redis-3.2.9/redis.conf /usr/local/redis/etc/redis.conf

修改配置文件

vim /usr/local/redis/etc/redis.conf
cat /usr/local/redis/etc/redis.conf |grep -v "^$" |grep -v "#

bind 0.0.0.0                            \\修改内容=======对外监听
protected-mode yes
port 6379		                \\修改端口号=====按照需求
tcp-backlog 511
timeout 0
tcp-keepalive 300
daemonize yes                  \\守护进程模式打开,添加系统服务用的
supervised no
pidfile /var/run/redis.pid            \\pid的位置
loglevel verbose                      \\日志启动级别
logfile /usr/local/redis/redis.log    \\日志保存位置
databases 16                          \\reids 数据库个数
save 900 1
save 300 10
save 60 10000
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename dump.rdb
dir ./
slave-serve-stale-data yes
slave-read-only yes
repl-diskless-sync no
repl-diskless-sync-delay 5
repl-disable-tcp-nodelay no
slave-priority 100
 requirepass mima                       \\访问身份验证=================密码
 maxmemory 256m                         \\最大内存设置
 maxmemory-policy volatile-ttl          \\redis最大内存丢弃规则
appendonly no
appendfilename "appendonly.aof"
appendfsync everysec
no-appendfsync-on-rewrite no
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb
aof-load-truncated yes
lua-time-limit 5000
slowlog-log-slower-than 10000
slowlog-max-len 128
latency-monitor-threshold 0
notify-keyspace-events ""
hash-max-ziplist-entries 512
hash-max-ziplist-value 64
list-max-ziplist-size -2
list-compress-depth 0
set-max-intset-entries 512
zset-max-ziplist-entries 128
zset-max-ziplist-value 64
hll-sparse-max-bytes 3000
activerehashing yes
client-output-buffer-limit normal 0 0 0

配置文件修改内容:

port 6379                 修改端口号

bind 0.0.0.0              修改绑定IP(按需求)

timeout 0                 修改连接超时时间

loglevel verbose         日志三种类型debug、verbose、notice、warn

logfile /var/log/redis.log    日志目录*****

maxmemory 256m            redis的内存大小***

maxmemory-policy volatile-ttl   内存丢弃策略

requirepass 密码              redis认证规则**(按需求)

单实例redis 的安装配置(上)单实例redis 的安装配置(上)
PS:注意配置日志和pid等的位置,要和启动脚本关联。密码也要和启动脚本关联。

创建修改系统启动配置文件

创建系统服务启动文件

启动文件的模板:/usr/local/src/redis-3.2.9/utils/redis_init_script

cp /usr/local/src/redis-3.2.9/utils/redis_init_script /etc/init.d/redis
chmod 755 /etc/init.d/redis

修改系统启动脚本

#!/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.pid 	###pid文件所在位置#####要和配置文件一致
CONF="/usr/local/redis/etc/redis.conf" 	####redis配置文件的路径##
REDISPORT="6379"				#####启动端口####################
# SysV Init Information
# chkconfig: - 58 74  	#####添加内容,注释但有意义######
# 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 INFO
  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 -a mima shutdown	\\###修改内容,添加-a密码验证的项目###
while [ -x /proc/${PID} ]
            do
                echo "Waiting for Redis to shutdown ..."
                sleep 1
            done
            echo "Redis stopped"
        fi
        ;;
status)
        PID=$(cat $PIDFILE)
        if [ ! -x /proc/${PID} ]
        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

PS:看过《Linux就该这样学》的人都知道系统启动文件怎么写,什么格式,在这里我们就不在解释了。

redis 启动脚本添加认证两个方法

方法一:
单实例redis 的安装配置(上)单实例redis 的安装配置(上)
方法二:
单实例redis 的安装配置(上)单实例redis 的安装配置(上)

将启动脚本添加到系统服务

chkconfig --add redis				#添加系统服务
chkconfig redis on			        #设置开机自启
service redis start
service redis status
service redis stop
service redis restart

Ubuntu系统没有chkconfig

PS:chkconfig 在ubuntu系统中有可能不太容易安装,可以使用update-rc.d 命令来进行使用。

update-rc.d redisd defaults 80 80

root@linuxprobe:/etc/redis# update-rc.d redisd defaults 80 80
 Adding system startup for /etc/init.d/redisd ...
/etc/rc0.d/K80redisd -> ../init.d/redisd
/etc/rc1.d/K80redisd -> ../init.d/redisd
/etc/rc6.d/K80redisd -> ../init.d/redisd
/etc/rc2.d/S80redisd -> ../init.d/redisd
/etc/rc3.d/S80redisd -> ../init.d/redisd
/etc/rc4.d/S80redisd -> ../init.d/redisd
/etc/rc5.d/S80redisd -> ../init.d/redisd
   2345 启动    0 1 6 关闭

单实例redis 的安装配置(上)单实例redis 的安装配置(上)

如果在启动脚本里没有添加认证字段:

启动文件的一致性
单实例redis 的安装配置(上)单实例redis 的安装配置(上)

经过以上的操作后,我们的redis安装大致完成了,但是还有一些配置没有处理,比如我们的环境变量,我们的压测调优。更多精彩请看下期分解!!!!

本文原创地址:http://www.linuxprobe.com/redis-install-conf1.html

© 著作权归作者所有

共有 人打赏支持
l
粉丝 15
博文 697
码字总数 785543
作品 0
深圳
运维
linux--redis的安装和配置和开启多个端口

在workerman开发过程中需要安装redis来存储用户ip、端口等信息 首先UBUNTU中安装redis: apt-update //更新apt包源apt-get install redis-server //安装redis-server 安装完毕后可以直接启动...

李有常
2015/09/29
5.4K
0
Redis Cluster(集群)的搭建

Redis Cluster(集群)的搭建 一、Redis的下载、安装、启动(单实例) 我们统一将Redis安装在/opt目录下,执行命令如下: 安装完成,下面我们启动Redis服务: Redis启动成功,将采用Redis的默...

Java同学会
06/05
0
0
redis 一二事 - 搭建集群缓存服务器

在如今并发的环境下,对大数据量的查询采用缓存是最好不过的了,本文使用redis搭建集群 (个人喜欢redis,对memcache不感冒) redis是3.0后增加的集群功能,非常强大 集群中应该至少有三个节...

风间影月
2016/04/28
0
0
redis-cluster分布式集群安装部署

一.服务器环境 1.1环境说明 此次演示是3台内网机器,开启6个redis单实例。其中每台机器上按照不同的端redis服务端口开启2个redis实例 环境:机器的内网IP地址: 3台服务器事前先关闭iptable...

wjw555
07/07
0
0
Redis总结(三)Redis 的主从复制

  接着上一篇,前面两篇我总结了《Redis总结(一)Redis安装》和《Redis总结(二)C#中如何使用redis》 所以这一篇,会讲讲Redis 的主从复制以及C#中如何调用。   Redis跟MySQL一样,拥有...

章为忠
2015/11/20
0
0

没有更多内容

加载失败,请刷新页面

加载更多

原型模式

1、原型模式-定义 用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象 克隆(浅度克隆->拷贝值类型或者引用,深度克隆->创建新的对象,开辟新的内存) 例如客户端知道抽象Pro...

阿元
今天
32
0
awk命令扩展使用操作

awk 中使用外部shell变量 示例1 [root@centos01 t1022]# A=888[root@centos01 t1022]# echo "" | awk -v GET_A=$A '{print GET_A}'888[root@centos01 t1022]# echo "aaaaaaaaaaaaa" | aw......

野雪球
今天
28
0
深入解析MySQL视图VIEW

Q:什么是视图?视图是干什么用的? A:视图(view)是一种虚拟存在的表,是一个逻辑表,本身并不包含数据。作为一个select语句保存在数据字典中的。   通过视图,可以展现基表的部分数据;...

IT--小哥
今天
37
0
虚拟机学习之二:垃圾收集器和内存分配策略

1.对象是否可回收 1.1引用计数算法 引用计数算法:给对象中添加一个引用计数器,每当有一个地方引用它时,计数器值就加1;当引用失效时,计数器值就减1;任何时候计数器值为0的对象就是不可能...

贾峰uk
今天
24
0
smart-doc功能使用介绍

smart-doc从8月份底开始开源发布到目前为止已经迭代了几个版本。在这里非常感谢那些敢于用smart-doc去做尝试并积极提出建议的社区用户。因此决定在本博客中重要说明下smart-doc的功能,包括使...

上官胡闹
昨天
37
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部