<html>
  <head>
    <meta content="text/html; charset=windows-1252"
      http-equiv="Content-Type">
  </head>
  <body text="#000000" bgcolor="#FFFFFF">
    What about configuring <span lang="EN-US">Loadbalancer to use
      sticky sessions?<br>
      <br>
      Vlastimil<br>
    </span><br>
    <div class="moz-cite-prefix">On 25.2.2016 16:10, Peter Krivansky
      wrote:<br>
    </div>
    <blockquote
cite="mid:928D7EA37F707B43B6CE2201274CD7534149DDE1@EX-TT-AC-01.traveltainment.int"
      type="cite">
      <meta http-equiv="Content-Type" content="text/html;
        charset=windows-1252">
      <meta name="Generator" content="Microsoft Word 15 (filtered
        medium)">
      <style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0cm;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;
        mso-fareast-language:EN-US;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:#0563C1;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:#954F72;
        text-decoration:underline;}
span.E-MailFormatvorlage17
        {mso-style-type:personal-compose;
        font-family:"Calibri",sans-serif;
        color:windowtext;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-family:"Calibri",sans-serif;
        mso-fareast-language:EN-US;}
@page WordSection1
        {size:612.0pt 792.0pt;
        margin:70.85pt 70.85pt 2.0cm 70.85pt;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
      <div class="WordSection1">
        <p class="MsoNormal">Hello,<o:p></o:p></p>
        <p class="MsoNormal"><o:p> </o:p></p>
        <p class="MsoNormal"><span lang="EN-US">I have a Keycloak
            cluster with two servers, in front of each Keaycloak is
            Apache running.<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US"><o:p> </o:p></span></p>
        <p class="MsoNormal" style="text-indent:35.4pt"><span
            lang="EN-US">LB<o:p></o:p></span></p>
        <p class="MsoNormal" style="text-indent:35.4pt"><span
            lang="EN-US">/\<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">  Host A    Host B<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US"><o:p> </o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">Now, Host-A and Host-B
            are in different subnets, due to this design we are running
            jGroups via TCP.
            <o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">Now everything is
            working fine, except for the Keycloak Admin console, once a
            user tries to log in, they get for a milisecond in to the
            Admin console, but then they get redirected to the login
            page immediately.<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">When I disable Host-A or
            Host-B on the Loadbalancer, (new sessions will land only on
            Hst-A or Host-B) the Login to Keycloak Admin Console will
            work normally.<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">During the immediate
            redirection there is only this one WARNING in the
            Server.log:<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US"><o:p> </o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">15:41:42,886 WARN 
            [org.jboss.resteasy.core.ExceptionHandler] (default task-10)
            Failed executing GET /admin/serverinfo:
            org.jboss.resteasy.spi.UnauthorizedException: Bearer<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
org.keycloak.services.resources.admin.AdminRoot.authenticateRealmAdminRequest(AdminRoot.java:156)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
org.keycloak.services.resources.admin.AdminRoot.getServerInfo(AdminRoot.java:209)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
            sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
            java.lang.reflect.Method.invoke(Method.java:498)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
org.jboss.resteasy.core.ResourceLocatorInvoker.createResource(ResourceLocatorInvoker.java:81)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
org.jboss.resteasy.core.ResourceLocatorInvoker.createResource(ResourceLocatorInvoker.java:60)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
org.jboss.resteasy.core.ResourceLocatorInvoker.invoke(ResourceLocatorInvoker.java:102)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
org.jboss.resteasy.core.SynchronousDispatcher.invoke(SynchronousDispatcher.java:356)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
org.jboss.resteasy.core.SynchronousDispatcher.invoke(SynchronousDispatcher.java:179)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
org.jboss.resteasy.plugins.server.servlet.ServletContainerDispatcher.service(ServletContainerDispatcher.java:220)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher.service(HttpServletDispatcher.java:56)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher.service(HttpServletDispatcher.java:51)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
            javax.servlet.http.HttpServlet.service(HttpServlet.java:790)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.servlet.handlers.ServletHandler.handleRequest(ServletHandler.java:86)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.servlet.handlers.FilterHandler$FilterChainImpl.doFilter(FilterHandler.java:130)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
org.keycloak.services.filters.KeycloakSessionServletFilter.doFilter(KeycloakSessionServletFilter.java:61)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
            io.undertow.servlet.core.ManagedFilter.doFilter(ManagedFilter.java:60)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.servlet.handlers.FilterHandler$FilterChainImpl.doFilter(FilterHandler.java:132)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.servlet.handlers.FilterHandler.handleRequest(FilterHandler.java:85)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.servlet.handlers.security.ServletSecurityRoleHandler.handleRequest(ServletSecurityRoleHandler.java:62)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.servlet.handlers.ServletDispatchingHandler.handleRequest(ServletDispatchingHandler.java:36)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
org.wildfly.extension.undertow.security.SecurityContextAssociationHandler.handleRequest(SecurityContextAssociationHandler.java:78)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.servlet.handlers.security.SSLInformationAssociationHandler.handleRequest(SSLInformationAssociationHandler.java:131)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.servlet.handlers.security.ServletAuthenticationCallHandler.handleRequest(ServletAuthenticationCallHandler.java:57)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.security.handlers.AbstractConfidentialityHandler.handleRequest(AbstractConfidentialityHandler.java:46)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.servlet.handlers.security.ServletConfidentialityConstraintHandler.handleRequest(ServletConfidentialityConstraintHandler.java:64)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.security.handlers.AuthenticationMechanismsHandler.handleRequest(AuthenticationMechanismsHandler.java:58)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.servlet.handlers.security.CachedAuthenticatedSessionHandler.handleRequest(CachedAuthenticatedSessionHandler.java:72)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.security.handlers.NotificationReceiverHandler.handleRequest(NotificationReceiverHandler.java:50)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.security.handlers.SecurityInitialHandler.handleRequest(SecurityInitialHandler.java:76)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
org.wildfly.extension.undertow.security.jacc.JACCContextIdHandler.handleRequest(JACCContextIdHandler.java:61)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.servlet.handlers.ServletInitialHandler.handleFirstRequest(ServletInitialHandler.java:282)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.servlet.handlers.ServletInitialHandler.dispatchRequest(ServletInitialHandler.java:261)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.servlet.handlers.ServletInitialHandler.access$000(ServletInitialHandler.java:80)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
io.undertow.servlet.handlers.ServletInitialHandler$1.handleRequest(ServletInitialHandler.java:172)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
            io.undertow.server.Connectors.executeRootHandler(Connectors.java:199)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
            io.undertow.server.HttpServerExchange$1.run(HttpServerExchange.java:774)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">         at
            java.lang.Thread.run(Thread.java:745)<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US"><o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US"><o:p> </o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">I attached my domain.xml<o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">Have I missed something,
            or what did I wrong? 
            <o:p></o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US"><o:p> </o:p></span></p>
        <p class="MsoNormal"><span lang="EN-US">With Kind regards Peter<o:p></o:p></span></p>
      </div>
      <br>
      <fieldset class="mimeAttachmentHeader"></fieldset>
      <br>
      <pre wrap="">_______________________________________________
keycloak-dev mailing list
<a class="moz-txt-link-abbreviated" href="mailto:keycloak-dev@lists.jboss.org">keycloak-dev@lists.jboss.org</a>
<a class="moz-txt-link-freetext" href="https://lists.jboss.org/mailman/listinfo/keycloak-dev">https://lists.jboss.org/mailman/listinfo/keycloak-dev</a></pre>
    </blockquote>
    <br>
    <pre class="moz-signature" cols="72">-- 
Vlastimil Elias
Principal Software Engineer
Developer Portal Engineering Team</pre>
  </body>
</html>