Docker 中安装单体架构 Redis 的 Shell 脚本

该脚本用于实现 root 用户在 Linux 操作系统下的 Docker 中安装单体架构 Redis

Shell 脚本 Git 仓库地址

Gitee:https://gitee.com/tongchaowei/common-shell/tree/main/root

执行脚本

bash ./docker-redis-install-single.sh

image.png

需要注意的

  • 该脚本会先检查是否安装了社区版 Docker,如果没有安装,则会退出脚本的执行,所以请先完成社区版 Docker 的安装
  • 该脚本会进行如下目录的映射:
    • /log: /var/log/redis:Redis 日志文件存放目录
    • /data:/var/lib/mysql,Redis 数据文件存放的目录
    • /conf/redis.conf:/etc/redis/redis.conf,Redis 配置文件
  • 该脚本启动容器时,会设置的参数如下:
    • --restart=always:跟随系统启动而自启
    • --privileged=true:容器具有 root 权限
    • redis-server /etc/redis/redis.conf:启动容器之后,运行 redis-server 命令,并指定 redis-server 命令读取的 Redis 配置文件的路径
  • 该脚本在启动 Redis 容器之前,会创建 Redis 日志文件 $home/log/redis-server.log,同时会修改日志文件权限为 777,防止容器中 Redis 无法访问和修改日志文件
  • 该脚本在启动 Redis 容器之前,会要求输入访问 Redis 服务时使用的密码,因为在后面的编写 Redis 配置文件时,会开启 Redis 服务的访问权限认证(设置客户端访问 Redis 服务时的密码)

Redis 配置文件

该脚本在启动 Redis 容器之前,编写的配置文件内容如下:

配置文件存放位置:$home/conf/redis.conf
$home:Docker 安装 Redis 相关映射目录和文件的家目录;
其中,有进行注释说明的配置项是我目前有使用到的配置,没有进行注释说明的配置项是在 Redis 默认配置文件中有进行配置的,我复制过来的;
Redis 配置文件配置项详细说明可以参考:https://www.yuque.com/u27599042/ckgabz/hpf8hyeui2fghcxx

