diff --git a/.github/dependabot.yml b/.github/dependabot.yml
index 8b04a2dfc..1ed796abb 100644
--- a/.github/dependabot.yml
+++ b/.github/dependabot.yml
@@ -27,6 +27,14 @@ updates:
reviewers:
- "masesdevelopers"
target-branch: "release/2.7.X"
+
+ - package-ecosystem: "nuget" # See documentation for possible values
+ directory: "/src/net" # Location of package manifests
+ schedule:
+ interval: "weekly"
+ reviewers:
+ - "masesdevelopers"
+ target-branch: "release/2.8.X"
- package-ecosystem: maven
directory: "/src/jvm/knet"
@@ -51,6 +59,14 @@ updates:
- "masesdevelopers"
target-branch: "release/2.7.X"
+ - package-ecosystem: maven
+ directory: "/src/jvm/knet"
+ schedule:
+ interval: "weekly"
+ reviewers:
+ - "masesdevelopers"
+ target-branch: "release/2.8.X"
+
- package-ecosystem: "github-actions"
directory: "/"
schedule:
@@ -72,4 +88,12 @@ updates:
interval: "weekly"
reviewers:
- "masesdevelopers"
- target-branch: "release/2.7.X"
\ No newline at end of file
+ target-branch: "release/2.7.X"
+
+ - package-ecosystem: "github-actions"
+ directory: "/"
+ schedule:
+ interval: "weekly"
+ reviewers:
+ - "masesdevelopers"
+ target-branch: "release/2.8.X"
\ No newline at end of file
diff --git a/.github/workflows/generateclasses.yaml b/.github/workflows/generateclasses.yaml
index af5613eb7..dac0dea85 100644
--- a/.github/workflows/generateclasses.yaml
+++ b/.github/workflows/generateclasses.yaml
@@ -18,7 +18,7 @@ on:
default: false
type: boolean
ContinueOnLatestJNetReflectorError:
- description: 'Shall continue execution in case of failure of build from latest unpublished version of JNetReflector'
+ description: 'Shall continue execution in case of failure of build from latest reflection done with JNetReflector'
required: true
default: false
type: boolean
@@ -66,7 +66,7 @@ jobs:
gpg-passphrase: MAVEN_GPG_PASSPHRASE # env variable for GPG private key passphrase
- name: Create Jars
- run: mvn --file ./src/jvm/knet/pom.xml --no-transfer-progress package
+ run: mvn "-DmavenSkipMain=true" --file ./src/jvm/knet/pom.xml --no-transfer-progress package
env:
MAVEN_USERNAME: ${{ secrets.MAVEN_USERNAME }}
MAVEN_CENTRAL_TOKEN: ${{ secrets.MAVEN_CENTRAL_TOKEN }}
diff --git a/README.md b/README.md
index 5c0dddabf..03a665ed3 100644
--- a/README.md
+++ b/README.md
@@ -1,6 +1,6 @@
-# KNet: .NET suite for [Apache Kafka™](https://kafka.apache.org/)
+# KNet: .NET suite for [Apache Kafkaâ„¢](https://kafka.apache.org/)
-KNet is a comprehensive .NET suite for [Apache Kafka™](https://kafka.apache.org/) providing access to all [APIs](https://kafka.apache.org/documentation/#api) and features: Producer, Consumer, Admin, Streams, Connect, backends (ZooKeeper and Kafka).
+KNet is a comprehensive .NET suite for [Apache Kafkaâ„¢](https://kafka.apache.org/) providing access to all [APIs](https://kafka.apache.org/documentation/#api) and features: Producer, Consumer, Admin, Streams, Connect, backends (ZooKeeper and Kafka).
### Libraries and Tools
@@ -16,38 +16,41 @@ KNet is a comprehensive .NET suite for [Apache Kafka
### Project disclaimer
-KNet is a suite for Apache Kafka™, curated by MASES Group, can be supported by the open-source community.
+KNet is a suite for Apache Kafkaâ„¢, curated by MASES Group, can be supported by the open-source community.
Its primary scope is to support other, public or internal, MASES Group projects: open-source community and commercial entities can use it for their needs and support this project, moreover there are dedicated community and commercial subscription plans.
-The repository code and releases may contain bugs, the release cycle depends from Apache Kafka™ release cycle, critical discovered issues and/or enhancement requested from this or other projects.
+The repository code and releases may contain bugs, the release cycle depends from Apache Kafkaâ„¢ release cycle, critical discovered issues and/or enhancement requested from this or other projects.
-Looking for the help of Apache Kafka™ experts? MASES Group can help you design, build, deploy, and manage Apache Kafka™ clusters and streaming applications.
+Looking for the help of Apache Kafkaâ„¢ experts? MASES Group can help you design, build, deploy, and manage Apache Kafkaâ„¢ clusters and streaming applications.
---
## Scope of the project
-This project aims to create a set of libraries and tools to direct access, from .NET, all the features available in the [Apache Kafka™ binary distribution](https://kafka.apache.org/downloads).
+This project aims to create a set of libraries and tools to direct access, from .NET, all the features available in the [Apache Kafkaâ„¢ binary distribution](https://kafka.apache.org/downloads).
-There are many client libraries written to manage communication with Apache Kafka™. Conversely, this project use directly the Java packages released from The Apache Foundation giving more than one benefit:
+There are many client libraries written to manage communication with Apache Kafkaâ„¢. Conversely, this project use directly the Java packages released from The Apache Foundation giving more than one benefit:
* all implemented features are availables at no extra implementation costs, see [KNet usage](src/documentation/articles/usage.md);
* avoids any third party communication protocol implementation;
-* access all features made available from Apache Kafka™: the most important are Apache Kafka™ Streams and Apache Kafka™ Connect which does not have any C# implementation;
+* access all features made available from Apache Kafkaâ„¢: the most important are Apache Kafkaâ„¢ Streams and Apache Kafkaâ„¢ Connect which does not have any C# implementation;
* measured high [performance](src/documentation/articles/performance.md) in many operating conditions.
-Currently the project tries to support, at our best, the [supported Apache Kafka™ binary distribution](https://kafka.apache.org/downloads):
-- Apache Kafka™ version 3.8.*:
+Currently the project tries to support, at our best, the [supported Apache Kafkaâ„¢ binary distribution](https://kafka.apache.org/downloads):
+- Apache Kafkaâ„¢ version 3.9.*:
+ - branch [master](https://github.com/masesgroup/KNet)
+ - KNet version 2.9.*
+- Apache Kafkaâ„¢ version 3.8.*:
- branch [master](https://github.com/masesgroup/KNet)
- KNet version 2.8.*
-- Apache Kafka™ version 3.7.*:
+- Apache Kafkaâ„¢ version 3.7.*:
- branch [release/2.7.X](https://github.com/masesgroup/KNet/tree/release/2.7.X)
- KNet version 2.7.*
-- Apache Kafka™ version 3.6.*:
+- Apache Kafkaâ„¢ version 3.6.*:
- branch [release/2.6.X](https://github.com/masesgroup/KNet/tree/release/2.6.X)
- KNet version 2.6.*
-The Apache Kafka™ packages are downloaded from:
+The Apache Kafkaâ„¢ packages are downloaded from:
|kafka-clients | kafka-streams | kafka-tools | kafka_2.13 |
|:---: |:---: |:---: |:---: |
@@ -90,17 +93,17 @@ This project adheres to the Contributor [Covenant code of conduct](CODE_OF_CONDU
### News
-* V1.4.4+: From version 1.4.4 there is a new project, named KNetPS, which permits to write PowerShell client scripts for an Apache Kafka™ cluster and many other things, [here full usage](src/documentation/articles/usagePS.md).
-* V1.4.7+: From version 1.4.7 there is a new project, named KNetConnect, to execute Apache Kafka™ Connect related jobs, [here full usage](src/documentation/articles/usageConnect.md).
+* V1.4.4+: From version 1.4.4 there is a new project, named KNetPS, which permits to write PowerShell client scripts for an Apache Kafkaâ„¢ cluster and many other things, [here full usage](src/documentation/articles/usagePS.md).
+* V1.4.7+: From version 1.4.7 there is a new project, named KNetConnect, to execute Apache Kafkaâ„¢ Connect related jobs, [here full usage](src/documentation/articles/usageConnect.md).
* V1.5.4+: From version 1.5.4 there are new packages dedicated to [KNet Serializer/Deserializer](src/documentation/articles/usageSerDes.md)
-* V2.0.0+: From version 2.0.0 the code base is fully reflected from the JARs of the Apache Kafka™ distribution downloaded from Maven; some developed classes still remains beside the specific KNet implementations
+* V2.0.0+: From version 2.0.0 the code base is fully reflected from the JARs of the Apache Kafkaâ„¢ distribution downloaded from Maven; some developed classes still remains beside the specific KNet implementations
* V2.4.0+: From version 2.4.0 it is available the new KNet Streams SDK
* V2.5.0+: From version 2.5.0 there are two breaking changes: uses `Java.Lang.String` instead of `string` (`System.String`) in generated classes and KNet Streams SDK manages the counter-part JVM types
* V2.7.0+: From version 2.7.0:
* all classes KNetProducer, KNetConsumer and KNet Streams SDK manage the counter-part JVM types
* serializers supports data exchange based on `byte` array and `ByteBuffer`
* version 2.7.2 introduces `ISerDesSelector` to optimize serialization selection based on `byte` array or `ByteBuffer`
-* V2.8.0+: From version 2.8.0: supports Apache Kafka™ version 3.8.*
+* V2.8.0+: From version 2.8.0: supports Apache Kafkaâ„¢ version 3.8.*
---
@@ -111,9 +114,9 @@ KNet uses [JNet](https://github.com/masesgroup/JNet), and indeed [JCOBridge](htt
* [JVM](https://en.wikipedia.org/wiki/Java_virtual_machine) and [CLR, or CoreCLR,](https://en.wikipedia.org/wiki/Common_Language_Runtime) runs in the same process, but are insulated from each other;
* JCOBridge does not make any code injection into JVM;
* JCOBridge does not use any other communication mechanism than JNI;
- * .NET (CLR) inherently inherits the cyber-security levels of running JVM and Apache Kafka™;
+ * .NET (CLR) inherently inherits the cyber-security levels of running JVM and Apache Kafkaâ„¢;
* **Direct access the JVM from any .NET application**:
- * Any Java/Scala class behind Apache Kafka™ can be directly managed: Consumer, Producer, Administration, Streams, Server-side, and so on;
+ * Any Java/Scala class behind Apache Kafkaâ„¢ can be directly managed: Consumer, Producer, Administration, Streams, Server-side, and so on;
* No need to learn new APIs: we try to expose the same APIs in C# style;
* No extra validation cycle on protocol and functionality: bug fix, improvements, new features are immediately available;
* Documentation is shared;
diff --git a/src/README.md b/src/README.md
index 35c5892cf..80b34eccc 100644
--- a/src/README.md
+++ b/src/README.md
@@ -2,8 +2,16 @@
The command used to build the classes is the following:
+1. Download the latest version of reflection utility:
+
+```cmd
+dotnet tool update -g MASES.JNetReflector
+```
+
+2. Run the reflection utility:
+
```cmd
-MASES.JNetReflector.exe -TraceLevel 0 -OriginRootPath .\jars -DestinationRootPath .\src\ -ConfigurationFile .\src\configuration.json
+jnetreflector -TraceLevel 0 -OriginRootPath .\jars -DestinationRootPath .\src\ -ConfigurationFile .\src\configuration.json
```
The configuration is:
@@ -18,67 +26,72 @@ The configuration is:
"DisableInterfaceMethodGeneration": true,
"CreateInterfaceInheritance": true,
"JarList": [
- "kafka_2.13-3.8.0.jar",
- "kafka-clients-3.8.0.jar",
- "kafka-streams-3.8.0.jar",
- "kafka-tools-3.8.0.jar",
- "kafka-raft-3.8.0.jar",
- "connect-api-3.8.0.jar",
- "connect-basic-auth-extension-3.8.0.jar",
- "connect-json-3.8.0.jar",
- "connect-mirror-3.8.0.jar",
- "connect-mirror-client-3.8.0.jar",
- "connect-runtime-3.8.0.jar",
- "connect-transforms-3.8.0.jar"
+ "kafka_2.13-3.9.0.jar",
+ "kafka-clients-3.9.0.jar",
+ "kafka-streams-3.9.0.jar",
+ "kafka-tools-3.9.0.jar",
+ "kafka-raft-3.9.0.jar",
+ "kafka-shell-3.9.0.jar",
+ "connect-api-3.9.0.jar",
+ "connect-basic-auth-extension-3.9.0.jar",
+ "connect-json-3.9.0.jar",
+ "connect-mirror-3.9.0.jar",
+ "connect-mirror-client-3.9.0.jar",
+ "connect-runtime-3.9.0.jar",
+ "connect-transforms-3.9.0.jar"
],
"OriginJavadocJARVersionAndUrls": [
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka_2.13/3.8.0/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka_2.13/3.9.0/"
+ },
+ {
+ "Version": 8,
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka-clients/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka-clients/3.8.0/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka-streams/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka-streams/3.8.0/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka-tools/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka-tools/3.8.0/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka-raft/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka-raft/3.8.0/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka-shell/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-api/3.8.0/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-api/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-basic-auth-extension/3.8.0/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-basic-auth-extension/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-json/3.8.0/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-json/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-mirror/3.8.0/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-mirror/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-mirror-client/3.8.0/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-mirror-client/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-runtime/3.8.0/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-runtime/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-transforms/3.8.0/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-transforms/3.9.0/"
}
],
"NamespacesToAvoid": [
@@ -136,6 +149,10 @@ The configuration is:
"org.apache.kafka.raft.internals",
"org.apache.kafka.server",
"org.apache.kafka.shaded",
+ "org.apache.kafka.shell.command",
+ "org.apache.kafka.shell.glob",
+ "org.apache.kafka.shell.node",
+ "org.apache.kafka.shell.state",
"org.apache.kafka.streams.internals",
"org.apache.kafka.streams.processor.internals",
"org.apache.kafka.streams.state.internals",
diff --git a/src/configuration.json b/src/configuration.json
index 0e7ccf191..c3174ecff 100644
--- a/src/configuration.json
+++ b/src/configuration.json
@@ -7,72 +7,72 @@
"DisableInterfaceMethodGeneration": true,
"CreateInterfaceInheritance": true,
"JarList": [
- "kafka_2.13-3.8.1.jar",
- "kafka-clients-3.8.1.jar",
- "kafka-streams-3.8.1.jar",
- "kafka-tools-3.8.1.jar",
- "kafka-raft-3.8.1.jar",
- "kafka-shell-3.8.1.jar",
- "connect-api-3.8.1.jar",
- "connect-basic-auth-extension-3.8.1.jar",
- "connect-json-3.8.1.jar",
- "connect-mirror-3.8.1.jar",
- "connect-mirror-client-3.8.1.jar",
- "connect-runtime-3.8.1.jar",
- "connect-transforms-3.8.1.jar"
+ "kafka_2.13-3.9.0.jar",
+ "kafka-clients-3.9.0.jar",
+ "kafka-streams-3.9.0.jar",
+ "kafka-tools-3.9.0.jar",
+ "kafka-raft-3.9.0.jar",
+ "kafka-shell-3.9.0.jar",
+ "connect-api-3.9.0.jar",
+ "connect-basic-auth-extension-3.9.0.jar",
+ "connect-json-3.9.0.jar",
+ "connect-mirror-3.9.0.jar",
+ "connect-mirror-client-3.9.0.jar",
+ "connect-runtime-3.9.0.jar",
+ "connect-transforms-3.9.0.jar"
],
"OriginJavadocJARVersionAndUrls": [
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka_2.13/3.8.1/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka_2.13/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka-clients/3.8.1/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka-clients/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka-streams/3.8.1/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka-streams/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka-tools/3.8.1/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka-tools/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka-raft/3.8.1/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka-raft/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka-shell/3.8.1/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/kafka-shell/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-api/3.8.1/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-api/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-basic-auth-extension/3.8.1/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-basic-auth-extension/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-json/3.8.1/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-json/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-mirror/3.8.1/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-mirror/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-mirror-client/3.8.1/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-mirror-client/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-runtime/3.8.1/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-runtime/3.9.0/"
},
{
"Version": 8,
- "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-transforms/3.8.1/"
+ "Url": "https://www.javadoc.io/doc/org.apache.kafka/connect-transforms/3.9.0/"
}
],
"NamespacesToAvoid": [
diff --git a/src/documentation/articles/docker.md b/src/documentation/articles/docker.md
index 79c005e6b..0f33f70cc 100644
--- a/src/documentation/articles/docker.md
+++ b/src/documentation/articles/docker.md
@@ -1,6 +1,6 @@
---
-title: Docker images of .NET suite for Apache Kafka™
-_description: Describes the Docker images of .NET suite for Apache Kafka™
+title: Docker images of .NET suite for Apache Kafkaâ„¢
+_description: Describes the Docker images of .NET suite for Apache Kafkaâ„¢
---
@@ -11,7 +11,7 @@ _description: Describes the Docker images of .NET suite for Apache Kafka
# KNet: Docker images
-.NET suite for Apache Kafka™ comes with a ready made Docker image can work in multiple modes, the image name is _knet_:
+.NET suite for Apache Kafkaâ„¢ comes with a ready made Docker image can work in multiple modes, the image name is _knet_:
- it is avialble in the following registries:
- GitHub: https://github.com/masesgroup/KNet/pkgs/container/knet
- Docker Hub: https://hub.docker.com/repository/docker/masesgroup/knet/general
@@ -23,9 +23,9 @@ The container image can work in multiple modes based on the environment variable
- the Docker image will issue the command:
> dotnet /app/MASES.KNetCLI.dll $@
-- The image can run [ZooKeeper™](https://zookeeper.apache.org/) node and/or [Apache Kafka™](https://kafka.apache.org/) broker node using specific values for **KNET_DOCKER_RUNNING_MODE**:
+- The image can run [ZooKeeperâ„¢](https://zookeeper.apache.org/) node and/or [Apache Kafkaâ„¢](https://kafka.apache.org/) broker node using specific values for **KNET_DOCKER_RUNNING_MODE**:
- - **KNET_DOCKER_RUNNING_MODE**=**zookeeper**: starts a [ZooKeeper™](https://zookeeper.apache.org/) node, defaults to run a standalone [ZooKeeper™](https://zookeeper.apache.org/) exposing on port 2181
+ - **KNET_DOCKER_RUNNING_MODE**=**zookeeper**: starts a [ZooKeeperâ„¢](https://zookeeper.apache.org/) node, defaults to run a standalone [ZooKeeperâ„¢](https://zookeeper.apache.org/) exposing on port 2181
- the Docker image will issue the command:
> dotnet /app/MASES.KNetCLI.dll zookeeperstart -Log4JConfiguration /app/config_container/log4j.properties /app/config_container/zookeeper.properties
- the image can add, or update, configuration variables of zookeeper.properties using the following pattern for environment variables:
@@ -34,7 +34,7 @@ The container image can work in multiple modes based on the environment variable
- The value of the environment variable is the value will be used in the configuration file
- The default file is available at https://github.com/masesgroup/KNet/blob/master/src/container/config_container/zookeeper.properties, all configuration information are available at https://zookeeper.apache.org/doc/r3.8.3/index.html
- - **KNET_DOCKER_RUNNING_MODE**=**broker**: starts an [Apache Kafka™](https://kafka.apache.org/) broker node, defaults to run a standalone broker exposing on port 9092
+ - **KNET_DOCKER_RUNNING_MODE**=**broker**: starts an [Apache Kafkaâ„¢](https://kafka.apache.org/) broker node, defaults to run a standalone broker exposing on port 9092
- the Docker image will issue the command:
> dotnet /app/MASES.KNetCLI.dll kafkastart -Log4JConfiguration /app/config_container/log4j.properties /app/config_container/server.properties
- the image can add, or update, configuration variables of server.properties using the following pattern for environment variables:
@@ -44,11 +44,11 @@ The container image can work in multiple modes based on the environment variable
- As an example: the environment variable **KAFKA_ADVERTISED_LISTENERS** represents **advertised.listeners**
- The default file is available at https://github.com/masesgroup/KNet/blob/master/src/container/config_container/server.properties, all configuration information are available at https://kafka.apache.org/documentation/
- - **KNET_DOCKER_RUNNING_MODE**=**server**: starts, within the container, both a [ZooKeeper™](https://zookeeper.apache.org/) node and an [Apache Kafka™](https://kafka.apache.org/) broker node, it defaults to run exposing [ZooKeeper™](https://zookeeper.apache.org/) on port 2181 and [Apache Kafka™](https://kafka.apache.org/) broker on port 9092; the image can add, or update, configuration variables of [ZooKeeper™](https://zookeeper.apache.org/) and [Apache Kafka™](https://kafka.apache.org/) using the same pattern of previous points.
+ - **KNET_DOCKER_RUNNING_MODE**=**server**: starts, within the container, both a [ZooKeeperâ„¢](https://zookeeper.apache.org/) node and an [Apache Kafkaâ„¢](https://kafka.apache.org/) broker node, it defaults to run exposing [ZooKeeperâ„¢](https://zookeeper.apache.org/) on port 2181 and [Apache Kafkaâ„¢](https://kafka.apache.org/) broker on port 9092; the image can add, or update, configuration variables of [ZooKeeperâ„¢](https://zookeeper.apache.org/) and [Apache Kafkaâ„¢](https://kafka.apache.org/) using the same pattern of previous points.
-- The image can run [Apache Kafka™](https://kafka.apache.org/) in [KRaft](https://developer.confluent.io/learn/kraft/) mode using specific values for **KNET_DOCKER_RUNNING_MODE**:
+- The image can run [Apache Kafkaâ„¢](https://kafka.apache.org/) in [KRaft](https://developer.confluent.io/learn/kraft/) mode using specific values for **KNET_DOCKER_RUNNING_MODE**:
- - **KNET_DOCKER_RUNNING_MODE**=**kraft-broker**: starts a [Apache Kafka™](https://kafka.apache.org/) as broker node
+ - **KNET_DOCKER_RUNNING_MODE**=**kraft-broker**: starts a [Apache Kafkaâ„¢](https://kafka.apache.org/) as broker node
- the Docker image will issue the command:
> dotnet /app/MASES.KNetCLI.dll kafkastart -Log4JConfiguration /app/config_container/log4j.properties /app/config_container/kraft/broker.properties
- the image can add, or update, configuration variables of broker.properties using the following pattern for environment variables:
@@ -57,7 +57,7 @@ The container image can work in multiple modes based on the environment variable
- The value of the environment variable is the value will be used in the configuration file
- The default file is available at https://github.com/masesgroup/KNet/blob/master/src/container/config_container/kraft/broker.properties, all configuration information are available at https://kafka.apache.org/documentation/
- - **KNET_DOCKER_RUNNING_MODE**=**kraft-controller**: starts a [Apache Kafka™](https://kafka.apache.org/) as controller node
+ - **KNET_DOCKER_RUNNING_MODE**=**kraft-controller**: starts a [Apache Kafkaâ„¢](https://kafka.apache.org/) as controller node
- the Docker image will issue the command:
> dotnet /app/MASES.KNetCLI.dll kafkastart -Log4JConfiguration /app/config_container/log4j.properties /app/config_container/kraft/controller.properties
- the image can add, or update, configuration variables of controller.properties using the following pattern for environment variables:
@@ -66,7 +66,7 @@ The container image can work in multiple modes based on the environment variable
- The value of the environment variable is the value will be used in the configuration file
- The default file is available at https://github.com/masesgroup/KNet/blob/master/src/container/config_container/kraft/controller.properties, all configuration information are available at https://kafka.apache.org/documentation/
- - **KNET_DOCKER_RUNNING_MODE**=**kraft-server**: starts a [Apache Kafka™](https://kafka.apache.org/) as server node
+ - **KNET_DOCKER_RUNNING_MODE**=**kraft-server**: starts a [Apache Kafkaâ„¢](https://kafka.apache.org/) as server node
- the Docker image will issue the command:
> dotnet /app/MASES.KNetCLI.dll kafkastart -Log4JConfiguration /app/config_container/log4j.properties /app/config_container/kraft/server.properties
- the image can add, or update, configuration variables of server.properties using the following pattern for environment variables:
@@ -95,10 +95,10 @@ The container image can work in multiple modes based on the environment variable
> dotnet /app/MASES.KNetConnect.dll -s -Log4JConfiguration /app/config_container/log4j.properties /app/config_container/connect-standalone.properties /app/config_container/connect-knet-specific.properties
- the image can add, or update, configuration variables of connect-standalone.properties and connect-knet-specific.properties using the same pattern of **knet-connect-standalone**:
- - **KNET_DOCKER_RUNNING_MODE**=**knet-connect-standalone-server**: starts, within the container, a [ZooKeeper™](https://zookeeper.apache.org/) node and an [Apache Kafka™](https://kafka.apache.org/) broker node like in **server**, then starts the same command of **knet-connect-standalone**; this is an autonoumous instance can be used for development or any other possible usage
+ - **KNET_DOCKER_RUNNING_MODE**=**knet-connect-standalone-server**: starts, within the container, a [ZooKeeperâ„¢](https://zookeeper.apache.org/) node and an [Apache Kafkaâ„¢](https://kafka.apache.org/) broker node like in **server**, then starts the same command of **knet-connect-standalone**; this is an autonoumous instance can be used for development or any other possible usage
- the image can add, or update, configuration variables of using the same pattern of **zookeeper**, **broker** and **knet-connect-standalone**
- - **KNET_DOCKER_RUNNING_MODE**=**connect-standalone-server**: starts, within the container, a [ZooKeeper™](https://zookeeper.apache.org/) node and an [Apache Kafka™](https://kafka.apache.org/) broker node like in **server**, then starts the same command of **connect-standalone**; this is an autonoumous instance can be used for development or any other possible usage
+ - **KNET_DOCKER_RUNNING_MODE**=**connect-standalone-server**: starts, within the container, a [ZooKeeperâ„¢](https://zookeeper.apache.org/) node and an [Apache Kafkaâ„¢](https://kafka.apache.org/) broker node like in **server**, then starts the same command of **connect-standalone**; this is an autonoumous instance can be used for development or any other possible usage
- the image can add, or update, configuration variables of using the same pattern of **zookeeper**, **broker** and **connect-standalone**
- **KNET_DOCKER_RUNNING_MODE**=**knet-connect-distributed**: starts, within the container, a distributed KNet Connect instance
diff --git a/src/documentation/articles/intro.md b/src/documentation/articles/intro.md
index f2769e5ce..63c358884 100644
--- a/src/documentation/articles/intro.md
+++ b/src/documentation/articles/intro.md
@@ -1,11 +1,11 @@
---
-title: .NET suite for Apache Kafka™
-_description: Main page of .NET suite for Apache Kafka™
+title: .NET suite for Apache Kafkaâ„¢
+_description: Main page of .NET suite for Apache Kafkaâ„¢
---
-# KNet: .NET suite for [Apache Kafka™](https://kafka.apache.org/)
+# KNet: .NET suite for [Apache Kafkaâ„¢](https://kafka.apache.org/)
-KNet is a comprehensive .NET suite for [Apache Kafka™](https://kafka.apache.org/) providing access to all [APIs](https://kafka.apache.org/documentation/#api) and features: Producer, Consumer, Admin, Streams, Connect, backends (ZooKeeper and Kafka™).
+KNet is a comprehensive .NET suite for [Apache Kafkaâ„¢](https://kafka.apache.org/) providing access to all [APIs](https://kafka.apache.org/documentation/#api) and features: Producer, Consumer, Admin, Streams, Connect, backends (ZooKeeper and Kafka™).
### Libraries and Tools
@@ -21,38 +21,41 @@ KNet is a comprehensive .NET suite for [Apache Kafka
### Project disclaimer
-KNet is a suite for Apache Kafka™, curated by MASES Group, can be supported by the open-source community.
+KNet is a suite for Apache Kafkaâ„¢, curated by MASES Group, can be supported by the open-source community.
Its primary scope is to support other, public or internal, MASES Group projects: open-source community and commercial entities can use it for their needs and support this project, moreover there are dedicated community and commercial subscription plans.
-The repository code and releases may contain bugs, the release cycle depends from Apache Kafka™ release cycle, critical discovered issues and/or enhancement requested from this or other projects.
+The repository code and releases may contain bugs, the release cycle depends from Apache Kafkaâ„¢ release cycle, critical discovered issues and/or enhancement requested from this or other projects.
-Looking for the help of Apache Kafka™ experts? MASES Group can help you design, build, deploy, and manage Apache Kafka™ clusters and streaming applications.
+Looking for the help of Apache Kafkaâ„¢ experts? MASES Group can help you design, build, deploy, and manage Apache Kafkaâ„¢ clusters and streaming applications.
---
## Scope of the project
-This project aims to create a set of libraries and tools to direct access, from .NET, all the features available in the [Apache Kafka™ binary distribution](https://kafka.apache.org/downloads).
+This project aims to create a set of libraries and tools to direct access, from .NET, all the features available in the [Apache Kafkaâ„¢ binary distribution](https://kafka.apache.org/downloads).
-There are many client libraries written to manage communication with Apache Kafka™. Conversely, this project use directly the Java packages released from The Apache Foundation giving more than one benefit:
+There are many client libraries written to manage communication with Apache Kafkaâ„¢. Conversely, this project use directly the Java packages released from The Apache Foundation giving more than one benefit:
* all implemented features are availables at no extra implementation costs, see [KNet usage](usage.md);
* avoids any third party communication protocol implementation;
-* access all features made available from Apache Kafka™: the most important are Apache Kafka™ Streams and Apache Kafka™ Connect which does not have any C# implementation;
+* access all features made available from Apache Kafkaâ„¢: the most important are Apache Kafkaâ„¢ Streams and Apache Kafkaâ„¢ Connect which does not have any C# implementation;
* measured high [performance](performance.md) in many operating conditions.
-Currently the project tries to support, at our best, the [supported Apache Kafka™ binary distribution](https://kafka.apache.org/downloads):
-- Apache Kafka™ version 3.8.*:
+Currently the project tries to support, at our best, the [supported Apache Kafkaâ„¢ binary distribution](https://kafka.apache.org/downloads):
+- Apache Kafkaâ„¢ version 3.9.*:
+ - branch [master](https://github.com/masesgroup/KNet)
+ - KNet version 2.9.*
+- Apache Kafkaâ„¢ version 3.8.*:
- branch [master](https://github.com/masesgroup/KNet)
- KNet version 2.8.*
-- Apache Kafka™ version 3.7.*:
+- Apache Kafkaâ„¢ version 3.7.*:
- branch [release/2.7.X](https://github.com/masesgroup/KNet/tree/release/2.7.X)
- KNet version 2.7.*
-- Apache Kafka™ version 3.6.*:
+- Apache Kafkaâ„¢ version 3.6.*:
- branch [release/2.6.X](https://github.com/masesgroup/KNet/tree/release/2.6.X)
- KNet version 2.6.*
-The Apache Kafka™ packages are downloaded from:
+The Apache Kafkaâ„¢ packages are downloaded from:
|kafka-clients | kafka-streams | kafka-tools | kafka_2.13 |
|:---: |:---: |:---: |:---: |
diff --git a/src/documentation/index.md b/src/documentation/index.md
index 008d87e5a..d8970b4ec 100644
--- a/src/documentation/index.md
+++ b/src/documentation/index.md
@@ -1,11 +1,11 @@
---
-title: .NET suite for Apache Kafka™
-_description: Main page of .NET suite for Apache Kafka™
+title: .NET suite for Apache Kafkaâ„¢
+_description: Main page of .NET suite for Apache Kafkaâ„¢
---
-# KNet: .NET suite for [Apache Kafka™](https://kafka.apache.org/)
+# KNet: .NET suite for [Apache Kafkaâ„¢](https://kafka.apache.org/)
-KNet is a comprehensive .NET suite for [Apache Kafka™](https://kafka.apache.org/) providing access to all [APIs](https://kafka.apache.org/documentation/#api) and features: Producer, Consumer, Admin, Streams, Connect, backends (ZooKeeper and Kafka).
+KNet is a comprehensive .NET suite for [Apache Kafkaâ„¢](https://kafka.apache.org/) providing access to all [APIs](https://kafka.apache.org/documentation/#api) and features: Producer, Consumer, Admin, Streams, Connect, backends (ZooKeeper and Kafka).
### Libraries and Tools
@@ -15,38 +15,38 @@ KNet is a comprehensive .NET suite for [Apache Kafka
### Project disclaimer
-KNet is a suite for Apache Kafka™, curated by MASES Group, can be supported by the open-source community.
+KNet is a suite for Apache Kafkaâ„¢, curated by MASES Group, can be supported by the open-source community.
Its primary scope is to support other, public or internal, MASES Group projects: open-source community and commercial entities can use it for their needs and support this project, moreover there are dedicated community and commercial subscription plans.
-The repository code and releases may contain bugs, the release cycle depends from Apache Kafka™ release cycle, critical discovered issues and/or enhancement requested from this or other projects.
+The repository code and releases may contain bugs, the release cycle depends from Apache Kafkaâ„¢ release cycle, critical discovered issues and/or enhancement requested from this or other projects.
-Looking for the help of Apache Kafka™ experts? MASES Group can help you design, build, deploy, and manage Apache Kafka™ clusters and streaming applications.
+Looking for the help of Apache Kafkaâ„¢ experts? MASES Group can help you design, build, deploy, and manage Apache Kafkaâ„¢ clusters and streaming applications.
---
## Scope of the project
-This project aims to create a set of libraries and tools to direct access, from .NET, all the features available in the [Apache Kafka™ binary distribution](https://kafka.apache.org/downloads).
+This project aims to create a set of libraries and tools to direct access, from .NET, all the features available in the [Apache Kafkaâ„¢ binary distribution](https://kafka.apache.org/downloads).
-There are many client libraries written to manage communication with Apache Kafka™. Conversely, this project use directly the Java packages released from The Apache Foundation giving more than one benefit:
+There are many client libraries written to manage communication with Apache Kafkaâ„¢. Conversely, this project use directly the Java packages released from The Apache Foundation giving more than one benefit:
* all implemented features are availables at no extra implementation costs, see [KNet usage](articles/usage.md);
* avoids any third party communication protocol implementation;
-* access all features made available from Apache Kafka™: the most important are Apache Kafka™ Streams and Apache Kafka™ Connect which does not have any C# implementation;
+* access all features made available from Apache Kafkaâ„¢: the most important are Apache Kafkaâ„¢ Streams and Apache Kafkaâ„¢ Connect which does not have any C# implementation;
* measured high [performance](articles/performance.md) in many operating conditions.
-Currently the project tries to support, at our best, the [supported Apache Kafka™ binary distribution](https://kafka.apache.org/downloads):
-- Apache Kafka™ version 3.8.*:
+Currently the project tries to support, at our best, the [supported Apache Kafkaâ„¢ binary distribution](https://kafka.apache.org/downloads):
+- Apache Kafkaâ„¢ version 3.8.*:
- branch [master](https://github.com/masesgroup/KNet)
- KNet version 2.8.*
-- Apache Kafka™ version 3.7.*:
+- Apache Kafkaâ„¢ version 3.7.*:
- branch [release/2.7.X](https://github.com/masesgroup/KNet/tree/release/2.7.X)
- KNet version 2.7.*
-- Apache Kafka™ version 3.6.*:
+- Apache Kafkaâ„¢ version 3.6.*:
- branch [release/2.6.X](https://github.com/masesgroup/KNet/tree/release/2.6.X)
- KNet version 2.6.*
-The Apache Kafka™ packages are downloaded from:
+The Apache Kafkaâ„¢ packages are downloaded from:
|kafka-clients | kafka-streams | kafka-tools | kafka_2.13 |
|:---: |:---: |:---: |:---: |
@@ -88,17 +88,17 @@ This project adheres to the Contributor [Covenant code of conduct](https://githu
### News
-* V1.4.4+: From version 1.4.4 there is a new project, named KNetPS, which permits to write PowerShell client scripts for an Apache Kafka™ cluster and many other things, [here full usage](articles/usagePS.md).
-* V1.4.7+: From version 1.4.7 there is a new project, named KNetConnect, to execute Apache Kafka™ Connect related jobs, [here full usage](articles/usageConnect.md).
+* V1.4.4+: From version 1.4.4 there is a new project, named KNetPS, which permits to write PowerShell client scripts for an Apache Kafkaâ„¢ cluster and many other things, [here full usage](articles/usagePS.md).
+* V1.4.7+: From version 1.4.7 there is a new project, named KNetConnect, to execute Apache Kafkaâ„¢ Connect related jobs, [here full usage](articles/usageConnect.md).
* V1.5.4+: From version 1.5.4 there are new packages dedicated to [KNet Serializer/Deserializer](articles/usageSerDes.md)
-* V2.0.0+: From version 2.0.0 the code base is fully reflected from the JARs of the Apache Kafka™ distribution downloaded from Maven; some developed classes still remains beside the specific KNet implementations
+* V2.0.0+: From version 2.0.0 the code base is fully reflected from the JARs of the Apache Kafkaâ„¢ distribution downloaded from Maven; some developed classes still remains beside the specific KNet implementations
* V2.4.0+: From version 2.4.0 it is available the new KNet Streams SDK
* V2.5.0+: From version 2.5.0 there are two breaking changes: uses `Java.Lang.String` instead of `string` (`System.String`) in generated classes and KNet Streams SDK manages the counter-part JVM types
* V2.7.0+: From version 2.7.0:
* all classes KNetProducer, KNetConsumer and KNet Streams SDK manage the counter-part JVM types
* serializers supports data exchange based on `byte` array and `ByteBuffer`
* version 2.7.2 introduces `ISerDesSelector` to optimize serialization selection based on `byte` array or `ByteBuffer`
-* V2.8.0+: From version 2.8.0: supports Apache Kafka™ version 3.8.*
+* V2.8.0+: From version 2.8.0: supports Apache Kafkaâ„¢ version 3.8.*
---
@@ -109,9 +109,9 @@ KNet uses [JNet](https://github.com/masesgroup/JNet), and indeed [JCOBridge](htt
* [JVM](https://en.wikipedia.org/wiki/Java_virtual_machine) and [CLR, or CoreCLR,](https://en.wikipedia.org/wiki/Common_Language_Runtime) runs in the same process, but are insulated from each other;
* JCOBridge does not make any code injection into JVM;
* JCOBridge does not use any other communication mechanism than JNI;
- * .NET (CLR) inherently inherits the cyber-security levels of running JVM and Apache Kafka™;
+ * .NET (CLR) inherently inherits the cyber-security levels of running JVM and Apache Kafkaâ„¢;
* **Direct access the JVM from any .NET application**:
- * Any Java/Scala class behind Apache Kafka™ can be directly managed: Consumer, Producer, Administration, Streams, Server-side, and so on;
+ * Any Java/Scala class behind Apache Kafkaâ„¢ can be directly managed: Consumer, Producer, Administration, Streams, Server-side, and so on;
* No need to learn new APIs: we try to expose the same APIs in C# style;
* No extra validation cycle on protocol and functionality: bug fix, improvements, new features are immediately available;
* Documentation is shared;
diff --git a/src/jvm/knet/pom.xml b/src/jvm/knet/pom.xml
index 386ee7ffb..9670b945a 100644
--- a/src/jvm/knet/pom.xml
+++ b/src/jvm/knet/pom.xml
@@ -40,7 +40,8 @@
11
11
${basedir}/classpathfile.classpath
- 3.8.1
+ false
+ 3.9.0
2.8.2.0
../../../bin/net8.0/JCOBridge.jar
../../../bin/net8.0/jars/jnet-2.5.10.0.jar
@@ -137,13 +138,9 @@
-cp
${originalClassPath}${path.separator}${basedir}/${jcobridgepath}${path.separator}${basedir}/${jnetpath}
+ ${mavenSkipMain}
-
- org.apache.maven.plugins
- maven-compiler-plugin
- 3.13.0
-
org.apache.maven.plugins
maven-source-plugin
@@ -252,17 +249,17 @@
io.netty
netty-codec
- 4.1.110.Final
+ 4.1.111.Final
io.netty
netty-handler
- 4.1.110.Final
+ 4.1.111.Final
io.netty
netty-transport-native-epoll
- 4.1.110.Final
+ 4.1.111.Final
com.google.errorprone