02. Install redis on Linux
- 安装下载redis,参考官方文档:https://redis.io/download
- 下载:
shell>wget http://download.redis.io/releases/redis-3.2.6.tar.gz # 这里版本读者应该已官方最新stable版本为准
- Notice:我使用的安装目录是/ghca/redis ; 使用的版本是3.2.6; 下文提到的有关目录和版本,请读者已自己实际目录和版本替换。
- 解压编译安装:
shell>tar zxf redis-3.2.6.tar.gz
shell>cd redis-3.2.6
shell>make
这是二进制程序已经编译到了src目录下,启动redis-server可以直接就执行其二进制文件,也可以对启进行make install 安装,将可执行程序移到指定安装目录下
shell>make install PREFIX=/ghca/redis
这一步将redis相关二进制可执行程序安装到/ghca/redis
shell>cd /ghca/redis
shell>mkdir log etc #创建日志和配置目录
shell>mkdir data #创建rdb和dump文件存放目录
- 系统级配置修改 (修改配置这一步,可以到启动redis-server后,按照日志报警提示对应修改)
- 涉及到启动redis-server时三个warning的处理http://blog.csdn.net/a491857321/article/details/52006376
- 系统相关配置三项:
- 1)修改/etc/sysctl.conf文件,添加 vm.overcommit_memory=1到文件中
shell>sysctl vm.overcommit_memory=1
- 2)查看cat /sys/kernel/mm/transparent_hugepage/enabled,如果不是[never] 那么执行,如打印“[always] madvise never“则执行:
shell>echo never >/sys/kernel/mm/transparent_hugepage/enabled
shell>cat /sys/kernel/mm/transparent_hugepage/enabled
always madvise [never]
还要将echo 命令加入到 /etc/rc.local 为了在重启设置
shell>vi /etc/rc.local
echo never > /sys/kernel/mm/transparent_hugepage/enabled
- 3)tcp backlog设置,默认配置是511,如果启动是日志有警告warn 则需要修改系统/proc/sys/net/core/somaxconn的值为511
shell>echo 511 >/proc/sys/net/core/somaxconn
- 操作系统最好还是设置swap
- 创建配置文件,从源码中赋值配置模板,在配置模板基础上修改。具体配置内容参见《03.Redis-配置文件》
将源码文件夹下的配置文件复制到安装目录下的配置文件目录
shell>cd etc
shell>cp <源码路径>/redis.conf /ghca/redis/etc/
相关配置介绍说明(可以略过):
1)然后根据需求修改相应配置,不过要redis在后台运行,general 模块的第一个directive: daemonize no 要修改为daemonize yes
2)3.2.6版本多了安全模式配置,默认是开启安全模式,开启安全模式是一层保护redis的措施,如果:没有明确指定bind配置或者没有password配置,redis就会在安全模式下运行。redis只会接受连接来自IPV4 IPV6的loopback地址(127.0.0.1)和unix domain sockets 的连接。
3)tcp-keepalived 顾名思义:redis是tcp协议,为了保证client与redis-server之间活起的,该配置会让redis-server一定周期向client发送一个acks,可配置tcp-keepalived为0 要求没那么严格的话。
4)有关snapshot-镜像快照:save <seconds> <changes> 时间和次数 两个维度条件满足,那么就做一次snapshot。save的策略可以有多个,因为有时间这个维度的参与,时间到了满足个数的条件就执行。 这个时间起始计数应该是一次changed的开始吧??,不要快照就注释所有save。如果最后一次快照失败,那么redis会停止所有的对redis key的写操作。这样能够让adm知道出现了故障,否则就不会有人注意到灾难的发生。如果后台saving线程再次开始工作了,redis将自动允许写操作。
5)复制replication:
6)网络配置
7)指定pid文件,创建指定日志文件,日志文件名最好跟上端口号
创建启动脚本,通过service 管理;
shell>cp <源码路径>/utils/redis_init_start /tmp/ # 注意redis更高的版本redis_init_start 文件名改为了redis_init_script,高版本的操作这个文件即可
shell>修改/tmp/redis_init_start 或者 /tmp/redis_init_script
实例内容如下:
#!/bin/sh
#
# Simple Redis init.d script conceived to work on Linux systems
# as it does use of the /proc filesystem. ### BEGIN INIT INFO
# Provides: redis_6379
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Redis data structure server
# Description: Redis data structure server. See https://redis.io
### END INIT INFO REDISPORT=6379 # 端口号,和配置文件一致
REDIS_HOME=/ghca/redis # redis安装目录
EXEC=$REDIS_HOME/bin/redis-server
CLIEXEC=$REDIS_HOME/bin/redis-cli PIDFILE=/ghca/redis/redis.pid # pid文件路径 和配置文件中设置的路径一致
CONF="$REDIS_HOME/etc/redis.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 将启动文件复制到/etc/init.d/目录下:如,sudo cp /tmp/redis_init_start /etc/init.d/redis_server 复制的service服务名可以自己定义,我这里定义为redis_server;后面就可以使用service 启停redis_server服务了。不要忘记,配置文件redis.conf我们还没修改,下一步就修改配置文件了:
设置完启动脚本后,就要去设置配置文件内容了,配置文件内容参考《03. Redis-配置文件》
- 最后,添加redis 安装目录bin 到PATH中,"export PATH=/ghca/redis/bin:$PATH" 到~/.bashrc文件最后。添加完成source ~/.bashrc 加载。
02. Install redis on Linux的更多相关文章
- Redis 在 LINUX 系统下 安装, 启动
01, 下载 http://www.redis.cn/ , 这里下再下来的是 redis-4.0.1.tar.gz 这个压缩包 02, 将压缩包放到 linux 系统中, 一般放在 usr/lo ...
- 【redis】 linux 下redis 集群环境搭建
Redis集群 (要让集群正常工作至少需要3个主节点,在这里我们要创建6个redis节点,其中三个为主节点,三个为从节点,对应的redis节点的ip和端口对应关系如下) 127.0.0.1:63791 ...
- centos yum install redis
linux下yum安装redis以及使用 1.yum install redis --查看是否有redis yum 源 [root@localhost ~]# yum install r ...
- redis在linux云服务器上完整的搭建步骤
Redis的安装 搭建环境: 华为云linux服务器 Linux系统CneterOS-7.3 SSH客户端 Xshell6 安装c语言编译环境软件如下: 安装报错 然后找到了解决方法: 安装kerne ...
- Redis在linux上的配置
一.安装gcc 1.Redis在linux上的安装首先必须先安装gcc,这个是用来编译redis的源文件的.首先需要先切换的到root用户 2.然后开始安装gcc: yum install gcc- ...
- redis 在Linux下的安装与配置
redis在Linux下的安装与配置 by:授客 QQ:1033553122 测试环境 redis-3.0.7.tar.gz 下载地址: http://redis.io/download http: ...
- Redis 起步(linux)
Rdis和JQuery一样是纯粹为应用而产生的,这里记录的是在CentOS 5.7上学习入门文章: 1.Redis简介 Redis是 一个key-value存储系统.和Memcached类似,但是解决 ...
- redis 在 Linux 和 Windows 上的安装配置
最近需要在服务器上安装 redis,虽然只是一个小事情,但这个过程中也遇到了不少的问题,所以做一个总结,也希望能给到其他人一些帮助. 本文记录了 linux 系统和 windows 系统的 redis ...
- redis在linux中的安装启动
1. 拖到 /usr/local 下 2. 解压 tar zxf redis-4.0.8.tar.gz 3. mkdir /usr/redis 4. 编译 cd redis-4.0.8/src ...
随机推荐
- -bash: ./switch.sh: /bin/bash^M: bad interpreter: No such file or directory
问题: 偶然使用 windows 进行编写脚本.使用 wsl (windows subsystem for linux) 进行运行的时候,什么事情没有.但是当把脚本移植到远程服务器进行运行的时候,发现 ...
- React入门一
React.js算是当今主流框架之一了,好多公司项目都是React.直接上图: 所以最近整合一些论坛,今儿咱就说说React, React 是一个用于构建用户界面的 JAVASCRIPT 库. Rea ...
- python装饰器小计
1.装饰器:本质是函数,是用来给其他函数添加附加扩展功能的函数,其返回值是一个函数(函数指针) 2.装饰器作用:不改变函数源代码和函数调用方式的前提下添加函数的附加功能. 3.装饰器储备知识点: A. ...
- java通过反射获取字段的类型
import java.lang.reflect.Field; //这是需要引入的包 Field[] f = 类名.class.getDeclaredFields(); //获取该类的字段for(F ...
- 用CSS画小猪佩奇,你就是下一个社会人!
欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 作者:江志耿 | 腾讯TEG网络工程师 我是佩奇,哼,这是我的弟弟乔治,呱呱,这是我的妈妈,嚯,这是我的爸爸,嚯~ 背景 小猪佩奇已经火了好 ...
- Notify和NotifyAll的区别?
Notify和NotifyAll都是用来对对象进行状态改变的方式,只是他们的作用域不太一样,从字面上就能看的出来,当对象被上锁之后,当其他的方法要去访问该对象中的数据,就需要该对象对其进行解锁,当然, ...
- Linux时间子系统之四:定时器的引擎:clock_event_device
早期的内核版本中,进程的调度基于一个称之为tick的时钟滴答,通常使用时钟中断来定时地产生tick信号,每次tick定时中断都会进行进程的统计和调度,并对tick进行计数,记录在一个jiffies变量 ...
- InnoDB存储引擎结构介绍
Ⅰ.InnoDB发展史 时间 事件 备注 1995 由Heikki Tuuri创建Innobase Oy公司,开发InnoDB存储引擎 Innobase开始做的是数据库,希望卖掉该公司 1996 My ...
- .NET Orm 性能测试
.NET Orm 性能测试 简介 OrmBenchmark 这个项目主要是为了测试主要的Orm对于 SqlServer 数据库的查询并将数据转换成所需 POCO 对象的耗时情况(好吧,实际上不完全or ...
- oracle+mybatis 使用动态Sql在要insert的字段不确定的情况下实现批量insert
最近做项目遇到一个挺操蛋的问题,由于业务的关系,DB的数据表无法确定,在使用过程中字段可能会增加,这样在insert时给我造成了很大的困扰. 先来看一下最终我是怎么实现的: <insert id ...