################################## NETWORK #####################################
# 指定可以访问当前 Redis 服务的客户端 IP,为了使所有其它客户端都可访问,一般要将其注释掉
# bind 127.0.0.1 -::1
# 关闭保护模式,以确保其它客户端可以连接 Redis,否则只允许本机的客户端访问
protected-mode no
# Redis 服务监听端口号,默认 6379
port 6379
# TCP 连接的队列的长度,其主要用于解决高并发场景下客户端慢连接问题,生产环境下(特别是高并发场景下),backlog 的值最好要大一些
tcp-backlog 511
# 当客户端与 Redis 间的空闲时间超过该时长后,客户端和 Redis 服务器的连接会自动断开。单位秒。默认值为 0,表示永远不超时。
timeout 0
# 设置 Redis 检测与其连接的所有客户端的存活性时间间隔,单位秒,一般是在空闲超时 timeout 设置为 0 时进行配置。
tcp-keepalive 300
################################# GENERAL #####################################
# 配置 Redis 启动不采用守护进程方式,避免与 Docker 启动容器 -d(以守护进程执行) 选项发生冲突
daemonize no
# 指定 Redis 运行时 pid(Redis 进程 id)写入的文件
pidfile /var/run/redis_6379.pid
# 配置日志级别。notice:可以获取到在生产中想获取到的适当多的信息,默认级别。
loglevel notice
# 指定 Redis 运行日志记录的位置
logfile "/var/log/redis/redis-server.log"
# 设置数据库的数量
databases 16
# 只有在交互式会话中才会显示 Redis Logo,否则始终在启动日志中显示 Redis Logo。
always-show-logo no
set-proc-title yes
proc-title-template "{title} {listen-addr} {server-mode}"
locale-collate ""
################################ SNAPSHOTTING  ################################
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename dump.rdb
rdb-del-sync-files no
dir ./
################################# REPLICATION #################################
replica-serve-stale-data yes
replica-read-only yes
repl-diskless-sync yes
repl-diskless-sync-delay 5
repl-diskless-sync-max-replicas 0
repl-diskless-load disabled
repl-disable-tcp-nodelay no
replica-priority 100
################################## SECURITY ###################################
acllog-max-len 128
# 设置客户端访问 Redis 服务时的密码
requirepass $redis_pwd
############################# LAZY FREEING ####################################
lazyfree-lazy-eviction no
lazyfree-lazy-expire no
lazyfree-lazy-server-del no
replica-lazy-flush no
lazyfree-lazy-user-del no
lazyfree-lazy-user-flush no
############################ KERNEL OOM CONTROL ##############################
oom-score-adj no
oom-score-adj-values 0 200 800
disable-thp yes
appendonly no
appendfilename "appendonly.aof"
appenddirname "appendonlydir"
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 yes
aof-timestamp-enabled no
################################## SLOW LOG ###################################
slowlog-log-slower-than 10000
slowlog-max-len 128
################################ LATENCY MONITOR ##############################
latency-monitor-threshold 0
############################# EVENT NOTIFICATION ##############################
notify-keyspace-events ""
############################### ADVANCED CONFIG ###############################
hash-max-listpack-entries 512
hash-max-listpack-value 64
list-max-listpack-size -2
list-compress-depth 0
set-max-intset-entries 512
set-max-listpack-entries 128
set-max-listpack-value 64
zset-max-listpack-entries 128
zset-max-listpack-value 64
hll-sparse-max-bytes 3000
stream-node-max-bytes 4096
stream-node-max-entries 100
activerehashing yes
client-output-buffer-limit normal 0 0 0
client-output-buffer-limit replica 256mb 64mb 60
client-output-buffer-limit pubsub 32mb 8mb 60
hz 10
dynamic-hz yes
aof-rewrite-incremental-fsync yes
rdb-save-incremental-fsync yes
########################### ACTIVE DEFRAGMENTATION #######################
jemalloc-bg-thread yes

Shell 脚本源码

