Bibliotecas cliente de Azure Managed Redis (versión preliminar)
Azure Managed Redis (versión preliminar) se basa en el popular almacén de datos en memoria, Redis. Se puede acceder mediante una amplia variedad de clientes de Redis para muchos lenguajes de programación. Cada biblioteca cliente tiene su propia API que realiza llamadas al servidor de Redis mediante comandos de Redis, pero las bibliotecas cliente se compilan para comunicarse con cualquier servidor de Redis.
Cada biblioteca cliente mantiene su propia documentación de referencia. Las bibliotecas también proporcionan vínculos para obtener soporte técnico a través de la comunidad de desarrolladores de la biblioteca cliente. El equipo de Azure Managed Redis no posee el desarrollo ni la compatibilidad con ninguna biblioteca cliente.
Las recomendaciones siguientes se basan en la popularidad y si hay una comunidad en línea activa para apoyar y responder a sus preguntas. Solo se recomienda usar la versión disponible más reciente y actualizar periódicamente a medida que estén disponibles nuevas versiones. Estas bibliotecas están en desarrollo activo y, a menudo, publican nuevas versiones con mejoras en la confiabilidad y el rendimiento.
Biblioteca cliente | Lenguaje | Repositorio de GitHub | Documentación |
---|---|---|---|
StackExchange.Redis | C#/.NET | Vínculo | Más información aquí |
Lettuce | Java | Vínculo | Más información aquí |
Jedis | Java | Vínculo | |
node_redis | Node.js | Vínculo | |
Redisson | Java | Vínculo | Más información aquí |
ioredis | Node.js | Vínculo | Más información aquí |
Nota:
La aplicación puede usar cualquier biblioteca cliente compatible con Redis de código abierto para conectarse a la instancia de Azure Managed Redis.
Elección de la biblioteca cliente adecuada en función de la directiva de agrupación en clústeres
Azure Managed Redis admite la directiva de agrupación en clústeres enterprise y la directiva de agrupación en clústeres de OSS. Consulte más información aquí (agregue un vínculo a la información de directiva de agrupación en clústeres). Todas las bibliotecas cliente funcionan con la instancia de Redis con la directiva de agrupación en clústeres enterprise. Sin embargo, si usa la directiva de agrupación en clústeres de OSS, asegúrese de que la biblioteca cliente que elija admite la conexión a instancias de Redis en clúster.
Comandos bloqueados
Microsoft administra la configuración y la administración de instancias de Azure Managed Redis, lo que deshabilita los comandos siguientes de manera predeterminada. Para obtener más información sobre los comandos bloqueados, consulte Compatibilidad de comandos de administración de clústeres
Comandos de varias claves
Dado que las instancias AMR usan una configuración en clúster, es posible que vea excepciones CROSSSLOT
en comandos que funcionan en varias claves. El comportamiento varía en función de la directiva de agrupación en clústeres utilizada. Si usa la directiva de agrupación en clústeres de OSS, los comandos de varias claves requieren que todas las claves se asignen a la misma ranura hash.
También puede ver errores CROSSSLOT
con la directiva de agrupación en clústeres Enterprise. Solo se permiten los siguientes comandos de varias claves entre ranuras con clústeres Enterprise: DEL
, MSET
, MGET
, EXISTS
, UNLINK
y TOUCH
.
En bases de datos Activa-activa, los comandos de escritura de varias claves (DEL
, MSET
y UNLINK
) solo se podrán ejecutar en las claves que estén en la misma ranura. Sin embargo, se permiten los siguientes comandos de varias claves entre ranuras de bases de datos Activa-activa: MGET
, EXISTS
y TOUCH
. Para obtener más información, consulte Agrupación en clústeres de base de datos.
Comandos bloqueados para la directiva de agrupación en clústeres enterprise
- CLUSTER INFO
- CLUSTER HELP
- CLUSTER KEYSLOT
- CLUSTER NODES
- CLUSTER SLOTS
Comandos bloqueados para la replicación geográfica activa
- FLUSHALL
- FLUSHDB
Guía específica de bibliotecas cliente
Para obtener información sobre los procedimientos recomendados específicos de la biblioteca cliente, consulte los vínculos siguientes:
- StackExchange.Redis (.NET)
- Java: ¿Qué cliente debo usar?
- Lettuce (Java)
- Jedis (Java)
- Redisson (Java)
- Node.js
- PHP
- HiRedisCluster
- Proveedor de estado de sesión de ASP.NET
Redisson (Java)
Se recomienda usar Redisson 3.14.1 o una versión superior. Las versiones anteriores contienen problemas conocidos de pérdida de conexión que causan problemas después de las conmutaciones por error. Supervise el registro de cambios de Redisson para ver otros problemas conocidos que pueden afectar a las características usadas por la aplicación. Para más información, consulte CHANGELOG
y las preguntas más frecuentes de Redisson.
Otras notas:
- Redisson adopta de forma predeterminada la estrategia de "lectura de réplica", a diferencia de otros clientes. Para cambiar esto, modifique el valor de configuración "readMode".
- Redisson cuenta con una estrategia de agrupación de conexiones con valores mínimos y máximos configurables, y los valores mínimos predeterminados son grandes. Los valores predeterminados grandes podrían contribuir a comportamientos de reconexión agresivos o "tormentas de conexión". Para reducir el riesgo, considere la posibilidad de usar menos conexiones, dado que puede canalizar eficazmente comandos o lotes de comandos por unas pocas conexiones.
- Redisson tiene un tiempo de espera de conexión de inactividad predeterminado de 10 segundos, lo que lleva a que se cierren y abran conexiones con una mayor frecuencia de lo que sería recomendable.
Esta es una configuración de línea de base recomendada para el modo de clúster que puede modificar según sea necesario:
clusterServersConfig:
idleConnectionTimeout: 30000
connectTimeout: 15000
timeout: 5000
retryAttempts: 3
retryInterval: 3000
checkLockSyncedSlaves: false
failedSlaveReconnectionInterval: 15000
failedSlaveCheckInterval: 60000
subscriptionsPerConnection: 5
clientName: "redisson"
loadBalancer: !<org.redisson.connection.balancer.RoundRobinLoadBalancer> {}
subscriptionConnectionMinimumIdleSize: 1
subscriptionConnectionPoolSize: 50
slaveConnectionMinimumIdleSize: 2
slaveConnectionPoolSize: 24
masterConnectionMinimumIdleSize: 2
masterConnectionPoolSize: 24
readMode: "MASTER"
subscriptionMode: "MASTER"
nodeAddresses:
- "redis://mycacheaddress:10000"
scanInterval: 1000
pingConnectionInterval: 60000
keepAlive: false
tcpNoDelay: true
Para ver un artículo en el que se muestra cómo usar la compatibilidad de Redisson con JCache como almacén para el estado de sesión HTTP en Azure, consulte Uso de Java EE JCache con Open Liberty o WebSphere Liberty en un clúster de Azure Kubernetes Service (AKS).
Cómo usar bibliotecas cliente
Además de la documentación de referencia, hay varios tutoriales que muestran cómo empezar a trabajar con Azure Managed Redis con distintos lenguajes y clientes de caché.
Para obtener más información sobre el uso de algunas de estas bibliotecas cliente en tutoriales, consulte los siguientes artículos:
- Codificación de una aplicación de .NET Framework
- Codificación de una aplicación de .NET Core
- Codificación de una aplicación web ASP.NET
- Codificación de una aplicación web de ASP.NET Core
- Codificación de una aplicación Java
- Codificación de una aplicación Node.js
- Codificación de una aplicación Python