ansible-playbook 安装redis 主从

手动在测试机上安装一遍redis,最好使用utils下面的install_server.sh安装服务,然后将redis的配置文件和init需要的执行文件 拷贝备用

配置hosts:

[root@ansible ansible]#grep -v '^#' ./hosts |grep -v '^$'

[redis:children]

redis_master

redis_slave

[redis_master]      #命名规则使用下划线,不然后面的调用有问题

192.168.3.12

[redis_slave]

192.168.3.13

192.168.3.14

建立redis角色的文件夹:

[root@ansible redis]#mkdir /etc/ansible/roles/redis/{files,templates,tasks,handlers,vars,default,meta} -pv

roles/redis/

├── default

├── files

│ └── redis-4.0.8.tar.gz

├── handlers

├── meta

├── tasks

│ └── main.yml

├── templates

│ ├── redis.j2

│ └── redis.conf.j2

└── vars

[root@ansible redis]# cat tasks/main.yml

- name: yum gcc

yum: name=gcc state=present

- name: copy redis

copy: src=redis-4.0.8.tar.gz dest=/usr/local/src/

- name: tar redis

shell: chdir=/usr/local/src/ tar -zxf redis-4.0.8.tar.gz

- name: install redis

shell: chdir=/usr/local/src/redis-4.0.8 make PREFIX=/usr/local/redis install

- name: mkdir /usr/local/redis/conf/

file: path=/usr/local/redis/conf state=directory

- name: copy redis_{{ port|default(6397) }}.conf

template: src=redis.conf.j2 dest=/usr/local/redis/conf/redis_{{ port|default(6397) }}.conf

- name: copy /etc/init.d/redis_{{ port|default(6397) }}

template: src=redis.j2 dest=/etc/init.d/redis_{{ port|default(6397) }} mode=755

- name: mkdir /var/lib/redis/{{ port|default(6397) }}

file: path=/var/lib/redis/{{ port|default(6397) }} state=directory

- name: chkconfig redis_{{ port|default(6397) }}

shell: chkconfig --add redis_{{ port|default(6397) }}

- name: systemctl enable redis_{{ port|default(6397) }}

shell: systemctl enable redis_{{ port|default(6397) }}

- name: open firewalld {{ port|default(6397) }}

shell: firewall-cmd --zone=public --add-port={{ port|default(6397) }}/tcp --permanent

- name: restart firewalld

service: name=firewalld state=restarted

- name: start redis_{{ port|default(6397) }}

service: name=redis_{{ port|default(6397) }} state=started

[root@ansible redis]#cat templates/redis.j2         #文件来源于make install之后用redis文件下面的utils下面的install_server.sh安装服务后的拷贝 主要是端口用{{ port|default(6397) }}这个代替

#!/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_{{ port|default(6397) }}.pid

CONF="/usr/local/redis/conf/redis_{{ port|default(6397) }}.conf"

REDISPORT="{{ port|default(6397) }}"

###############

# SysV Init Information

# chkconfig: - 58 74

# description: redis_{{ port|default(6397) }} is the redis daemon.

### BEGIN INIT INFO

# Provides: redis_{{ port|default(6397) }}

# 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_{{ port|default(6397) }}

# 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 shutdown

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

[root@ansible redis]#grep -v '^#' templates/redis.conf.j2 |grep -v '^$'   #文件来源于make install之后用redis文件下面的utils下面的install_server.sh安装服务后的拷贝 主要是端口用{{ port|default(6397) }}这个代替

bind 127.0.0.1 {{ inventory_hostname }}

protected-mode yes

port {{ port|default(6397) }}

tcp-backlog 511

timeout 0

tcp-keepalive 300

daemonize yes

supervised no

pidfile /var/run/redis_{{ port|default(6397) }}.pid

loglevel notice

logfile /var/log/redis_{{ port|default(6397) }}.log

databases 16

always-show-logo yes

save 900 1

save 300 10

save 60 10000

stop-writes-on-bgsave-error yes

rdbcompression yes

rdbchecksum yes

dbfilename dump.rdb

dir /var/lib/redis/{{ port|default(6397) }}

{% if inventory_hostname in groups.redis_slave %}

slaveof {{ groups.redis_master[0] }} {{ port|default(6397) }}

{% endif %}

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

lazyfree-lazy-eviction no

lazyfree-lazy-expire no

lazyfree-lazy-server-del no

slave-lazy-flush no

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

aof-use-rdb-preamble no

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

client-output-buffer-limit slave 256mb 64mb 60

client-output-buffer-limit pubsub 32mb 8mb 60

hz 10

aof-rewrite-incremental-fsync yes

配置安装yml:

[root@ansible ansible]# cat redis.yml

- hosts: redis

remote_user: root

roles:

- redis

[root@ansible ansible]# ansible-playbook --check redis.yml -e port=7000       # -e port=7000 不是必须的

[root@ansible ansible]# ansible-playbook  redis.yml -e port=7000                  # -e port=7000 不是必须的

[root@ansible ansible]# ansible-playbook  redis.yml -e port=7001  --start-at-task="copy redis_{{ port|default(6397) }}.conf"       #安装多个redis的时候可以从这个task开始

