Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

add documentation to assist deployment changes #51

Open
wants to merge 5 commits into
base: master
Choose a base branch
from
Open
Changes from 4 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
95 changes: 95 additions & 0 deletions openshift/debugging.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,95 @@
### Checking logs in Kibana

Use the following query in Kibana to filter in meaningful log messages

```
kubernetes.container_name: "keycloak-server" AND NOT message: "*Allocation Failure*"
```


### Confirm from logs that keycloak clustering works
```
:16:31,892 INFO [org.infinispan.remoting.transport.jgroups.JGroupsTransport] (Incoming-6,kubernetes,10.1.13.206) ISPN000094: Received new cluster view for channel web: [10.1.12.52|28] (3) [10.1.12.52, 10.1.13.206, 10.1.0.105]
```

Cluster formation might take a while, ignore any errors in logs which look like

```
11:16:33,050 ERROR [org.jgroups.protocols.TCP] (TransferQueueBundler,kubernetes,10.1.13.206) JGRP000029: 10.1.13.206: failed sending message to 10.1.7.65 (73 bytes): java.net.SocketTimeoutException: connect timed out, headers: GMS: GmsHeader[VIEW_ACK], UNICAST3: DATA, seqno=144, TCP: [cluster_name=kubernetes]
```


### Handling memory issues

Maintain a good balance between the pod's memory allocation , and the Java memory allocation.
Ensure that the Java memory is slightly lesser than the pod's memory allocation to avoid the pod from crashing.

```
strategy:
type: Rolling
resources:
limits:
memory: 2Gi
```

```
- name: JAVA_OPTS
value: >-
-server -Xms256m -Xmx1434m -XX:MetaspaceSize=96M
```


### Using parameters

If there's an environment variable that wouldn't change much, as of now, it would be fair to harcode it as a parameter
Refer to discussion here : https://github.com/fabric8-services/keycloak-deployment/pull/45

```
replicas: ${REPLICAS}
```

and then

```
- name: REPLICAS
value: "3"
```

### Configuration for active-active clustering


```

- name: OPENSHIFT_KUBE_PING_NAMESPACE
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@sbose78 the kube_pint port is missing here

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I mean among all these details not exactly in this line

valueFrom:
fieldRef:
fieldPath: metadata.namespace
- name: OPENSHIFT_KUBE_PING_LABELS
valueFrom:
configMapKeyRef:
name: keycloak-config
key: openshift.kube.ping.labels
- name: OPENSHIFT_KUBE_PING_SERVER_PORT
valueFrom:
configMapKeyRef:
name: keycloak-config
key: openshift.kube.ping.server.port

```

Of course you would need to specify the mode as CLUSTERED or STANDALONE

```
- name: OPERATING_MODE
value: ${OPERATING_MODE}
```

### Testing the performance of a deployment

The performance can be tested by executing the following scripts :
https://github.com/fabric8-services/keycloak-performance-scripts