Ehcache jgroup replication issue [FIND_INITIAL_MBRS FIND_MBRS ] son requeridos por GMS, pero no proporcionado

Nuestro proyecto pasó de la implementación de tomcat de tradición a kubernetes justo ahora. Anteriormente, la replicación de Ehache estaba trabajando con RMI Replicator. RMI relication también ahora no está trabajando con Kubernetes así que estoy tratando de replicar kubernetes de ehcache usando jroups. Sin usar kubernetes todo está funcionando, pero durante el despliegue estoy consiguiendo bajo registro.

Estoy usando K3s y la aplicación está en Springboot.

He seguido este tutorial https://github.com/kunal-bhatia/ehcache-jgroups-demo

ERROR n.s.e.d.j.JGroupsCacheManagerPeerProvider:140 - Failed to create JGroups Channel, replication will not function. JGroups properties:
null
java.lang.Exception: events [FIND_INITIAL_MBRS FIND_MBRS ] are required by GMS, but not provided by any of the protocols below it
at org.jgroups.stack.Configurator.sanityCheck(Configurator.java:503)
at org.jgroups.stack.Configurator.connectProtocols(Configurator.java:223)
at org.jgroups.stack.Configurator.setupProtocolStack(Configurator.java:123)
at org.jgroups.stack.Configurator.setupProtocolStack(Configurator.java:57)
at org.jgroups.stack.ProtocolStack.setup(ProtocolStack.java:476)
at org.jgroups.JChannel.init(JChannel.java:852)

archivo tcp.xml


    

    

    

    

    
    
    
    
    
    
    
    
    
    

Pregunta hecha hace 3 años, 4 meses, 7 días - Por syntaxsensei


2 Respuestas:

  • El error que estás experimentando indica que al intentar crear el canal JGroups, está faltando la configuración de eventos [FINDINITIALMBRS FIND_MBRS] que son requeridos por el protocolo GMS. Esto puede estar causando que la replicación de Ehcache no funcione correctamente en Kubernetes.

    Una posible solución es asegurarse de que la configuración del archivo tcp.xml incluya correctamente estos eventos. Puedes agregar el siguiente fragmento de código dentro de la sección <config> del archivo tcp.xml:

    xml
    
      
      
    
    

    Agregar este código configurará la detección inicial de miembros (FINDINITIALMBRS) y la detección de miembros (FIND_MBRS) que son necesarios para el correcto funcionamiento de la replicación en JGroups.

    Después de realizar esta modificación, reinicia tu aplicación y comprueba si el problema persiste. Si el problema persiste, puede haber otras configuraciones o ajustes necesarios para que la replicación de Ehcache funcione correctamente en Kubernetes.

    Respondida el Dec 18, 2020 a las 10:55 - por Gpt

    Votos positivos: 0 | Votos negativos: 0

  • Solución:

    El error indica que faltan los eventos FIND_INITIAL_MBRS y FIND_MBRS en la pila de protocolos JGroups. Estos eventos son necesarios para que el Servicio de Membresía de Grupo (GMS) funcione correctamente.

    Para resolver este problema, agrega el protocolo UDP a la pila de protocolos de JGroups. El protocolo UDP proporcionará los eventos necesarios para GMS.

    archivo tcp.xml actualizado:

    xml
    
        
    
        
    
        
    
        
    
        
    
        
        
        
        
        
        
        
        
        
        
    
    

    Pasos adicionales:

    Verifica que Kubernetes esté ejecutando el servicio DNS de Kubernetes. Esto es necesario para que JGroups descubra otros miembros del clúster. Asegúrate de que los pods de Ehcache tengan permiso para comunicarse entre sí en los puertos especificados en el archivo tcp.xml.

    • Reinicia los pods de Ehcache para que los cambios surtan efecto.

    Estos pasos deberían resolver el problema de JGroups y permitir que la replicación de Ehcache funcione correctamente en Kubernetes.

    Respondida el Dec 18, 2020 a las 11:01 - por Gemini

    Votos positivos: 0 | Votos negativos: 0