对于 sentinel 可以安装在redis服务器,也可以安装到单独的服务器上。

ansible-playbook 安装redis 主从的更多相关文章

  1. docker安装redis主从以及哨兵

    docker安装redis主从以及哨兵 本文使用docker在四台机器上部署一主二从三哨兵的Redis主从结构. 服务器配置 192.168.102.128 主节点 centos7.5 192.168 ...

  2. ansible playbook 安装docker

    1.新增host配置到/etc/ansible/hosts文件中 [docker] 192.168.43.95 2.配置无密码登录 # 配置ssh,默认rsa加密,保存目录(公钥)~/.ssh/id_ ...

  3. Vagrant Ansible Playbook 安装一群虚拟机

    https://docs.ansible.com/ https://favoorr.github.io/2017/01/06/vagrant-virtualbox-vagrantfile-config ...

  4. ansible playbook部署ELK集群系统

    一.介绍 总共4台机器,分别为 192.168.1.99 192.168.1.100 192.168.1.210 192.168.1.211 服务所在机器为: redis:192.168.1.211 ...

  5. ansible自动安装rabbitmq

    ansible playbook 安装rabbitmq单机版,以下脚本在CentOS6.7服务器测试通过. 需要配置本机的yum源,用于安装socat软件. rabbitmq版本和Erlang版本需要 ...

  6. Redis 安装,主从配置及Sentinel配置自动Failover

    1.安装redis 首页地址:http://redis.io/ 下载地址:http://download.redis.io/ 下载最新的源码包 tar -zxvf redis-stable.tar.g ...

  7. Redis安装及主从配置(转)

    一.何为Redis redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合)和zset(有 ...

  8. Redis安装及主从配置

    一.何为Redis redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合)和zset(有 ...

  9. windows下安装和redis主从配置(通过哨兵控制主从切换)

    首先自己先得了解什么是redis,这里就不详做介绍什么是redis了,这篇文章主要讲的是怎么样配置 redis怎样配置主从关系和哨兵控制主从服务器的配置以及应用,就当是给自己记笔记吧! 1.下载red ...

随机推荐

  1. Noip模拟12 2021.7.12

    T1 interval 亏得昨天晚上改掉了T3并且理解了单调栈,今天一扫这题目就知道要用啥了. 先预处理出以a[i]为最大值的最大左右区间.然后再将a[i]取%!!!是的,要不然会影响单调栈的使用.. ...

  2. Linux过来人帮你理清学习思路

    很多同学接触linux不多,对linux平台的开发更是一无所知. 而现在的趋势越来越表明,作为一个优秀的软件开发人员,或计算机it行业从业人员,="" 掌握linux是一种很重要的 ...

  3. 洛谷 P2680 [NOIP2015 提高组] 运输计划

    链接:P2680 题意: 在树上把一条边边权变为0使得最长给定路径最短 分析: 最大值最小可以想到二分答案,对于每一个mid,寻找所有大于mid的路径,再寻找是否存在一条边使得删去它后大于mid的路径 ...

  4. Shadertoy 教程 Part 3 - 矩形和旋转

    Note: This series blog was translated from Nathan Vaughn's Shaders Language Tutorial and has been au ...

  5. Luogu P3758 [TJOI2017]可乐 | 矩阵乘法

    题目链接 让我们先来思考一个问题,在一张包含$n$个点的图上,如何求走两步后从任意一点$i$到任意一点$j$的方案数. 我们用$F_p(i,j)$来表示走$p$步后从$i$到$j$的方案数,如果存储原 ...

  6. VS2013快捷键及技巧 / 智能插件

    复制/剪切/删除整行代码 1)如果你想复制一整行代码,只需将光标移至该行,再使用组合键"Ctrl+C"来完成复制操作,而无需选择整行. 2)如果你想剪切一整行代码,只需将光标移至该 ...

  7. Fiddler抓包工具简介:(三)手机端代理配置

    1.接入网络:需要在移动终端(手机或pad)上指定代理服务器为Fiddler所在主机的IP,端口默认为8888,要保证手机和安装有fiddler的电脑处在同一局域网内,手机能ping通电脑. [方法] ...

  8. JSON Parse error: Unexpected identifier "object";stringToAnyType报错 uni-app

    只限于uni 的局限问题,博主的报错是因为初始化某些关键数据在uni的  onLoad生命周期  和  onReady生命周期里面初始化,导致数据加载时出现个别报错的BUG JSON Parse er ...

  9. 第四周PTA笔记 好吃的巧克力+特殊的翻译+下次一定(续)+走迷宫

    好吃的巧克力 超市正在特价售卖巧克力,正好被贪吃的Lucky_dog看见了. 巧克力从左到右排成一排,一共有N个,M种. 超市有一个很奇怪的规定,就是你在购买巧克力时必须提供两个数字a和b,代表你要购 ...

  10. Django笔记&教程 0-1 前言

    Django 自学笔记兼学习教程第0章第1节--前言 点击查看教程总目录 1 最初的想法 自学Django已经有一段时间了,自认收获不少,学的还算可以,然而实际去做项目写代码的时候,很多用法记得不清, ...