#!/bin/bash

# 判断是否为root用户,不是root用户提示退出

if [[ $EUID -ne 0 ]]; then
   echo "This script. must be run as root" 1>&2
   exit 1
fi
 
# 安装必要的组件
yum install -y gcc
 
# 下载redis源代码
cd /tmp
 
# 对比文件下载是否正确
echo 26c0fc282369121b4e278523fce122910b65fbbf  redis-3.2.1.tar.gz > /tmp/download.txt
sha1sum -c download.txt
if [ $? -ne 0 ]
then
  echo "The Download File is not Correct, Please Download it again."
  exit 0
fi
 
# 编译安装
tar xf redis-3.2.1.tar.gz
cd redis-3.2.1
make
make install
 
# 创建组和用户
groupadd redis
useradd -g redis redis
 
# LOG文件存放位置
mkdir /var/log/redis
chown redis:redis /var/log/redis
 
# 当前IP地址
IP=`ifconfig eth0 | grep "inet " | awk '{ print $2}'`
 
# Redis服务开机运行
echo "[Unit]" > /usr/lib/systemd/system/redis.service 
echo "Description=Redis persistent key-value database" >> /usr/lib/systemd/system/redis.service 
echo "After=network.target" >> /usr/lib/systemd/system/redis.service 
echo "[Service]" >> /usr/lib/systemd/system/redis.service  
echo "Type=forking" >> /usr/lib/systemd/system/redis.service  
echo "ExecStart=/usr/local/bin/redis-server /etc/redis/redis.conf" >> /usr/lib/systemd/system/redis.service  
echo "ExecStop=/usr/local/bin/redis-cli -h ${IP} shutdown" >> /usr/lib/systemd/system/redis.service  
echo "User=redis" >> /usr/lib/systemd/system/redis.service  
echo "Group=redis" >> /usr/lib/systemd/system/redis.service  
echo "[Install]" >> /usr/lib/systemd/system/redis.service  
echo "WantedBy=multi-user.target" >> /usr/lib/systemd/system/redis.service
 
# Redis Sentinel 服务开机运行
echo "[Unit]" > /usr/lib/systemd/system/redis-sentinel.service 
echo "Description=Redis Sentinel" >> /usr/lib/systemd/system/redis-sentinel.service 
echo "After=network.target" >> /usr/lib/systemd/system/redis-sentinel.service 
echo "[Service]" >> /usr/lib/systemd/system/redis-sentinel.service  
echo "Type=forking" >> /usr/lib/systemd/system/redis-sentinel.service  
echo "ExecStart=/usr/local/bin/redis-sentinel /etc/redis/sentinel.conf" >> /usr/lib/systemd/system/redis-sentinel.service  
echo "ExecStop=/usr/local/bin/redis-cli -h ${IP} -p 26379 shutdown" >> /usr/lib/systemd/system/redis-sentinel.service  
echo "User=redis" >> /usr/lib/systemd/system/redis-sentinel.service  
echo "Group=redis" >> /usr/lib/systemd/system/redis-sentinel.service  
echo "[Install]" >> /usr/lib/systemd/system/redis-sentinel.service  
echo "WantedBy=multi-user.target" >> /usr/lib/systemd/system/redis-sentinel.service
 
# redis 服务限制
mkdir /etc/systemd/system/redis.service.d/
echo "[Service]" > /etc/systemd/system/redis.service.d/limits.conf 
echo "LimitNOFILE=65535" >> /etc/systemd/system/redis.service.d/limits.conf
 
# 启用开机自动运行
systemctl enable redis.service
systemctl enable redis-sentinel.service
 