#!/bin/bash
# 该脚本用于实现 root 用户在 Linux 操作系统下的 Docker 中安装单体架构 Redis# 临时保存并修改语言环境
LANG_temp=$LANG
LANG=zh_CN.UTF-8# 还原语言环境
function re_lang () {# 将语言环境修改回原来的值LANG=$LANG_temp
}# 还原语言环境,并无异常退出
function re_lang_exit () {re_langexit 0
}function success_text () {echo -e -n "\033[32m【SUCCESS】\033[0m"echo $1
}function warn_text () {echo -e -n "\033[33m【WARN】\033[0m"echo $1
}function error_text () {echo -e -n "\033[31m【ERROR】\033[0m"echo $1
}function error_re_lang_exit () {echo -e -n "\033[31m【ERROR】\033[0m"echo $1re_lang_exit
}# 如果传入的目录不存在,进行目录的创建
function mkdir_404 () {if [ ! -d $1 ]; thenwarn_text "目录 $1 不存在,进行目录的创建..."mkdir -p $1 || error_re_lang_exit "目录 $1 创建失败"success_text "目录 $1 创建成功"elsesuccess_text "目录 $1 已存在,无需进行创建."fi
}# 检查是否安装了社区版 Docker
is_docker_ce_install=`rpm -q docker-ce | grep '未安装软件包.*'`
if [ ${#is_docker_ce_install} -gt 0 ]; thenerror_text '还未安装社区版 Docker,请先进行安装.'re_lang_exit
fi# 启动 Docker 并开启 Docker 开机自启,确保 Docker 处于运行状态
echo "Docker 启动中..."
systemctl start docker || re_lang_exit
echo "开启 Docker 开机自启中..."
systemctl enable docker || re_lang_exit# 要安装的软件
software=redis# 要进行安装的版本
version_default=latest
read -p "请输入要安装的 $software 版本(默认 $version_default):" version
if [ -z "$version" ]; thenversion=$version_default
fi# Docker 镜像名称及其版本
image_name=$software:$version# Docker 安装软件相关映射目录和文件的家目录
home_default=/home/docker/$software/$version
read -p "请输入 Docker 安装 $software 相关映射目录和文件的家目录(默认 $home_default):" home
if [ -z "$home" ]; thenhome=$home_default
fi# 需要进行映射的目录
map_dir=( /data /conf /log )# 目录如果不存在,进行目录的创建
mkdir_404 $home
read -p "是否删除原先存在的映射目录(y-确认删除):" -n 1 is_rm
echo
for (( i=0; i<${#map_dir[*]}; i++ )); doif [ "$is_rm" = "y" ]; then # 删除原先存在的映射目录rm -rf $home${map_dir[i]}warn_text "已删除 $home${map_dir[i]} 目录及其子目录和其中的文件"fimkdir_404 $home${map_dir[i]}
done# 访问密码
while true; doread -p "请输入 $software 服务的访问密码:" redis_pwdif [[ -n "${redis_pwd}" ]]; thenbreakfi
done# 编写配置文件
# 没有进行注释说明的配置项是我目前没有使用到的配置,从 Redis 默认配置文件中复制而来,
# 在 Redis 默认配置文件中有进行配置
echo "开始编写 $software 配置文件..."
tee $home/conf/$software.conf <<- EOF
################################## NETWORK #####################################
# 指定可以访问当前 Redis 服务的客户端 IP,为了使所有其它客户端都可访问,一般要将其注释掉
# bind 127.0.0.1 -::1
# 关闭保护模式,以确保其它客户端可以连接 Redis,否则只允许本机的客户端访问
protected-mode no
# Redis 服务监听端口号,默认 6379
port 6379
# TCP 连接的队列的长度,其主要用于解决高并发场景下客户端慢连接问题,生产环境下(特别是高并发场景下),backlog 的值最好要大一些
tcp-backlog 511
# 当客户端与 Redis 间的空闲时间超过该时长后,客户端和 Redis 服务器的连接会自动断开。单位秒。默认值为 0,表示永远不超时。
timeout 0
# 设置 Redis 检测与其连接的所有客户端的存活性时间间隔,单位秒,一般是在空闲超时 timeout 设置为 0 时进行配置。
tcp-keepalive 300
################################# GENERAL #####################################
# 配置 Redis 启动不采用守护进程方式,避免与 Docker 启动容器 -d(以守护进程执行) 选项发生冲突
daemonize no
# 指定 Redis 运行时 pid(Redis 进程 id)写入的文件
pidfile /var/run/redis_6379.pid
# 配置日志级别。notice:可以获取到在生产中想获取到的适当多的信息,默认级别。
loglevel notice
# 指定 Redis 运行日志记录的位置
logfile "/var/log/redis/redis-server.log"
# 设置数据库的数量
databases 16
# 只有在交互式会话中才会显示 Redis Logo,否则始终在启动日志中显示 Redis Logo。
always-show-logo no
set-proc-title yes
proc-title-template "{title} {listen-addr} {server-mode}"
locale-collate ""
################################ SNAPSHOTTING  ################################
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename dump.rdb
rdb-del-sync-files no
dir ./
################################# REPLICATION #################################
replica-serve-stale-data yes
replica-read-only yes
repl-diskless-sync yes
repl-diskless-sync-delay 5
repl-diskless-sync-max-replicas 0
repl-diskless-load disabled
repl-disable-tcp-nodelay no
replica-priority 100
################################## SECURITY ###################################
acllog-max-len 128
# 设置客户端访问 Redis 服务时的密码
requirepass $redis_pwd
############################# LAZY FREEING ####################################
lazyfree-lazy-eviction no
lazyfree-lazy-expire no
lazyfree-lazy-server-del no
replica-lazy-flush no
lazyfree-lazy-user-del no
lazyfree-lazy-user-flush no
############################ KERNEL OOM CONTROL ##############################
oom-score-adj no
oom-score-adj-values 0 200 800
disable-thp yes
appendonly no
appendfilename "appendonly.aof"
appenddirname "appendonlydir"
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 yes
aof-timestamp-enabled no
################################## SLOW LOG ###################################
slowlog-log-slower-than 10000
slowlog-max-len 128
################################ LATENCY MONITOR ##############################
latency-monitor-threshold 0
############################# EVENT NOTIFICATION ##############################
notify-keyspace-events ""
############################### ADVANCED CONFIG ###############################
hash-max-listpack-entries 512
hash-max-listpack-value 64
list-max-listpack-size -2
list-compress-depth 0
set-max-intset-entries 512
set-max-listpack-entries 128
set-max-listpack-value 64
zset-max-listpack-entries 128
zset-max-listpack-value 64
hll-sparse-max-bytes 3000
stream-node-max-bytes 4096
stream-node-max-entries 100
activerehashing yes
client-output-buffer-limit normal 0 0 0
client-output-buffer-limit replica 256mb 64mb 60
client-output-buffer-limit pubsub 32mb 8mb 60
hz 10
dynamic-hz yes
aof-rewrite-incremental-fsync yes
rdb-save-incremental-fsync yes
########################### ACTIVE DEFRAGMENTATION #######################
jemalloc-bg-thread yes
EOF# 如果配置文件编写失败
if [ $? -ne 0 ]; thenerror_re_lang_exit "编写 $software 配置文件失败"
elsesuccess_text "编写 $software 配置文件成功"
fi# 创建日志文件
echo "创建 $software 日志文件..."
touch $home/log/redis-server.log || error_re_lang_exit "创建 $software 日志文件失败"
success_text "创建 $software 日志文件成功"
# 修改日志文件权限,防止容器无法访问和修改日志文件
echo "修改 $software 日志文件权限为 777..."
chmod 777 $home/log/redis-server.log || error_re_lang_exit "修改 $software 日志文件权限为 777 失败"
success_text "修改 $software 日志文件权限为 777 成功."# 查询 Docker 中是否存在指定镜像,如果不存在,则进行镜像的拉取
image=`docker images -a | grep "$software" | grep "$version"`
if [ -z "$image" ]; thenwarn_text "Docker 中不存在 $image_name 镜像"echo "开始拉取镜像 $image_name..."docker pull $image_name || re_lang_exitsuccess_text "拉取 $image_name 镜像成功"
elsesuccess_text "镜像 $image_name 已存在,无需进行拉取"
fi# 容器名称
container_name=$software$version# 判断容器是否存在,如果存在,手动输入指定容器名称
while true; doif [ ! -z "`docker ps -a | grep \"$container_name\"`" ]; thenerror_text "名称为 $container_name 的 Docker 容器已经存在"read -p "请输入新 Docker 容器名称:" container_nameelseif [ -z "$container_name" ]; thenerror_text "Docker 容器名称不能为空."read -p "请输入新 Docker 容器名称:" container_namecontinuefibreakfi
done# 容器运行时的端口,即容器的端口映射
port_default=6379
while true; doread -p "请输入容器运行映射的端口号(默认 $port_default):" portif [ -z "$port" ]; thenport=$port_defaultfi# 判断端口是否被占用if [ ! -z "`lsof -i:$port`" ]; thenerror_text "端口 $port 已经被占用,请选择未被占用的端口号."elsebreakfi
done# 运行容器
docker run \
--privileged=true \
--restart=always \
-p $port:6379 \
--name $container_name \
-v $home/conf/redis.conf:/etc/redis/redis.conf \
-v $home/data:/data \
-v $home/log:/var/log/redis \
-d $image_name \
redis-server /etc/redis/redis.conf \
|| error_re_lang_exit "$software 容器启动运行失败"success_text "$software 容器启动运行成功."
echo "$software 容器运行情况如下:"
docker ps -f name=$container_name# 还原语言环境
re_lang

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/4993.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数学建模--图论最短路径基础

1.图的定义 学过数据结构或者离散数学的小伙伴们应该知道图的概念&#xff0c;我在这里简单的介绍一下&#xff1a; 图的概念和我们理解的是很不一样的&#xff0c;这里的图并不是我们的生活里面的图片&#xff0c;而是一种表示不同的数据之间的关系&#xff0c;例如这里的5个…

C++中auto关键字的用法详解

1.简介 auto作为一个C语言就存在的关键字&#xff0c;在C语言和C之间却有很大区别。 在C语言中auto修饰的变量&#xff0c;是具有自动存储器的局部变量&#xff0c;但因为局部变量默认类别默认是auto修饰导致一直没有人去使用它。 C11中&#xff0c;标准委员会赋予了auto全新…

XY_RE复现(二)

一&#xff0c;何须相思煮余年 0x55 0x8b 0xec 0x81 0xec 0xa8 0x0 0x0 0x0 0xa1 0x0 0x40 0x41 0x0 0x33 0xc5 0x89 0x45 0xfc 0x68 0x9c 0x0 0x0 0x0 0x6a 0x0 0x8d 0x85 0x60 0xff 0xff 0xff 0x50 0xe8 0x7a 0xc 0x0 0x0 0x83 0xc4…

【智能算法】火烈鸟搜索算法(FSA)原理及实现

目录 1.背景2.算法原理2.1算法思想2.2算法过程 3.结果展示4.参考文献 1.背景 2021年&#xff0c;W Zhiheng等人受到火烈鸟迁徙觅食行为启发&#xff0c;提出了火烈鸟搜索算法&#xff08;Flamingo Search Algorithm, FSA&#xff09;。 2.算法原理 2.1算法思想 FSA受到火烈鸟…

C++|STL简介-string-vector基础运用

目录 什么是STL STL里面有什么 容器 string 序列式容器 vector deque list 关联式容器 set multiset map multimap 算法 非可变序列算法 可变序列算法 排序算法 数值算法 什么是STL STL(标准模板库)&#xff1a;是C标准库的重要组成部分&#xff0c;不仅是一…

MVC架构简述

MVC简介 MVC 是一种非常常见且常用的分层架构&#xff0c;主要包括&#xff1b;M - mode 对象层&#xff0c;封装到 domain 里。V - view 展示层&#xff0c;但因为目前都是前后端分离的项目&#xff0c;几乎不会在后端项目里写 JSP 文件了。C - Controller 控制层&#xff0c…

站群SEO优化策略及其遭遇DDoS攻击时的应对方法

一、站群SEO优化策略 站群优化主要是指通过合理布局和内容优化提升一系列网站在搜索引擎中的整体排名表现。以下是一些关键步骤与相关代码示例&#xff08;以WordPress为例&#xff09;&#xff1a; 差异化内容建设&#xff1a; 每个站点的内容必须具有独立性和价值性&#x…

CSS-vminvmax单位

vmin 和 vmax 单位 vmin 是相对于视口宽度和高度中较小值进行计算&#xff0c;它的值为视口宽度和高度中的较小值的百分比。 例如&#xff0c;如果视口宽度为 800px&#xff0c;高度为 1000px&#xff0c;那么 1vmin 等于 8px&#xff08;800px 的 1%&#xff09;。 vmax 是…

【Unity基础】TextMeshPro组件学习过程记录

目录 1.TextMeshPro组件渲染创建文本RTL Editor字体Font Asset字体加粗&#xff0c;下划线等字体大小控制字体颜色控制字体渐变控制字符间隔、单词间隔、行间距、段落间距控制WrappingUV映射控制代码 2.TextMeshPro组件AssetFace InfoGeneration Setting 3.使用Dynamic SDF Sys…

【可视化3D卷积计算过程】

目录 1. 可视化过程2. 代码验证 前言&#xff1a;开始处理视频数据&#xff0c;遇到了陌生又熟悉的3D卷积&#xff0c;但对其计算过程有点疑惑&#xff0c;网上也没找到什么可视化动画&#xff0c;所以研究明白并做个记录&#xff0c;方便日后复习。有点简化&#xff0c;但认真…

基于FCN网络实现的多类别图像分割任务

1、前言 FCN 作为图像分割的开山之作&#xff0c;将分割任务作为逐个像素点的分类任务 之前完成了基于unet、resnetunet、deeplab等等网络的分割任务&#xff0c;具体的可以参考本专栏&#xff1a; 图像分割_听风吹等浪起的博客-CSDN博客 因为FCN网络的实现较为复杂&#xf…

杰发科技AC7840——CAN通信简介(7)_波形分析

参考&#xff1a; CAN总线协议_stm32_mustfeng-GitCode 开源社区 0. 简介 隐形和显性波形 整帧数据表示 1. 字节描述 CAN数据帧标准格式域段域段名位宽&#xff1a;bit描述帧起始SOF(Start Of Frame)1数据帧起始标志&#xff0c;固定为1bit显性(b0)仲裁段dentify(ID)11本数…

网安行业拐点!网络安全6大企业2023年报盘点

回顾2023&#xff1a;寒冬中的市场概览 2023年&#xff0c;网络安全行业经历了前所未有的挑战。全球经济波动与行业竞争加剧&#xff0c;加之下游客户预算收紧&#xff0c;招投标流程延长&#xff0c;使得整个行业感受到了冬日的严寒。裁员和不发年终奖金的决定在行业中成为普…

记录些RAG-Fusion、Agent、NL2SQL的问题

RAG-Fusion RAG-Fusion 的实现原理 Query Duplication with a Twist&#xff1a;用 LLM 根据用户的 Query 生成几个相关的但不同的 Queries。Vector Search Unleashed&#xff1a;对原 Query 和生成的 Queries 都进行向量&#xff08;或者其他方式的&#xff09;搜索。Intell…

DiffusionGAN ——最快的小波扩散模型应用研究

介绍 扩散模型最近出现并迅速发展&#xff0c;吸引了许多研究人员的兴趣。这些模型能从随机的噪声输入生成高质量的图像。在图像生成任务中&#xff0c;它们的表现尤其优于最先进的生成模型&#xff08;GANs&#xff09;。扩散模型可以灵活地处理各种条件输入&#xff0c;从而…

meterpreter运行run getgui -e报错

meterpreter运行run getgui -e报错 meterpreter > run getgui -e [!] Meterpreter scripts are deprecated. Try post/windows/manage/enable_rdp. [!] Example: run post/windows/manage/enable_rdp OPTIONvalue [...] [-] The specified meterpreter session script cou…

【C++第三阶段】list容器排序

以下内容仅为当前认识&#xff0c;可能有不足之处&#xff0c;欢迎讨论&#xff01; 文章目录 构造函数赋值和交换大小操作插入和删除数据存取反转和排序排序案例 list容器在STL中是双向循环链表。 如图所示&#xff0c;每一个节点三个域&#xff0c;前向指针域&#xff0c;后…

用户中心(上)

文章目录 企业做项目流程需求分析技术选型计划初始化项目数据库设计登录/注册⽤户管理&#xff08;仅管理员可⻅&#xff09; 初始化项目⼀、前端初始化1.下载nodejs2.Ant Design Pro相关问题1.前端项目启动时报错、无法启动&#xff1f;2.如何初始化前端项目&#xff1f;为什么…

vue 模板字符串

1.模板字符串换行问题 white-space: pre-wrap; 2. 鼠标移入 显示提示框 点击手动隐藏 myChart.on("mouseover", function (params) {myChart.dispatchAction({type: "downplay",}); }); tooltip: {show: true, //是否显示提示框组件&#xff0c;包括…

机器人实验室CNRS-AIST JRL, IRL介绍

一、背景 作为搞机器人方向的学生&#xff0c;必须时常关注国际上顶尖实验室的研究成果&#xff0c;以免自己做的方向out&#xff0c;除了大家耳熟能详的Boston Dynamics&#xff0c;还有许多非常厉害的机器人实验室值得我们关注&#xff0c;如日本的CNRS-AIST JRL, IRL实验室…