Please note that the original design goal of this role was more concerned with the initial installation and bootstrapping environment, which currently does not involve performing continuous maintenance, and therefore are only suitable for testing and development purposes, should not be used in production environments. The author does not guarantee the accuracy, completeness, reliability, and availability of the role content. Under no circumstances will the author be held responsible or liable in any way for any claims, damages, losses, expenses, costs or liabilities whatsoever, including, without limitation, any direct or indirect damages for loss of profits, business interruption or loss of information.
请注意,此角色的最初设计目标更关注初始安装和引导环境,目前不涉及执行连续维护,因此仅适用于测试和开发目的,不应在生产环境中使用。作者不对角色内容之准确性、完整性、可靠性、可用性做保证。在任何情况下,作者均不对任何索赔,损害,损失,费用,成本或负债承担任何责任,包括但不限于因利润损失,业务中断或信息丢失而造成的任何直接或间接损害。
Table of Contents
- Overview
- Requirements
- Role variables
- Dependencies
- Example Playbook
- License
- Author Information
- Donations
Redis provides high availability via Redis Sentinel distributed system. Sentinel helps to monitor Redis instances, detect failures and will do roles switches automatically thus enabling a Redis deployment to resist any kind of failures.
It features monitoring of Redis instances (master and replicas), supports notification of other services/processes or the system administrator, automatic failover to promote a replica to a master when the master goes down and provides configuration for clients to discover the current master offering a particular service.
This Ansible role installs Redis on linux operating system, including establishing a filesystem structure and server configuration with some common operational features, Will works on the following operating systems:
- CentOS 7
The following list of supported the Redis releases:
- Redis 5, 6
There are some variables in defaults/main.yml which can (Or needs to) be overridden:
redis_version
: Specify the Redis version.redis_path
: Specify the Redis data directory.redis_authorization
: A boolean to determine whether or not to enable authentication.redis_requirepass
: Authorization clients password.redis_ssl
: A boolean to determine whether or not to Encrypting client and cluster communications.redis_cluster_name
: Cluster name of servers that implements distribution performance.redis_cluster_mode
: Defines type of cluster type: sentinel / standalone / cluster.redis_sentinel_authorization
: A boolean to determine whether or not to enable sentinel authentication.redis_sentinel_requirepass
: Sentinel authorization clients password.
redis_port
: Redis listen.redis_cluster_port
: Redis Cluster listen.redis_exporter_port
: Prometheus Redis exporter.redis_sentinel_port
: Redis sentinel listen.redis_sentinel_exporter_port
: Prometheus Redis Sentinel exporter.
redis_backupset_arg.keep
: Backup retention cycle in days.redis_backupset_arg.encryptkey
: BackupSet encryption key.redis_backupset_arg.cloud_rsync
: Whether rsync for cloud storage.redis_backupset_arg.cloud_drive
: Specify the cloud storage providers, azureblob / s3 for minio.redis_backupset_arg.cloud_bwlimit
: Controls the bandwidth limit.redis_backupset_arg.cloud_event
: Define transfer events.redis_backupset_arg.cloud_config
: Specify the cloud storage configuration.
redis_tcp_backlog
: TCP listen backlog.redis_timeout
: Client connection idle time in seconds.redis_tcp_keepalive
: Client keepalive time in seconds.redis_maxclients
: The max number of connected clients at the same time.redis_maxmemory
: A memory usage limit to the specified amount in MB.redis_maxmemory_policy
: How Redis will select what to remove when maxmemory is reached.redis_ulimit_nproc
: The number of processes launched by systemd.redis_ulimit_nofile
: The number of files launched by systemd.redis_renamed_commands
: Disabling of specific commands.
environments
: Define the service environment.datacenter
: Define the DataCenter.domain
: Define the Domain.customer
: Define the customer name.tags
: Define the service custom label.exporter_is_install
: Whether to install prometheus exporter.consul_public_register
: Whether register a exporter service with public consul client.consul_public_exporter_token
: Public Consul client ACL token.consul_public_http_prot
: The consul Hypertext Transfer Protocol.consul_public_clients
: List of public consul clients.consul_public_http_port
: The consul HTTP API port.
There are some variables in vars/main.yml:
redis_kernel_parameters
: Operating system variables.
- Ansible versions >= 2.8
- Python >= 2.7.5
Including an example of how to use your role (for instance, with variables passed in as parameters) is always nice for users too:
- hosts: all
roles:
- role: ansible-role-linux-redis
You can also use the group_vars or the host_vars files for setting the variables needed for this role. File you should change: group_vars/all or host_vars/group_name
.
redis_version: '5.0.14'
redis_path: '/data'
redis_authorization: true
redis_requirepass: 'changme'
redis_ssl: false
redis_cluster_name: 'cluster01'
redis_cluster_mode: 'standalone'
redis_port: '6379'
redis_cluster_port: "16379"
redis_exporter_port: '9121'
redis_sentinel_port: '26379'
redis_sentinel_exporter_port: '9355'
redis_backupset_arg:
keep: '7'
encryptkey: 'HgDEvnj5bfcq'
cloud_rsync: false
cloud_drive: 'azureblob'
cloud_bwlimit: '10M'
cloud_event: 'sync'
cloud_config:
account: 'blobuser'
key: 'base64encodedkey=='
endpoint: 'blob.core.chinacloudapi.cn'
redis_tcp_backlog: '16384'
redis_timeout: '300'
redis_tcp_keepalive: '60'
redis_maxclients: '10000'
redis_maxmemory: '1024'
redis_maxmemory_policy: "noeviction"
redis_ulimit_nproc: '65535'
redis_ulimit_nofile: '65535'
redis_renamed_commands:
- 'DEBUG'
- 'SHUTDOWN'
environments: 'prd'
datacenter: 'dc01'
domain: 'local'
customer: 'demo'
tags:
subscription: 'default'
owner: 'nobody'
department: 'Infrastructure'
organization: 'The Company'
region: 'China'
exporter_is_install: false
consul_public_register: false
consul_public_exporter_token: '00000000-0000-0000-0000-000000000000'
consul_public_http_prot: 'https'
consul_public_http_port: '8500'
consul_public_clients:
- '127.0.0.1'
Please send your suggestions to make this role better.
Please donate to the following monero address.
46CHVMbb6wQV2PJYEbahb353SYGqXhcdFQVEWdCnHb6JaR5125h3kNQ6bcqLye5G7UF7qz6xL9qHLDSAY3baagfmLZABz75