Maison >base de données >Redis >Comment installer et configurer Redis dans CentOS7
Installation
Décompressez et entrez dans le répertoire tar xzf redis-4.0.12.tar.gz code>、<code>cd redis-4.0.12/
;tar xzf redis-4.0.12.tar.gz
、cd redis-4.0.12/
;
编译到指定目录 make prefix=/usr/local/redis install
创建 /usr/local/redis/ect
目录,将 redis.conf
复制过来
/usr/local/redis
目录结构如下
将 redis 添加系统服务,执行 vim /usr/lib/systemd/system/redis-server.service
,内容如下
[unit] description=the redis-server process manager after=syslog.target network.target [service] type=simple pidfile=/var/run/redis.pid execstart=/usr/local/redis/bin/redis-server /usr/local/redis/etc/redis.conf execreload=/bin/kill -s hup $mainpid execstop=/bin/kill -s quit $mainpid [install] wantedby=multi-user.target
开启服务 systemctl start redis-server
设置为开机启动 systemctl enable redis-server
测试,使用 redis-cli
测试看下
修改 redis 配置
修改数据保存路径,新建 /usr/local/redis/data
目录,设置 dir
为 这个路径;
rdb 和 aof 持久化
默认的 rdb 是 save 900 1 save 300 10 save 60 10000
,即 900 秒 1 次更改、300 秒 10 次更改、60 秒 10000 次更改,满足上述任一条件即可,使用默认值;
aof 是默认关闭的,修改 appendonly
为 yes
。更新条件有三种选择,是 always
表示每次更新操作后手动调用fsync()将数据写到磁盘(慢,安全)、everysec
表示每秒同步一次(折中,默认值)、no
表示等操作系统进行数据缓存同步到磁盘(快),使用默认值就好了;
二者是可以同时使用的,其它的相关配置就使用默认值了。
修改数据淘汰策略
最大占用内存 maxmemory
默认是注释的,设置为 512m,注意单位是 bytes ,所以值为 536870912;
redis 共提供了 6 种超值后的数据淘汰策略,分别是
volatile-lru:从设置了过期时间的数据集中,选择最近最久未使用的数据释放;
allkeys-lru:从数据集中(包括设置过期时间以及未设置过期时间的数据集中),选择最近最久未使用的数据释放;
volatile-random:从设置了过期时间的数据集中,随机选择一个数据进行释放;
allkeys-random:从数据集中(包括了设置过期时间以及未设置过期时间)随机选择一个数据进行入释放;
volatile-ttl:从设置了过期时间的数据集中,选择马上就要过期的数据进行释放操作;
noeviction:不删除任意数据(但redis还会根据引用计数器进行释放),这时如果内存不够时,会直接返回错误。
这里设置 maxmemory-policy
为 volatile-lru
。
其它配置保持默认值,后续根据需求进行修改。记得修改完成后重启服务 systemctl restart redis-server
make prefix=/usr/local/ redis install
Créez le répertoire /usr/local/redis/ect
et copiez redis.conf
#🎜🎜##🎜 🎜##🎜🎜## 🎜🎜# /usr/local/redis
La structure des répertoires est la suivante#🎜🎜##🎜🎜##🎜🎜##🎜🎜#Ajoutez Redis au service système et exécutez vim /usr/lib/systemd/ system/redis-server.service
, le contenu est le suivant #🎜🎜#rrreee#🎜🎜#Démarrer le service systemctl start redis-server
#🎜🎜##🎜🎜##🎜🎜##🎜🎜# Configurer pour démarrer au démarrage systemctl activer redis-server
# 🎜🎜##🎜🎜#Test, utilisez redis-cli
pour tester et voir#🎜🎜##🎜🎜# #🎜🎜##🎜🎜 ##🎜🎜#Modifier la configuration de Redis#🎜🎜##🎜🎜##🎜🎜##🎜 🎜##🎜🎜#Modifier le chemin de sauvegarde des données, créer un nouveau /usr/local/redis/data code> et définissez <code>dir
sur ce chemin #🎜🎜# #🎜🎜##🎜🎜#rdb et aof persistence#🎜🎜# #🎜🎜#Le rdb par défaut est save 900 1 save 300 10 save 60 10000
, c'est-à-dire 1 changement en 900 secondes, 10 changements en 300 secondes et 10 000 changements en 60 secondes, le cas échéant. les conditions ci-dessus sont remplies, utilisez la valeur par défaut ;appendonly
est oui
. Il existe trois options pour les conditions de mise à jour, toujours
signifie appeler manuellement fsync() pour écrire des données sur le disque après chaque opération de mise à jour (lent, sûr), everysec
signifie synchroniser une fois par seconde (compromis, valeur par défaut), non
signifie attendre que le système d'exploitation synchronise le cache de données sur le disque (rapide), utilisez simplement la valeur par défaut ;maxmemory
est commentée par défaut et est fixée à 512m, payez attention à l'unité est en octets, donc la valeur est 536870912 ;volatile-lru : À partir de l'ensemble de données avec un délai d'expiration défini , sélectionnez la version la plus récente et les données inutilisées les plus récemment ;#🎜🎜#Ici, définissez
allkeys-lru : à partir de l'ensemble de données (y compris les ensembles de données avec délai d'expiration défini et les ensembles de données sans délai d'expiration défini), sélectionnez la version de données la plus récente et la plus inutilisée. ;
volatile-random : sélection aléatoire d'un élément de données à publier dans l'ensemble de données avec un délai d'expiration défini ;
allkeys-random : sélection aléatoire d'un élément de données dans l'ensemble de données (y compris le délai d'expiration défini) et délai d'expiration non défini) pour la libération ;
volatile-ttl : à partir de l'ensemble de données avec un délai d'expiration défini, sélectionnez les données qui sont sur le point d'expirer pour l'opération de libération ;
noeviction : ne supprimez aucune donnée (mais redis le publiera également en fonction du compteur de référence). À ce moment, s'il n'y a pas assez de mémoire, une erreur sera renvoyée directement.
maxmemory-policy
sur volatile-lru
. #🎜🎜##🎜🎜#Les autres configurations restent aux valeurs par défaut et seront modifiées selon les besoins. N'oubliez pas de redémarrer le service systemctl restart redis-server
une fois la modification terminée. #🎜🎜#Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!