centos8上redis5在生产环境的配置
一,创建redis的数据和日志目录:
[root@yjweb data]# mkdir /data/redis6379
[root@yjweb data]# mkdir /data/redis6379/data
[root@yjweb data]# mkdir /data/redis6379/log
说明:刘宏缔的架构森林是一个专注架构的博客,地址:https://www.cnblogs.com/architectforest
对应的源码可以访问这里获取: https://github.com/liuhongdi/
说明:作者:刘宏缔 邮箱: 371125307@qq.com
二,redis运行环境的linux配置
1,设置系统中每个端口的监听队列的最大的长度
[root@yjweb log]# sysctl -a | grep somaxconn
net.core.somaxconn = 128
我们修改为大于redis中的TCP backlog值
说明:redis中的TCP backlog值默认是511
tcp-backlog 511
[root@yjweb log]# vi /etc/sysctl.conf
增加一行:
net.core.somaxconn = 1024
使配置起作用:
[root@yjweb log]# sysctl -p
说明:
sysctl命令用来显示和配置内核运行时参数
-a:显示所有的配置参数
-p:从/etc/sysctl.conf加载配置
参见:
[root@yjweb log]# man sysctl
2,配置overcommit_memory
说明:内核参数overcommit_memory
它是 内存分配策略
有三个值可用:0、1、2。
0, 表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程。
1, 表示内核允许分配所有的物理内存,而不管当前的内存状态如何。
2, 表示内核允许分配超过所有物理内存和交换空间总和的内存
这里面,2这种策略不够安全,
0有可能发生申请失败的情况
redis建议我们采用1的策略
编辑内核参数配置文件
[root@yjweb log]# vi /etc/sysctl.conf
增加一行:
vm.overcommit_memory=1
使配置起作用:
[root@yjweb log]# sysctl -p
检查是否生效
[root@yjweb log]# sysctl -a | grep overcommit_memory
vm.overcommit_memory = 1
说明;此处注意给redis分配的内存大小
maxmemory的值不要超过物理内存的四分之三,
否则有可能引发系统内存不足
3,关闭Transparent Huge Pages(THP)
[root@localhost ~]# cat /sys/kernel/mm/transparent_hugepage/enabled
[always] madvise never
说明:透明大页内存管理会影响数据的访问速度,可以关闭
关闭方法:
[root@yjweb log]# echo never > /sys/kernel/mm/transparent_hugepage/enabled
[root@yjweb log]# cat /sys/kernel/mm/transparent_hugepage/enabled
always madvise [never]
成功了,为了保证开机重启后还能自动写入配置,
参见这一篇:
centos8下启用rc-local服务
地址:https://www.cnblogs.com/architectforest/p/12467474.html
二,修改配置文件redis.conf
[root@yjweb conf]# vi /usr/local/soft/redis5/conf/redis.conf
内容:
1,指定监听的本地ip
bind 10.51.136.133
说明:如果bind 127.0.0.1 则只能从本机访问。
请确认是否只从本机访问redis,
否则建议设置为可以从网络访问的地址
2,保护模式:
protected-mode yes
说明:
protected-mode 会在没有设置 bind 和 密码时起作用,
建议protected-mode设置为yes
3,指定端口号
port 6379
说明:
如果在同一台机器上运行多个redis实例,各个实例的端口要区分开
4,指定密码:
requirepass demopassword
说明:安全起见,此处应该指定一个有复杂度的密码
5,指定以daemon方式运行
daemonize yes
6,loglevel : 保持值为notice即可:
loglevel notice
说明:
# This can be one of:
# debug (a lot of information, useful for development/testing)
# verbose (many rarely useful info, but not a mess like the debug level)
# notice (moderately verbose, what you want in production probably)
# warning (only very important / critical messages are logged)
7,logfile 指定日志文件路径
logfile "/data/redis6379/log/redis.log"
使用上面创建的路径
8,指定数据文件的路径
dir /data/redis6379/data/
说明:此处的值只能是一个目录
9,使用的最大内存容量
maxmemory 128MB
10,最大并发连接数
maxclients 10000
不建议修改,注意这个值应该在ulimit -n 返回的值以内
ulimit -n 显示的是linux系统里单用户打开文件描述符的最大值
11,slowlog的时长:
# The following time is expressed in microseconds, so 1000000 is equivalent
# to one second. Note that a negative number disables the slow log, while
# a value of zero forces the logging of every command. slowlog-log-slower-than 10000
说明:这个值的单位是微秒,
默认值10000即10毫秒
注意不要设置为0,因为它会记录所有命令
12,slowlog的最大记录数
# There is no limit to this length. Just be aware that it will consume memory.
# You can reclaim memory used by the slow log with SLOWLOG RESET. slowlog-max-len 512
说明:默认值是128,
我们适当加大,这个值也可以从命令行中动态配置
例子:
127.0.0.1:6379> config set slowlog-max-len 1024
OK
说明:如何把动态配置的参数写入到配置文件当中?
127.0.0.1:6379> config rewrite
OK
修改完成后重启:
[root@yjweb conf]# systemctl stop redis
[root@yjweb conf]# systemctl start redis
四,如何查看redis的慢查询日志?
1,当前的慢查询日志共多少条?
10.51.136.133:6379> slowlog len
(integer) 128
2,显示两条慢查询日志
10.51.136.133:6379> slowlog get 3
1) 1) (integer) 709
2) (integer) 1545732832
3) (integer) 13846
4) 1) "HGETALL"
2) "promotion_goods_detail"
说明:
第一个值:#日志的唯一标识符
第二个值:#命令执行是的UNIX时间戳
第三个值:#命令执行的时长,单位微妙
第四个值:#执行的命令及命令参数
3,清除所有的slowlog
127.0.0.1:6379> slowlog reset
五,查看redis的版本
[root@yjweb ~]$ /usr/local/soft/redis5/bin/redis-server --version
Redis server v=5.0.7 sha=00000000:0 malloc=libc bits=64 build=7abb9ee9ee0ce29b
六,查看centos的版本
[root@yjweb ~]$ cat /etc/redhat-release
CentOS Linux release 8.0.1905 (Core)
centos8上redis5在生产环境的配置的更多相关文章
- 分离Webpack开发环境与生产环境的配置
这是Webpack+React系列配置过程记录的第五篇.其他内容请参考: 第一篇:使用webpack.babel.react.antdesign配置单页面应用开发环境 第二篇:使用react-rout ...
- 【Spring】使用@Profile注解实现开发、测试和生产环境的配置和切换,看完这篇我彻底会了!!
写在前面 在实际的企业开发环境中,往往都会将环境分为:开发环境.测试环境和生产环境,而每个环境基本上都是互相隔离的,也就是说,开发环境.测试环境和生产环境是互不相通的.在以前的开发过程中,如果开发人员 ...
- Yarn 生产环境核心配置参数
目录 Yarn 生产环境核心配置参数 ResourceManager NodeManager Container Yarn 生产环境核心配置参数 ResourceManager 配置调度器 yarn. ...
- Spring.profile实现开发、测试和生产环境的配置和切换
软件开发过程一般涉及“开发 -> 测试 -> 部署上线”多个阶段,每个阶段的环境的配置参数会有不同,如数据源,文件路径等.为避免每次切换环境时都要进行参数配置等繁琐的操作,可以通过spri ...
- vue-cli 3.0 axios 跨域请求代理配置及生产环境 baseUrl 配置
1. 开发环境跨域配置 在 vue.config.js 文件中: module.exports = { runtimeCompiler: true, publicPath: '/', // 设置打包文 ...
- IDEA开发、测试、生产环境pom配置及使用
pom文件 一般放在最下面,project里 <!--开发环境.测试环境.生产环境--> <!--生产环境--> <profiles> <profile> ...
- [转]Docker 生产环境之配置容器 - 限制容器资源
默认情况下,容器没有资源限制,可以使用主机内核调度程序允许的给定资源.Docker 提供了一些方法来控制容器可以使用多少内存.CPU 或块 IO,并设置 docker run 命令的运行时配置标志.本 ...
- django+vue+nginx生产环境部署配置
部署环境: 1. linux redhat 7.1 2.python 3.6.3 3. vue 4. nginx 5. gunicorn 6. supervisord 安装: 一. 基础环境安装 1. ...
- elasticsearch7.5.0+kibana-7.5.0+cerebro-0.8.5集群生产环境安装配置及通过elasticsearch-migration工具做新老集群数据迁移
一.服务器准备 目前有两台128G内存服务器,故准备每台启动两个es实例,再加一台虚机,共五个节点,保证down一台服务器两个节点数据不受影响. 二.系统初始化 参见我上一篇kafka系统初始化:ht ...
随机推荐
- Scrapy框架的架构原理解析
爬虫框架--Scrapy 如果你对爬虫的基础知识有了一定了解的话,那么是时候该了解一下爬虫框架了.那么为什么要使用爬虫框架? 学习框架的根本是学习一种编程思想,而不应该仅仅局限于是如何使用它.从了解到 ...
- LVM最佳实践
LVM逻辑卷管理器 LVM概念 在Linux中,逻辑卷管理器(Logical Volume Manager, LVM)是为Linux内核提供逻辑卷管理的设备映射器目标.大多数现代Linux发行版都能够 ...
- jmeter中接口测试出现乱码或不识别中文解决办法
在查看结果是中出现乱码时:jmeter的bin目录下的jmeter.properties下最下面添加sampleresult.default.encoding=UTF-8后重新打开工具就好了 在接口的 ...
- oracle之insert语句总结
insert语句总结 16.1 第一类,insert语句:单行插入 1)SQL> create table a (id int,name char(10) default 'aaa'); / ...
- [LeetCode]26. 删除排序数组中的重复项(数组,双指针)
题目 给定一个排序数组,你需要在 原地 删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度. 不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下 ...
- 摆书 book
题目描述: dxy家收藏了一套书,这套书叫<SDOI故事集>,<SDOI故事集>有n(n≤19)本,每本书有一个编号,从1号到n号. dxy把这些书按编号从小到大,从上往下摞成 ...
- Combine 框架,从0到1 —— 4.在 Combine 中使用 KVO
本文首发于 Ficow Shen's Blog,原文地址: Combine 框架,从0到1 -- 4.在 Combine 中使用 KVO. 内容概览 前言 用 KVO 监控改动 将 KVO 代 ...
- 基于Ant Design Vue封装一个表单控件
开源代码 https://github.com/naturefwvue/nf-vue3-ant 有缺点本来是写在最后的,但是博文写的似乎有点太长了,估计大家没时间往下看,于是就把有缺点写在前面了,不喜 ...
- J.U.C之ReentrantLock 可重入锁
* A reentrant mutual exclusion {@link Lock} with the same basic * behavior and semantics as the impl ...
- 运行时数据区--程序计数器(PC Register)
程序计数器(PC Register) 这里的计数器(Program Counter Register)并非为广义上所指的物理寄存器,JVM中的PC寄存器(程序计数器)是对物理PC寄存器的一种抽象模拟, ...