Skip to content

Commit

Permalink
Merge remote-tracking branch 'origin/v3' into feature/remove-log4j
Browse files Browse the repository at this point in the history
# Conflicts:
#	charts/producer-app/README.md
#	charts/streams-app/README.md
  • Loading branch information
philipp94831 committed Jul 24, 2024
2 parents 8f54ba5 + 8dc843c commit 58e7a77
Show file tree
Hide file tree
Showing 17 changed files with 89 additions and 49 deletions.
2 changes: 1 addition & 1 deletion charts/producer-app-cleanup-job/templates/job.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,7 @@ spec:
- name: ENV_PREFIX
value: {{ .Values.configurationEnvPrefix }}_
{{- range $key, $value := .Values.streams.config }}
- name: {{ printf "STREAMS_%s" $key | replace "." "_" | upper | quote }}
- name: {{ printf "KAFKA_%s" $key | replace "." "_" | upper | quote }}
value: {{ $value | quote }}
{{- end }}
{{- if hasKey .Values.streams "brokers" }}
Expand Down
18 changes: 9 additions & 9 deletions charts/producer-app/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -56,15 +56,15 @@ Alternatively, a YAML file that specifies the values for the parameters can be p

### Other

| Parameter | Description | Default |
| ------------------------ | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------- |
| `configurationEnvPrefix` | Prefix for environment variables to use that should be parsed as command line arguments. | `APP` |
| `commandLine` | Map of command line arguments passed to the producer app. | `{}` |
| `env` | Custom environment variables | `{}` |
| `secrets` | Custom secret environment variables. Prefix with `configurationEnvPrefix` in order to pass secrets to command line or prefix with `STREAMS_` to pass secrets to Kafka Streams configuration. E.g., `APP_MY_PARAM` would be passed as `--my-param` and `STREAMS_MAX_POLL_TIMEOUT_MS` would be translated to `max.poll.timeout.ms`. | `{}` |
| `secretRefs` | Inject existing secrets as environment variables. Map key is used as environment variable name. Value consists of secret `name` and `key`. | `{}` |
| `secretFilesRefs` | Mount existing secrets as volumes | `[]` |
| `files` | Map of files to mount for the app. File will be mounted as `$value.mountPath/$key`. `$value.content` denotes file content (recommended to be used with `--set-file`). | `{}` |
| Parameter | Description | Default |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| `configurationEnvPrefix` | Prefix for environment variables to use that should be parsed as command line arguments. | `APP` |
| `commandLine` | Map of command line arguments passed to the producer app. | `{}` |
| `env` | Custom environment variables | `{}` |
| `secrets` | Custom secret environment variables. Prefix with `configurationEnvPrefix` in order to pass secrets to command line or prefix with `KAFKA_` to pass secrets to Kafka Streams configuration. E.g., `APP_MY_PARAM` would be passed as `--my-param` and `KAFKA_MAX_POLL_TIMEOUT_MS` would be translated to `max.poll.timeout.ms`. | `{}` |
| `secretRefs` | Inject existing secrets as environment variables. Map key is used as environment variable name. Value consists of secret `name` and `key`. | `{}` |
| `secretFilesRefs` | Mount existing secrets as volumes | `[]` |
| `files` | Map of files to mount for the app. File will be mounted as `$value.mountPath/$key`. `$value.content` denotes file content (recommended to be used with `--set-file`). | `{}` |

### JVM