# 禁用selinux
sed -i 's/SELINUX=enforcing/SELINUX=disable/' /etc/selinux/config
# 系统优化
echo "net.core.somaxconn=4096" >> /etc/sysctl.conf
echo "echo never > /sys/kernel/mm/transparent_hugepage/enabled" >> /etc/rc.local
chmod +x /etc/rc.local
echo "vm.overcommit_memory=1" >> /etc/sysctl.conf
echo "*  soft  nofile  65535" >> /etc/security/limits.conf
echo " *  hard  nofile  65535" >> /etc/security/limits.conf
echo " *  soft  nproc  65535" >> /etc/security/limits.conf
echo " *  hard  nproc  65535" >> /etc/security/limits.conf
echo "net.ipv4.tcp_tw_recycle=1" >> /etc/sysctl.conf
 
# 别名
echo "alias redis='redis-cli -h ${IP}'" >> /etc/profile
echo "alias sentinel='redis-cli -h ${IP} -p 26379'" >> /etc/profile
 
# 修改时区
/bin/cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
 
#Redis配置文件存放位置
mkdir /etc/redis
 
# 修改配置文件redis.conf
echo "bind ${IP}" > /etc/redis/redis.conf
echo "protected-mode no" >> /etc/redis/redis.conf
echo "tcp-backlog 4096" >> /etc/redis/redis.conf
echo "timeout 300" >> /etc/redis/redis.conf
echo "tcp-keepalive 60" >> /etc/redis/redis.conf
echo "daemonize yes" >> /etc/redis/redis.conf
echo "supervised systemd" >> /etc/redis/redis.conf
echo "logfile /var/log/redis/redis.log" >> /etc/redis/redis.conf
echo "dir /var/log/redis" >> /etc/redis/redis.conf
echo "maxclients 10000" >> /etc/redis/redis.conf
echo "maxmemory 4G" >> /etc/redis/redis.conf
echo "maxmemory-policy volatile-lru" >> /etc/redis/redis.conf
echo "appendonly no" >> /etc/redis/redis.conf
echo "slowlog-max-len 512" >> /etc/redis/redis.conf
echo "client-output-buffer-limit slave 512mb 256mb 300" >> /etc/redis/redis.conf
 
# 修改配置文件sentinel.conf
echo "port 26379" > /etc/redis/sentinel.conf
echo "bind ${IP}" >> /etc/redis/sentinel.conf
echo "dir /var/log/redis" >> /etc/redis/sentinel.conf
echo "sentinel monitor mymaster ${IP} 6379 2" >> /etc/redis/sentinel.conf
echo "maxclients 10" >> /etc/redis/sentinel.conf
echo "logfile /var/log/redis/sentinel.log" >> /etc/redis/sentinel.conf
echo "daemonize yes" >> /etc/redis/sentinel.conf
echo "sentinel down-after-milliseconds mymaster 5000" >> /etc/redis/sentinel.conf
echo "sentinel failover-timeout mymaster 60000" >> /etc/redis/sentinel.conf

Redis & Sentinel 安装脚本的更多相关文章

  1. Redis、Redis+sentinel安装(Ubuntu 14.04下Redis安装及简单测试)

    Ubuntu下Redis安装两种安装方式: 1.apt-get方式 步骤: 以root权限登录,切换到/usr目录下. 接下来输入命令,apt-get install redis-server,如图: ...

  2. Redis Sentinel安装与部署,实现redis的高可用

    前言 对于生产环境,高可用是避免不了要面对的问题,无论什么环境.服务,只要用于生产,就需要满足高可用:此文针对的是redis的高可用. 接下来会有系列文章,该系列是对spring-session实现分 ...

  3. Redis+Sentinel安装与配置

    在这里我们搭建的是一个1主3从的redis+3个哨兵集群的环境,由于是在一台物理机上,所有我们用端口区分. 物理机IP:192.168.0.12 主节点master端口:6301 从节点slave1端 ...

  4. Redis一键安装脚本

    #! /usr/bin/env bash # redis 6.0.3 源码安装 # 用法: bash -x install-redis-single.sh 6.0.3 version=$1 usage ...

  5. 高可用Redis(九):Redis Sentinel

    1.主从复制高可用的问题 主从复制高可用的作用 1.为master提供备份,当master宕机时,slave有完整的备份数据 2.对master实现分流,实现读写分离 但是主从架构有一个问题 1.如果 ...

  6. Redis入门到高可用(十九)——Redis Sentinel

    一.Redis  Sentinel架构     二.redis sentinel安装与配置 四.客户端连接Sentinel            四.实现原理—— 故障转移演练(客户端高可用) 五.实 ...

  7. Redis 入门到分布式 (八)Redis Sentinel

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) sentinel-目录 主从复制高可用 安装配置 实现原理 架构说明 客户端连接 常见开发运维问题 一. ...

  8. Redis Sentinel 集群安装 step by step

    一. 准备材料 服务器 IP address 操作系统 位数 Redis 版本   CNT06CAH05 192.168.3.47 CentOS 6.5 x64 Redis-3.2.6 sentine ...

  9. Redis 安装成windows服务- 一主二从三哨兵,sentinel安装为Windows服务

    这里只做记录说明 Redis的主从配置网上很多文章,百度一大堆,安装流程应该都可以配置通.我使用的这篇文章 https://blog.csdn.net/u010648555/article/detai ...

