Table of Contents | ||||
---|---|---|---|---|
|
Onboarding the Java CD Agent
These steps outline the onboarding steps needed on the environment, with the CD agent, added to each component that builds up the Application Under Test.
Each component within the application is a service running on a ‘dedicated’ JVM:
This could be an application server like Tomcat, JBoss, Websphere/Weblogic, or a standalone Java process using the Java Runtime Environment.
They can be on physical machines, VMs, containers, on-prem, or the cloud.
Configuration steps
Tip |
---|
When the application is up and running and the Sealights CD Agent configured, you can see it is properly running from the Cockpit -> Live Agents Monitor screen.
|
Agent’s Parameters Reference
Mandatory parameters
Property | Required | Description | ||
---|---|---|---|---|
sl.token | Yes | The agent token to use for the secure connection, either as a parameter or in a file
| ||
sl.appName | Yes | Name of the component | ||
sl.labId | Yes | The labId generated for the integration build entry in step #3 | ||
sl.buildName | Yes | Name of the components version sl.buildNameLocation value should be:
| ||
sl.includes | Yes | Comma separated list of search pattern with wildcards (
|
Optional parameters
These parameters may be required due to your specific configuration or environment’s limitations (e.g., proxy).
Property | Required | Description | ||
---|---|---|---|---|
sl.excludes | No | Comma separated list of search pattern with wildcards ( | ||
sl.branchName | No | Name of the branch of the component. If not provided, the lab branch name will be used | ||
sl.workspace | No | Folders to search in for files to be scanned. Default is the current working directory | ||
sl.filesincluded | No | Comma separated list of search pattern with wildcards for the files to be included in the scan. Default is
| ||
sl.filesexcluded | No | Comma separated list of search pattern with wildcards for the files to be excluded from the scan
| ||
sl.recursive | No | Indication if to scan the workspace paths recursivly. Default is true | ||
sl.proxy | No | Proxy for the agent to go through when communicating with SeaLights | ||
sl.tags | No | Free text comma separated tags to help identify the agents later in the cockpit |
Logging parameters
To enable logs, you can set the following parameters as environment variables or add them as -Dsl.*
parameters. Both console output and file options are compatible and non-exclusive.
For logging into the console, add
Code Block |
---|
-Dsl.log.toConsole=true -Dsl.log.level=info [--add-opens=java.base/jdk.internal.loader=ALL-UNNAMED] |
For logging into a file, add
Code Block |
---|
-Dsl.log.toFile=true -Dsl.log.level=info -Dsl.log.folder=<path/with/permissions/> [--add-opens=java.base/jdk.internal.loader=ALL-UNNAMED] [-Dsl.log.count=<value>] [-Dsl.log.limit=<arg>] [-Dsl.log.filename=<arg>] |
Parameter | Required | Description |
---|---|---|
| No | Sets the log level to one of the following: "off", "error", "warn", "info", "debug" |
| No | Set to true to enable log output to the console |
| No | Set to true to enable log output to a file |
| No | Provide a folder to save the log files in |
| No | Provide the name of the log file |
| No | Limit the number of log files to create. Default: 10 |
| No | Limit the size of the log file in megabytes (MB). Default value is 10 (i.e. 10*1024 KB) |
| No | Special JVM parameter to allow logging in Java 9 and later in addition to |
Sample Commands
Downloading the agent
The agent is downloadable from the following URL: https://agents.sealights.co/sl-cd-agent/sl-cd-agent-latest.zip
You can use the following commands to automate the process
Code Block | ||
---|---|---|
| ||
wget -nv https://agents.sealights.co/sl-cd-agent/sl-cd-agent-latest.zip unzip -oq sl-cd-agent-latest.zip echo "Sealights CD Agent version used is:" `cat version.txt` |
Configuration commands
Table of Contents | ||||||
---|---|---|---|---|---|---|
|
JRE
Code Block | ||
---|---|---|
| ||
java -javaagent:/sealights/sl-cd-agent.jar -Dsl.token=${SL_TOKEN} -Dsl.appName=microservices_orders -Dsl.buildName=weaveworksdemos/carts:0.4.8 -Dsl.tags=JRE -Dsl.labId=integ_test_microservices -Dsl.includes="works*" -jar app.jar |
BASH
Code Block | ||
---|---|---|
| ||
export JAVA_TOOL_OPTIONS="-javaagent:/sealights/sl-cd-agent.jar -Dsl.tokenFile=/sealights/sltoken.txt -Dsl.appName=microservices_orders -Dsl.buildName=weaveworksdemos/carts:0.4.8 -Dsl.tags=bash -Dsl.labId=integ_test_microservices -Dsl.includes=works*" java -jar app.jar |
Docker compose
Code Block | ||
---|---|---|
| ||
queue-master: image: weaveworksdemos/queue-master:0.3.1 hostname: queue-master volumes: - /var/run/docker.sock:/var/run/docker.sock restart: always cap_drop: - all cap_add: - NET_BIND_SERVICE read_only: true tmpfs: - /tmp:rw,noexec,nosuid environment: - JAVA_OPTS=-javaagent:/sealights/sl-cd-agent.jar -Dsl.tokenFile=/sealights/sltoken.txt -Dsl.appName=microservices_queuemaster -Dsl.buildName=${BUILD_NAME} -Dsl.tags=script,container -Dsl.labId=integ_test_microservices -Dsl.includes=works* volumes: - /tmp/sealights:/sealights |
A sample to use ${BUILD_NAME}
dynamically is to set it in the .env
file:
Code Block |
---|
BUILD_NAME=weaveworksdemos/queue-master:0.3.1 |
K8s using an init container
Code Block | ||
---|---|---|
| ||
apiVersion: apps/v1 kind: Deployment metadata: name: carts labels: name: carts namespace: sock-shop spec: replicas: 1 selector: matchLabels: name: carts template: metadata: labels: name: carts spec: initContainers: - name: java-cd-agent image: java-cd-agent:latest imagePullPolicy: Never command: ["/bin/sh", "-c", "cp /download/sl-cd-agent.jar /sealights"] volumeMounts: - mountPath: /sealights name: java-cd-agent-file containers: - name: carts image: weaveworksdemos/carts:0.4.8 env: - name: sl.token valueFrom: secretKeyRef: name: sealights key: SL_TOKEN - name: sl.appName value: microservices_carts - name: sl.buildName value: ${BUILD_NAME} - name: sl.tags value: k8s,ic - name: sl.labId value: integ_test_microservices - name: sl.includes value: works* - name: JAVA_TOOL_OPTIONS value: -javaagent:/sealights/sl-cd-agent.jar - name: JAVA_OPTS value: -Xms64m -Xmx128m -XX:+UseG1GC -Djava.security.egd=file:/dev/urandom -Dspring.zipkin.enabled=false resources: limits: cpu: 300m memory: 500Mi requests: cpu: 100m memory: 200Mi ports: - containerPort: 80 securityContext: runAsNonRoot: true runAsUser: 10001 capabilities: drop: - all add: - NET_BIND_SERVICE readOnlyRootFilesystem: true volumeMounts: - mountPath: /tmp name: tmp-volume - mountPath: /sealights name: java-cd-agent-file volumes: - name: tmp-volume emptyDir: medium: Memory - name: java-cd-agent-file emptyDir: {} nodeSelector: beta.kubernetes.io/os: linux |
A sample to use ${BUILD_NAME}
dynamically is to set it using envsubst
Code Block | ||
---|---|---|
| ||
export BUILD_NAME=weaveworksdemos/carts:0.4.8 envsubst < k8s.yaml | kubectl apply -f - |
Docker file for java-cd-agent
Code Block |
---|
FROM alpine:3.17.0 ADD sl-cd-agent.jar /download/sl-cd-agent.jar |