Expand Down
2 changes: 1 addition & 1 deletion charts/producer-app/templates/pod.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ spec:
- name: ENV_PREFIX
value: {{ .Values.configurationEnvPrefix }}_
{{- range $key, $value := .Values.streams.config }}
- name: {{ printf "STREAMS_%s" $key | replace "." "_" | upper | quote }}
- name: {{ printf "KAFKA_%s" $key | replace "." "_" | upper | quote }}
value: {{ $value | quote }}
{{- end }}
{{- if hasKey .Values.streams "brokers" }}
Expand Down
2 changes: 1 addition & 1 deletion charts/streams-app-cleanup-job/templates/job.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,7 @@ spec:
- name: ENV_PREFIX
value: {{ .Values.configurationEnvPrefix }}_
{{- range $key, $value := .Values.streams.config }}
- name: {{ printf "STREAMS_%s" $key | replace "." "_" | upper | quote }}
- name: {{ printf "KAFKA_%s" $key | replace "." "_" | upper | quote }}
value: {{ $value | quote }}
{{- end }}
{{- if hasKey .Values.streams "brokers" }}
Expand Down
18 changes: 9 additions & 9 deletions charts/streams-app/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -67,15 +67,15 @@ Alternatively, a YAML file that specifies the values for the parameters can be p

### Other

| Parameter | Description | Default |
| ------------------------ | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------- |
| `configurationEnvPrefix` | Prefix for environment variables to use that should be parsed as command line arguments. | `APP` |
| `commandLine` | Map of command line arguments passed to the streams app. | `{}` |
| `env` | Custom environment variables | `{}` |
| `secrets` | Custom secret environment variables. Prefix with `configurationEnvPrefix` in order to pass secrets to command line or prefix with `STREAMS_` to pass secrets to Kafka Streams configuration. E.g., `APP_MY_PARAM` would be passed as `--my-param` and `STREAMS_MAX_POLL_TIMEOUT_MS` would be translated to `max.poll.timeout.ms`. | `{}` |
| `secretRefs` | Inject existing secrets as environment variables. Map key is used as environment variable name. Value consists of secret `name` and `key`. | `{}` |
| `secretFilesRefs` | Mount existing secrets as volumes | `[]` |
| `files` | Map of files to mount for the app. File will be mounted as `$value.mountPath/$key`. `$value.content` denotes file content (recommended to be used with `--set-file`). | `{}` |
| Parameter | Description | Default |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| `configurationEnvPrefix` | Prefix for environment variables to use that should be parsed as command line arguments. | `APP` |
| `commandLine` | Map of command line arguments passed to the streams app. | `{}` |
| `env` | Custom environment variables | `{}` |
| `secrets` | Custom secret environment variables. Prefix with `configurationEnvPrefix` in order to pass secrets to command line or prefix with `KAFKA_` to pass secrets to Kafka Streams configuration. E.g., `APP_MY_PARAM` would be passed as `--my-param` and `KAFKA_MAX_POLL_TIMEOUT_MS` would be translated to `max.poll.timeout.ms`. | `{}` |
| `secretRefs` | Inject existing secrets as environment variables. Map key is used as environment variable name. Value consists of secret `name` and `key`. | `{}` |
| `secretFilesRefs` | Mount existing secrets as volumes | `[]` |
| `files` | Map of files to mount for the app. File will be mounted as `$value.mountPath/$key`. `$value.content` denotes file content (recommended to be used with `--set-file`). | `{}` |

### JMX Configuration

Expand Down
6 changes: 3 additions & 3 deletions charts/streams-app/templates/deployment.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -88,7 +88,7 @@ spec:
- name: ENV_PREFIX
value: {{ .Values.configurationEnvPrefix }}_
{{- range $key, $value := .Values.streams.config }}
- name: {{ printf "STREAMS_%s" $key | replace "." "_" | upper | quote }}
- name: {{ printf "KAFKA_%s" $key | replace "." "_" | upper | quote }}
value: {{ $value | quote }}
{{- end }}
{{- range .Values.ports }}
Expand All @@ -97,12 +97,12 @@ spec:
valueFrom:
fieldRef:
fieldPath: status.podIP
- name: STREAMS_APPLICATION_SERVER
- name: KAFKA_APPLICATION_SERVER
value: "$(POD_IP):{{ .containerPort }}"
{{- end }}
{{- end }}
{{- if .Values.streams.staticMembership }}
- name: STREAMS_GROUP_INSTANCE_ID
- name: KAFKA_GROUP_INSTANCE_ID
valueFrom:
fieldRef:
fieldPath: metadata.name
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -125,8 +125,8 @@ public static int startApplicationWithoutExit(final KafkaApplication<?, ?, ?, ?,
}