随机推荐

  1. HDU2859 Phalanx 简单DP

    dp[i][j]代表以s[i][j]字符为右上角的最大对称方阵的尺寸 最左边那一列都为1,然后按列更新,代码实现比较简单,感觉有点卡时间,如果对称度很好,时间应该比较高,我只会这种了 #include ...

  2. android和ios的系统特性区别

    1.  删除:android是长按,ios为滑动/或者进入编辑模式 2.  android:应用内返回键,保证用户停留在应用程序中:硬件返回键可以让用户退出应用程序 3.  剪切/粘贴/选择等文本操作 ...

  3. opencv开发的程序分发给客户时所需要的dll文件

    这里主要讲在其他裸机,没有搭建开发环境机器上运行自己开发的程序. 为了测试,我专门用visualbox搭建了一个虚拟机(主机和虚拟机都是win7系统) 在发给别人程序运行出现错误:msvcp100d. ...

  4. matlab 函数说明--fspecial

    好吧,这个函数在图像处理中运用得非常广泛,虽然我还是觉得不知道为啥要取这个名字,fspecial的作用如下:         产生一个预定义的2D 滤波器(create a predefined 2D ...

  5. Gym 100827G Number Game (博弈)

    Number Game Alice and Bob are playing a game on a line of N squares. The line is initially populated ...

  6. 声明了包的类Java命令找不到或无法加载主类

    首先你需要配置环境变量: CLASSPATH=.;%JAVA_HOME%/lib/dt.jar;%JAVA_HOME%/lib/tools.jar java 命令会在 CLASSPATH 目录下找相应 ...

  7. 转载 SharePoint 2013配置Master Page and Page Layout

    转载原地址: http://www.cnblogs.com/huangjianwu/p/4539706.html 涉及到的内容是关于SharePoint 2013如何部署自定义的母版页和布局页. 进入 ...

  8. 射频识别技术漫谈(10)——识别号的格式变化【worldsing笔记】

    从事RDID行业的朋友经常会遇到这样的情况,同一张ID卡,在不同厂家生产的读卡器上读出的识别号完全不一样,有时甚至差之千里.ID卡的识别号一般是在出厂时被固化在卡片的ROM里,本身是不会改变的,问题出 ...

  9. 移动端rem布局和百分比栅格化布局

    移动端的rem: 使用方法: 设置html的font-size,根据浏览器分辨率缩放 设置根元素font-size为100px这样好用的值,不要设为10px这样的: 然后获取浏览器的分辨率,也就是视口 ...

  10. JS基础DOM篇之一:何为DOM?

    近日在园子看了一篇文章,一位前端负责人问应聘者何为DOM事件流的三个阶段,我当时一看也是懵圈,于是强迫症复发,遂想要搞清楚它.谁知在查资料的过程中发现有好多关于DOM的概念也是模糊不清,便决定继续延伸 ...