Escaneo de claves caducadas
Hay dos formas de eliminar una clave en Redis.
- Utilice el comando DEL para eliminar directamente una clave.
- Utilice comandos como EXPIRE para establecer un tiempo de espera en una clave. Después de que transcurra el tiempo de espera, la clave se vuelve inaccesible pero no se elimina inmediatamente porque Redis es principalmente de un solo subproceso. Redis utiliza las siguientes estrategias para liberar la memoria utilizada por las claves caducadas:
- Borrado libre perezoso: La estrategia de borrado se controla en el bucle principal de eventos de E/S. Antes de ejecutar una orden de lectura/escritura, se llama a una función para comprobar si la clave a la que se accede ha expirado. Si ha caducado, se eliminará y se devolverá una respuesta indicando que la clave no existe. Si la clave no ha caducado, se reanuda la ejecución del comando.
- Eliminación programada: Una función de evento de tiempo se ejecuta en ciertos intervalos. Cada vez que se ejecuta la función, se comprueba una colección aleatoria de claves y se eliminan las claves caducadas.
Para evitar bloqueos prolongados en el subproceso principal de Redis, no todas las claves se comprueban en cada evento de tiempo. En su lugar, una colección aleatoria de claves se comprueba cada vez. Como resultado, la memoria utilizada por las claves caducadas no se puede liberar rápidamente.
DCS integra estas estrategias y le permite liberar periódicamente la memoria utilizada por las claves caducadas. Puede configurar análisis programados en los nodos principals de sus instancias. Todo el espacio de claves se recorre durante las exploraciones, activando Redis para comprobar si las claves han caducado y para eliminar las claves caducadas si las hay.
Esta función solo es compatible con las instancias de DCS Redis 4.0 y 5.0.
Procedimiento
- Inicie sesión en la consola DCS..
- Haga clic en en la esquina superior izquierda de la consola de gestión y seleccione una región.
Seleccione la misma región que su servicio de aplicación.
- En el panel de navegación, elija Cache Manager.
- Haga clic en el nombre de una instancia de DCS Redis.
- Elija Analysis and Diagnosis > Cache Analysis.
- Haga clic en Expired Key Scan. Puede hacer clic en Start Scanning para escanear la instancia inmediatamente. También puede configurar una tarea programada para analizar automáticamente la instancia a la hora especificada.
- Después de enviar la tarea de escaneo de clave caducada, puede verla en la lista de tareas.
Figura 1 Tareas de escaneo de clave caducadas
- Ocurrió una excepción.
- El escaneo agotó el tiempo de espera porque hay demasiadas claves. En este caso, se han eliminado algunas claves.
Programación de Escaneos Automáticos
Para programar análisis automáticos, haga clic en junto a Scheduled. Defina los parámetros según sea necesario y haga clic en OK.
Tabla 1 describe los parámetros para programar escaneos automáticos.
Parámetro |
Descripción |
Rango de valores |
Valor predeterminado |
Notas |
---|---|---|---|---|
Start At |
El primer escaneo solo puede comenzar después de la hora actual. |
Formato: yyyy/MM/dd hh:mm:ss |
- |
- |
Interval |
Intervalo entre escaneos. |
0 a 43,200 (unidad: minuto) |
1440 |
|
Timeout |
Este parámetro se utiliza para evitar el tiempo de espera de análisis debido a razones desconocidas. Si el escaneo se agota debido a razones desconocidas, no se pueden ejecutar las tareas programadas posteriores. Después de que transcurra el tiempo de espera especificado, se devuelve un mensaje de error y se realizará el siguiente análisis. |
De 1 a 86,400 (unidad: minuto) |
2880 |
|
Keys to Iterate |
El comando SCAN se utiliza para iterar las claves de la base de datos actual. La opción COUNT se utiliza para permitir al usuario indicar al comando de iteración cuántos elementos deben devolverse del conjunto de datos en cada iteración. Para obtener más información, consulte la descripción del comando SCAN. La exploración iterativa puede reducir los riesgos de ralentizar Redis cuando se analizan un gran número de claves a la vez. |
De 10 a 1000 |
10 |
Por ejemplo, si hay 10 millones de claves en Redis y el número de claves a iterar se establece en 1000, se completará un análisis completo después de las iteraciones de 10,000. |
Rendimiento
- El comando SCAN se ejecuta en el plano de datos cada 5 ms, es decir, 200 veces por segundo. Si Keys to Iterate se establecen en 10, 100 o 1000, se analizan 2000, 20,000 o 200,000 claves por segundo.
- Cuanto mayor sea el número de claves escaneadas por segundo, mayor será el uso de la CPU.
Prueba de referencia
- Eliminación natural: los registros de 10,000 se eliminan por segundo. Se tarda 8 minutos en eliminar 5 millones de claves caducadas. El uso de la CPU es de aproximadamente 5%.
- Keys to Iterate configuradas en 10: El escaneo tarda 125 minutos (15 millones/2000/60 segundos) y el uso de la CPU es de aproximadamente 8%.
- Keys to Iterate establecidas en 100: El escaneo dura 12.5 minutos (15 millones/20,000/60 segundos) y el uso de CPU es de aproximadamente 20%.
- Keys to Iterate configuradas en 1000: El escaneo tarda 1.25 minutos (15 millones/200,000/60 segundos) y el uso de la CPU es de aproximadamente el 25%.
Sugerencias de configuración
- Puede configurar el número de claves que se escanearán y el intervalo de escaneo en función del número total de claves y el aumento del número de claves en la instancia.
- En la prueba de referencia con 15 millones de teclas y Keys to Iterate establecidas en 10, el escaneo dura aproximadamente 125 minutos. En este caso, ajuste el intervalo a más de 4 horas.
- Si desea acelerar el escaneo, establezca Keys to Iterate en 100. Se tarda aproximadamente 12.5 minutos en completar el escaneo. Por lo tanto, ajuste el intervalo a más de 30 minutos.
- Cuanto mayor sea el número de teclas a iterar, más rápido será el escaneo y mayor será el uso de la CPU. Hay una compensación entre el tiempo y el uso de la CPU.
- Si el número de claves caducadas no aumenta rápidamente, puede escanear las claves caducadas una vez al día.
Comience a escanear durante las horas no pico. Establezca el intervalo en un día y el tiempo de espera en dos días.