private static String[] addEnvironmentVariablesArguments(final String[] args) {
Preconditions.checkArgument(!ENV_PREFIX.equals(EnvironmentStreamsConfigParser.PREFIX),
"Prefix '" + EnvironmentStreamsConfigParser.PREFIX + "' is reserved for Streams config");
Preconditions.checkArgument(!ENV_PREFIX.equals(EnvironmentKafkaConfigParser.PREFIX),
"Prefix '" + EnvironmentKafkaConfigParser.PREFIX + "' is reserved for Kafka config");
final List<String> environmentArguments = new EnvironmentArgumentsParser(ENV_PREFIX)
.parseVariables(System.getenv());
final Collection<String> allArgs = new ArrayList<>(environmentArguments);
Expand Down
1 change: 0 additions & 1 deletion streams-bootstrap-core/build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,6 @@ dependencies {
name = "slf4j-api",
version = "2.0.9"
) // required because other dependencies use Slf4j 1.x which is not properly resolved if this library is used in test scope
implementation(group = "com.google.guava", name = "guava", version = "33.0.0-jre")
implementation(group = "org.jooq", name = "jool", version = "0.9.14")

val junitVersion: String by project
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,7 @@ private static Map<String, Object> createBaseConfig(final KafkaEndpointConfig en
* </li>
* <li>
* Configs provided via environment variables (see
* {@link EnvironmentStreamsConfigParser#parseVariables(Map)})
* {@link EnvironmentKafkaConfigParser#parseVariables(Map)})
* </li>
* <li>
* Configs provided by {@link AppConfiguration#getKafkaConfig()}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -92,7 +92,7 @@ private static Map<String, Object> createBaseConfig(final KafkaEndpointConfig en
* </li>
* <li>
* Configs provided via environment variables (see
* {@link EnvironmentStreamsConfigParser#parseVariables(Map)})
* {@link EnvironmentKafkaConfigParser#parseVariables(Map)})
* </li>
* <li>
* Configs provided by {@link AppConfiguration#getKafkaConfig()}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -31,20 +31,20 @@
import java.util.stream.Collectors;

/**
* Parse configuration properties of a Kafka Streams app from environment variables
* Parse configuration properties of a Kafka app from environment variables
*/
public final class EnvironmentStreamsConfigParser {
public final class EnvironmentKafkaConfigParser {

static final String PREFIX = "STREAMS_";
static final String PREFIX = "KAFKA_";
private static final Pattern UNDERSCORE = Pattern.compile("_");
private static final Pattern PREFIX_PATTERN = Pattern.compile("^" + PREFIX);

private EnvironmentStreamsConfigParser() {
private EnvironmentKafkaConfigParser() {
throw new UnsupportedOperationException("Utility class");
}

/**
* Parse a list of environment variables as a streams configuration. All variables starting with {@code STREAMS_}
* Parse a list of environment variables as a streams configuration. All variables starting with {@code KAFKA_}
* prefix are converted. {@code _} are replaced by {@code .}
*
* @param environment map of environment variables
Expand All @@ -53,7 +53,7 @@ private EnvironmentStreamsConfigParser() {
public static Map<String, String> parseVariables(final Map<String, String> environment) {
return environment.entrySet().stream()
.filter(e -> e.getKey().startsWith(PREFIX))
.collect(Collectors.toMap(EnvironmentStreamsConfigParser::convertEnvironmentVariable, Entry::getValue));
.collect(Collectors.toMap(EnvironmentKafkaConfigParser::convertEnvironmentVariable, Entry::getValue));
}

private static String convertEnvironmentVariable(final Entry<String, String> environmentEntry) {
Expand Down
Loading

0 comments on commit 58e7a77

Please sign in to comment.