导读 | 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认证规则**(按需求)
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 启动脚本添加认证两个方法
方法一:
方法二:
将启动脚本添加到系统服务
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安装大致完成了,但是还有一些配置没有处理,比如我们的环境变量,我们的压测调优。更多精彩请看下期分解!!!!
原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/113543.html