Merge pull request #4711 from tkyjovsk/KEYCLOAK-5588
KEYCLOAK-5588 Cross-dc: docker setup
This commit is contained in:
commit
0940c922ef
11 changed files with 125 additions and 53 deletions
|
@ -30,8 +30,12 @@ networks:
|
|||
services:
|
||||
|
||||
infinispan_dc1:
|
||||
build: infinispan
|
||||
image: keycloak_test_infinispan:${KEYCLOAK_VERSION:-latest}
|
||||
build:
|
||||
context: infinispan
|
||||
args:
|
||||
LOCAL_SITE: dc1
|
||||
REMOTE_SITE: dc2
|
||||
image: keycloak_test_infinispan_dc1:${KEYCLOAK_VERSION:-latest}
|
||||
cpus: 1
|
||||
networks:
|
||||
- ispn_replication
|
||||
|
@ -41,16 +45,18 @@ services:
|
|||
PRIVATE_SUBNET: 10.0.4.0/24
|
||||
MGMT_USER: admin
|
||||
MGMT_USER_PASSWORD: admin
|
||||
# APP_USER: keycloak
|
||||
# APP_USER_PASSWORD: keycloak
|
||||
# APP_USER_GROUPS: keycloak
|
||||
TCP_PING_INITIAL_HOSTS: infinispan_dc1[7600]
|
||||
JAVA_OPTS: ${INFINISPAN_JVM_MEMORY:--Xms64m -Xmx512m -XX:MetaspaceSize=96M -XX:MaxMetaspaceSize=256m -XX:+DisableExplicitGC} -Djava.net.preferIPv4Stack=true -Djboss.modules.system.pkgs=org.jboss.byteman -Djava.awt.headless=true
|
||||
ports:
|
||||
- "9991:9990"
|
||||
|
||||
infinispan_dc2:
|
||||
build: infinispan
|
||||
image: keycloak_test_infinispan:${KEYCLOAK_VERSION:-latest}
|
||||
build:
|
||||
context: infinispan
|
||||
args:
|
||||
LOCAL_SITE: dc2
|
||||
REMOTE_SITE: dc1
|
||||
image: keycloak_test_infinispan_dc2:${KEYCLOAK_VERSION:-latest}
|
||||
depends_on:
|
||||
infinispan_dc1:
|
||||
condition: service_healthy
|
||||
|
@ -63,9 +69,7 @@ services:
|
|||
PRIVATE_SUBNET: 10.0.4.0/24
|
||||
MGMT_USER: admin
|
||||
MGMT_USER_PASSWORD: admin
|
||||
# APP_USER: keycloak
|
||||
# APP_USER_PASSWORD: keycloak
|
||||
# APP_USER_GROUPS: keycloak
|
||||
TCP_PING_INITIAL_HOSTS: infinispan_dc1[7600],infinispan_dc2[7600]
|
||||
JAVA_OPTS: ${INFINISPAN_JVM_MEMORY:--Xms64m -Xmx512m -XX:MetaspaceSize=96M -XX:MaxMetaspaceSize=256m -XX:+DisableExplicitGC} -Djava.net.preferIPv4Stack=true -Djboss.modules.system.pkgs=org.jboss.byteman -Djava.awt.headless=true
|
||||
ports:
|
||||
- "9992:9990"
|
||||
|
|
|
@ -1,6 +1,9 @@
|
|||
FROM jboss/infinispan-server:8.2.6.Final
|
||||
#FROM jboss/infinispan-server:9.1.0.Final
|
||||
|
||||
ARG LOCAL_SITE
|
||||
ARG REMOTE_SITE
|
||||
|
||||
USER root
|
||||
RUN yum -y install iproute
|
||||
USER jboss
|
||||
|
@ -10,12 +13,14 @@ ENV CONFIGURATION clustered.xml
|
|||
ADD configs/ ./
|
||||
ADD *.sh /usr/local/bin/
|
||||
|
||||
RUN sed -e s/%LOCAL_SITE%/$LOCAL_SITE/ -e s/%REMOTE_SITE%/$REMOTE_SITE/ add-keycloak-caches.cli.template > add-keycloak-caches.cli
|
||||
|
||||
USER root
|
||||
RUN chmod -v +x /usr/local/bin/*.sh
|
||||
USER jboss
|
||||
|
||||
RUN $INFINISPAN_SERVER_HOME/bin/ispn-cli.sh --file=add-keycloak-caches.cli; \
|
||||
$INFINISPAN_SERVER_HOME/bin/ispn-cli.sh --file=private-interface-for-jgroups-socket-bindings.cli; \
|
||||
RUN $INFINISPAN_SERVER_HOME/bin/ispn-cli.sh --file=add-private-network-interface.cli; \
|
||||
$INFINISPAN_SERVER_HOME/bin/ispn-cli.sh --file=add-keycloak-caches.cli; \
|
||||
cd $INFINISPAN_SERVER_HOME/standalone; rm -rf configuration/standalone_xml_history log data tmp
|
||||
|
||||
HEALTHCHECK --interval=5s --timeout=5s --retries=12 CMD ["infinispan-healthcheck.sh"]
|
||||
|
|
|
@ -1,15 +0,0 @@
|
|||
embed-server --server-config=clustered.xml
|
||||
|
||||
cd /subsystem=datagrid-infinispan/cache-container=clustered/configurations=CONFIGURATIONS
|
||||
|
||||
#./replicated-cache-configuration=sessions-cfg:add(mode=SYNC, start=EAGER, batching=false)
|
||||
./replicated-cache-configuration=sessions-cfg:add(mode=ASYNC, start=EAGER, batching=false)
|
||||
./replicated-cache-configuration=sessions-cfg/transaction=TRANSACTION:add(locking=PESSIMISTIC, mode=NON_XA)
|
||||
|
||||
cd /subsystem=datagrid-infinispan/cache-container=clustered
|
||||
|
||||
./replicated-cache=work:add(configuration=sessions-cfg)
|
||||
./replicated-cache=sessions:add(configuration=sessions-cfg)
|
||||
./replicated-cache=offlineSessions:add(configuration=sessions-cfg)
|
||||
./replicated-cache=actionTokens:add(configuration=sessions-cfg)
|
||||
./replicated-cache=loginFailures:add(configuration=sessions-cfg)
|
|
@ -0,0 +1,32 @@
|
|||
embed-server --server-config=clustered.xml
|
||||
|
||||
# 2)
|
||||
cd /subsystem=datagrid-jgroups
|
||||
|
||||
# 2.a)
|
||||
./channel=xsite:add(stack=tcp-private)
|
||||
|
||||
# 2.b)
|
||||
./stack=udp/relay=RELAY:add(site="%LOCAL_SITE%")
|
||||
./stack=udp/relay=RELAY/remote-site=%REMOTE_SITE%:add(channel=xsite)
|
||||
|
||||
|
||||
|
||||
# 3)
|
||||
cd /subsystem=datagrid-infinispan/cache-container=clustered/configurations=CONFIGURATIONS
|
||||
|
||||
./replicated-cache-configuration=sessions-cfg:add(mode=SYNC, start=EAGER, batching=false)
|
||||
cd replicated-cache-configuration=sessions-cfg
|
||||
./transaction=TRANSACTION:add(mode=NON_DURABLE_XA, locking=PESSIMISTIC)
|
||||
./locking=LOCKING:add(acquire-timeout=0)
|
||||
./backup=%REMOTE_SITE%:add(failure-policy=FAIL, strategy=SYNC, enabled=true, min-wait=60000, after-failures=3)
|
||||
|
||||
cd /subsystem=datagrid-infinispan/cache-container=clustered
|
||||
./replicated-cache=work:add(configuration=sessions-cfg)
|
||||
./replicated-cache=sessions:add(configuration=sessions-cfg)
|
||||
./replicated-cache=clientSessions:add(configuration=sessions-cfg)
|
||||
./replicated-cache=offlineSessions:add(configuration=sessions-cfg)
|
||||
./replicated-cache=offlineClientSessions:add(configuration=sessions-cfg)
|
||||
./replicated-cache=actionTokens:add(configuration=sessions-cfg)
|
||||
./replicated-cache=loginFailures:add(configuration=sessions-cfg)
|
||||
|
|
@ -0,0 +1,42 @@
|
|||
embed-server --server-config=clustered.xml
|
||||
|
||||
# ADD PRIVATE NETWORK INTERFATCE for cross-DC communication
|
||||
|
||||
/interface=private:add(inet-address=${jboss.bind.address.private:127.0.0.1})
|
||||
|
||||
|
||||
# ADD PRIVATE JGROUPS SOCKET BINDINGS
|
||||
|
||||
cd /socket-binding-group=standard-sockets
|
||||
|
||||
./socket-binding=jgroups-mping-private:add( interface=private, port=0, multicast-address="${jboss.private.multicast.address:234.99.54.14}", multicast-port="45700")
|
||||
./socket-binding=jgroups-tcp-private:add( interface=private, port=7600)
|
||||
./socket-binding=jgroups-tcp-fd-private:add(interface=private, port=57600)
|
||||
./socket-binding=jgroups-udp-private:add( interface=private, port=55200, multicast-address="${jboss.private.multicast.address:234.99.54.14}", multicast-port="45688")
|
||||
./socket-binding=jgroups-udp-fd-private:add(interface=private, port=54200)
|
||||
|
||||
|
||||
# ADD PRIVATE TCP STACK
|
||||
|
||||
cd /subsystem=datagrid-jgroups
|
||||
|
||||
./stack=tcp-private:add(transport={type=TCP, socket-binding=jgroups-tcp-private})
|
||||
cd stack=tcp-private
|
||||
|
||||
:add-protocol(type=MPING, socket-binding=jgroups-mping-private)
|
||||
:add-protocol(type=MERGE3)
|
||||
:add-protocol(type=FD_SOCK, socket-binding=jgroups-tcp-fd-private)
|
||||
:add-protocol(type=FD_ALL)
|
||||
:add-protocol(type=VERIFY_SUSPECT)
|
||||
:add-protocol(type=pbcast.NAKACK2, properties={"use_mcast_xmit" => "false"})
|
||||
:add-protocol(type=UNICAST3)
|
||||
:add-protocol(type=pbcast.STABLE)
|
||||
:add-protocol(type=pbcast.GMS)
|
||||
:add-protocol(type=MFC)
|
||||
# ISPN 8
|
||||
:add-protocol(type=FRAG2)
|
||||
## ISPN 9
|
||||
#:add-protocol(type=FRAG3)
|
||||
cd ..
|
||||
|
||||
|
|
@ -1,9 +0,0 @@
|
|||
embed-server --server-config=clustered.xml
|
||||
|
||||
/interface=private:add(inet-address=${jboss.bind.address.private:127.0.0.1})
|
||||
|
||||
/socket-binding-group=standard-sockets/socket-binding=jgroups-mping:write-attribute(name=interface, value=private)
|
||||
/socket-binding-group=standard-sockets/socket-binding=jgroups-tcp:write-attribute(name=interface, value=private)
|
||||
/socket-binding-group=standard-sockets/socket-binding=jgroups-tcp-fd:write-attribute(name=interface, value=private)
|
||||
/socket-binding-group=standard-sockets/socket-binding=jgroups-udp:write-attribute(name=interface, value=private)
|
||||
/socket-binding-group=standard-sockets/socket-binding=jgroups-udp-fd:write-attribute(name=interface, value=private)
|
|
@ -4,7 +4,7 @@ cat $INFINISPAN_SERVER_HOME/standalone/configuration/$CONFIGURATION
|
|||
|
||||
. get-ips.sh
|
||||
|
||||
PARAMS="-b $PUBLIC_IP -bmanagement $PUBLIC_IP -bprivate $PRIVATE_IP -Djgroups.bind_addr=$PRIVATE_IP -c $CONFIGURATION $@"
|
||||
PARAMS="-b $PUBLIC_IP -bmanagement $PUBLIC_IP -bprivate $PRIVATE_IP -Djgroups.bind_addr=$PUBLIC_IP -c $CONFIGURATION $@"
|
||||
echo "Server startup params: $PARAMS"
|
||||
|
||||
# Note: External container connectivity is always provided by eth0 -- irrespective of which is considered public/private by KC.
|
||||
|
|
|
@ -27,7 +27,6 @@ RUN curl --create-dirs --output modules/system/layers/base/org/mariadb/jdbc/main
|
|||
$JBOSS_HOME/bin/jboss-cli.sh --file=set-keycloak-ds.cli && \
|
||||
$JBOSS_HOME/bin/jboss-cli.sh --file=io-worker-threads.cli && \
|
||||
$JBOSS_HOME/bin/jboss-cli.sh --file=undertow.cli && \
|
||||
$JBOSS_HOME/bin/jboss-cli.sh --file=distributed-cache-owners.cli && \
|
||||
$JBOSS_HOME/bin/jboss-cli.sh --file=modcluster-simple-load-provider.cli && \
|
||||
if [ "$REMOTE_CACHES" == "true" ]; then $JBOSS_HOME/bin/jboss-cli.sh --file=add-remote-cache-stores.cli; fi && \
|
||||
cd $JBOSS_HOME/standalone; rm -rf configuration/standalone_xml_history log data tmp ; \
|
||||
|
|
|
@ -3,18 +3,18 @@ embed-server --server-config=standalone-ha.xml
|
|||
/subsystem=jgroups/stack=udp/transport=UDP:write-attribute(name=site, value=${env.SITE:dc1})
|
||||
/socket-binding-group=standard-sockets/remote-destination-outbound-socket-binding=remote-cache:add(host=${env.INFINISPAN_HOST:localhost}, port=${env.INFINISPAN_PORT:11222})
|
||||
|
||||
cd /subsystem=infinispan/cache-container=keycloak
|
||||
|
||||
/subsystem=infinispan/cache-container=keycloak:write-attribute(name=module, value=org.keycloak.keycloak-model-infinispan)
|
||||
:write-attribute(name=module, value=org.keycloak.keycloak-model-infinispan)
|
||||
|
||||
/subsystem=infinispan/cache-container=keycloak/replicated-cache=work/store=remote:add(cache=work, fetch-state=false, passivation=false, preload=false, purge=false, remote-servers=["remote-cache"], shared=true)
|
||||
/subsystem=infinispan/cache-container=keycloak/replicated-cache=work/store=remote:write-attribute(name=properties, value={rawValues=true, marshaller=org.keycloak.cluster.infinispan.KeycloakHotRodMarshallerFactory})
|
||||
./replicated-cache=work/store=remote:add(cache=work, fetch-state=false, passivation=false, preload=false, purge=false, remote-servers=["remote-cache"], shared=true, properties={rawValues=true, marshaller=org.keycloak.cluster.infinispan.KeycloakHotRodMarshallerFactory})
|
||||
|
||||
/subsystem=infinispan/cache-container=keycloak/distributed-cache=sessions/store=custom:add(class=org.keycloak.models.sessions.infinispan.remotestore.KeycloakRemoteStoreConfigurationBuilder, fetch-state=false, passivation=false, preload=false, purge=false, shared=true)
|
||||
/subsystem=infinispan/cache-container=keycloak/distributed-cache=sessions/store=custom:write-attribute(name=properties, value={remoteCacheName=sessions, useConfigTemplateFromCache=work})
|
||||
|
||||
/subsystem=infinispan/cache-container=keycloak/distributed-cache=offlineSessions/store=custom:add(class=org.keycloak.models.sessions.infinispan.remotestore.KeycloakRemoteStoreConfigurationBuilder, fetch-state=false, passivation=false, preload=false, purge=false, shared=true)
|
||||
/subsystem=infinispan/cache-container=keycloak/distributed-cache=offlineSessions/store=custom:write-attribute(name=properties, value={remoteCacheName=offlineSessions, useConfigTemplateFromCache=work})
|
||||
|
||||
/subsystem=infinispan/cache-container=keycloak/distributed-cache=loginFailures/store=custom:add(class=org.keycloak.models.sessions.infinispan.remotestore.KeycloakRemoteStoreConfigurationBuilder, fetch-state=false, passivation=false, preload=false, purge=false, shared=true)
|
||||
/subsystem=infinispan/cache-container=keycloak/distributed-cache=loginFailures/store=custom:write-attribute(name=properties, value={remoteCacheName=loginFailures, useConfigTemplateFromCache=work})
|
||||
./distributed-cache=sessions/store=remote:add(cache=sessions, fetch-state=false, passivation=false, preload=false, purge=false, remote-servers=["remote-cache"], shared=true, properties={rawValues=true, marshaller=org.keycloak.cluster.infinispan.KeycloakHotRodMarshallerFactory})
|
||||
./distributed-cache=offlineSessions/store=remote:add(cache=offlineSessions, fetch-state=false, passivation=false, preload=false, purge=false, remote-servers=["remote-cache"], shared=true, properties={rawValues=true, marshaller=org.keycloak.cluster.infinispan.KeycloakHotRodMarshallerFactory})
|
||||
./distributed-cache=clientSessions/store=remote:add(cache=clientSessions, fetch-state=false, passivation=false, preload=false, purge=false, remote-servers=["remote-cache"], shared=true, properties={rawValues=true, marshaller=org.keycloak.cluster.infinispan.KeycloakHotRodMarshallerFactory})
|
||||
./distributed-cache=offlineClientSessions/store=remote:add(cache=offlineClientSessions, fetch-state=false, passivation=false, preload=false, purge=false, remote-servers=["remote-cache"], shared=true, properties={rawValues=true, marshaller=org.keycloak.cluster.infinispan.KeycloakHotRodMarshallerFactory})
|
||||
./distributed-cache=loginFailures/store=remote:add(cache=loginFailures, fetch-state=false, passivation=false, preload=false, purge=false, remote-servers=["remote-cache"], shared=true, properties={rawValues=true, marshaller=org.keycloak.cluster.infinispan.KeycloakHotRodMarshallerFactory})
|
||||
|
||||
./distributed-cache=actionTokens/store=remote:add(cache=actionTokens, fetch-state=false, passivation=false, preload=false, purge=false, remote-servers=["remote-cache"], shared=true, properties={rawValues=true, marshaller=org.keycloak.cluster.infinispan.KeycloakHotRodMarshallerFactory})
|
||||
./distributed-cache=actionTokens/eviction=EVICTION:add(max-entries=-1, strategy=NONE)
|
||||
./distributed-cache=actionTokens/expiration=EXPIRATION:add(max-idle=-1,interval=300000)
|
|
@ -1,7 +1,13 @@
|
|||
embed-server --server-config=standalone-ha.xml
|
||||
|
||||
# increase number of "owners" for distributed keycloak caches to support failover
|
||||
/subsystem=infinispan/cache-container=keycloak/distributed-cache=sessions:write-attribute(name=owners, value=${distributed.cache.owners:2})
|
||||
/subsystem=infinispan/cache-container=keycloak/distributed-cache=authenticationSessions:write-attribute(name=owners, value=${distributed.cache.owners:2})
|
||||
/subsystem=infinispan/cache-container=keycloak/distributed-cache=offlineSessions:write-attribute(name=owners, value=${distributed.cache.owners:2})
|
||||
/subsystem=infinispan/cache-container=keycloak/distributed-cache=loginFailures:write-attribute(name=owners, value=${distributed.cache.owners:2})
|
||||
|
||||
cd /subsystem=infinispan/cache-container=keycloak/
|
||||
|
||||
./distributed-cache=sessions:write-attribute(name=owners, value=${distributed.cache.owners:2})
|
||||
./distributed-cache=offlineSessions:write-attribute(name=owners, value=${distributed.cache.owners:2})
|
||||
./distributed-cache=clientSessions:write-attribute(name=owners, value=${distributed.cache.owners:2})
|
||||
./distributed-cache=offlineClientSessions:write-attribute(name=owners, value=${distributed.cache.owners:2})
|
||||
./distributed-cache=loginFailures:write-attribute(name=owners, value=${distributed.cache.owners:2})
|
||||
./distributed-cache=actionTokens:write-attribute(name=owners, value=${distributed.cache.owners:2})
|
||||
|
||||
|
|
|
@ -0,0 +1,8 @@
|
|||
embed-server --server-config=standalone-ha.xml
|
||||
|
||||
cd subsystem=logging
|
||||
|
||||
./logger=org.keycloak.cluster.infinispan:add(level=DEBUG)
|
||||
./logger=org.keycloak.connections.infinispan:add(level=DEBUG)
|
||||
./logger=org.keycloak.models.cache.infinispan:add(level=DEBUG)
|
||||
./logger=org.keycloak.models.sessions.infinispan:add(level=DEBUG)
|
Loading…
Reference in a new issue