Konveyor AI (kai) is Konveyor's approach to easing modernization of application source code to a new target by leveraging LLMs with guidance from static code analysis augmented with data in Konveyor that helps to learn how an Organization solved a similar problem in the past.
- Kai Demo
In this demo, we will showcase the capabilities of Konveyor AI (Kai) in facilitating the modernization of application source code to a new target. We will illustrate how Kai can handle various levels of migration complexity, ranging from simple import swaps to more involved changes such as modifying scope from CDI bean requirements. Additionally, we will look into migration scenarios that involves EJB Remote and Message Driven Bean(MBD) changes
We will focus on migrating a partially migrated JavaEE Coolstore application to Quarkus, a task that involves not only technical translation but also considerations for deployment to Kubernetes. By the end of this demo, you will understand how Konveyor AI (Kai) can assist and expedite the modernization process.
- VSCode
- Git
- Kubernetes cluster (minikube)
- GenAI credentials
- Maven
- Quarkus 3.10
- Java 17
Additionally, you will need to have the Kai IDE plugin installed in VSCode. Download the latest from here.
You can configure Kai in multiple ways. The best
way to configure Kai is to follow the setup page to get started. After the
basic setup, additional configuration can be made by modifying settings.json
.
You will need to select an LLM model to use with Kai. Here are some examples of how to configure Kai to use different models. For more options, see llm_selection.md.
If you don't have access to an LLM, you also have the option to run Kai in demo mode, which uses cached responses.
Important
The demo assumes you are using IBM-served Llama 3. If you are using a different model, the responses you get back may be different.
Warning
In order to use this service an individual needs to obtain a w3id from IBM. The kai development team is unable to help obtaining this access.
- Login to https://bam.res.ibm.com/.
- To access via an API you can look at ‘Documentation’ after logging into https://bam.res.ibm.com/. You will see a field embedded in the 'Documentation' section where you can generate/obtain an API Key.
- Ensure you have exported the key via
export GENAI_KEY=my-secret-api-key-value
. and this should exist in the shell where VSCode is running
Next, ensure the following values are set in settings.json
:
{
"konveyor.kai.providerName": "ChatIBMGenAI",
"konveyor.kai.providerArgs": {
"model_id": "meta-llama/llama-3-70b-instruct",
"parameters": {
"max_new_tokens": 2048
}
}
}
Finally, start the Kai RPC server.
- Obtain your AWS API key from Amazon Bedrock.
- Export your
AWS_ACCESS_KEY_ID
,AWS_SECRET_ACCESS_KEY
, andAWS_DEFAULT_REGION
environment variables.
Next, paste the following into your settings.json
file:
{
"konveyor.kai.providerName": "ChatBedrock",
"konveyor.kai.providerArgs": {
"model_id": "meta.llama3-70b-instruct-v1:0",
"parameters": {}
}
}
Finally, start the Kai RPC server.
- Follow the directions from OpenAI here.
- Ensure you have exported the key via
export OPENAI_API_KEY=my-secret-api-key-value
Next, paste the following into your settings.json
file:
{
"konveyor.kai.providerName": "ChatOpenAI",
"konveyor.kai.providerArgs": {
"model": "gpt-3.5-turbo",
"parameters": {}
}
}
Finally, start the Kai RPC server.
- Follow the directions from OpenAI here.
- Ensure you have exported the key via
export OPENAI_API_KEY=my-secret-api-key-value
Next, paste the following into your settings.json
file:
{
"konveyor.kai.providerName": "ChatOpenAI",
"konveyor.kai.providerArgs": {
"model": "gpt-4o",
"parameters": {}
}
}
Finally, start the Kai RPC server.
If you don't have access to a GEN_AI
key, you can run the server in demo mode
which will use cached responses
To run the Kai server in demo mode, ensure konveyor.kai.demo_mode: true
is
set in settings.json
.
Let's clone the Coolstore application, which we will be used demo the migration process to Quarkus.
First, clone the Coolstore demo from its repository:
git clone https://github.com/konveyor-ecosystem/coolstore.git
Next, switch to the branch of the Coolstore app that's been partially migrated:
git checkout partial-migration
We will analyze the Coolstore application using the following migration targets to identify potential areas for improvement:
- cloud-readiness
- jakarta-ee
- jakarta-ee8
- jakarta-ee9
- quarkus
Let's perform our initial analysis:
- Open VSCode and load coolstore project if it is not already loaded.
- Follow the steps to run the analysis listed here
- Once the analysis is complete you will see incidents listed on the following files
src/main/java/com/redhat/coolstore/model/ShoppingCart.java
src/main/java/com/redhat/coolstore/model/InventoryEntity.java
src/main/java/com/redhat/coolstore/service/CatalogService.java
src/main/java/com/redhat/coolstore/service/ShippingService.java
src/main/java/com/redhat/coolstore/service/ShoppingCartOrderProcessor.java
Note
While the file src/main/java/com/redhat/coolstore/rest/RestApplication.java
is flagged, for the purpose of this demo it is okay to skip that file and
proceed.
The incidents in the above files will provide insights into potential issues or areas that require attention during the migration process.
- Right-click on the file
src/main/java/com/redhat/coolstore/model/ShoppingCart.java
. - Select Kai Fix-All.
- Accept the proposed changes.
- Repeat the same process for the file -
src/main/java/com/redhat/coolstore/model/InventoryEntity.java
.
The above steps show how Kai simplifies the translation of import namespaces, ensuring seamless automated migration of javax libraries to jakarta persistence libraries.
In this step, we will use Kai to modify the scope in CatalogService.java
to
adhere to Quarkus CDI bean requirements. Kai will handle this automatically,
ensuring seamless migration.
- Right-click on the file
src/main/java/com/redhat/coolstore/service/CatalogService.java
. - Select Kai Fix-All.
- Accept the proposed changes.
We will address EJB Remote and MDB functionalities in ShippingService.java
and
ShoppingCartOrderProcessor.java
respectively. Kai will guide us through
replacing EJBs with REST functionality and updating related imports and
annotations.
- Right-click on the file
src/main/java/com/redhat/coolstore/service/ShippingService.java
. - Select
Kai Fix-All
. - Accept the proposed changes.
Due to the absence of support for Remote EJBs in Quarkus, you will notice that these functionalities are removed and replaced with REST functionality.
-
Right-click on the file
src/main/java/com/redhat/coolstore/service/ShoppingCartOrderProcessor.java
. -
Select
Kai Fix-All
and accept the changes.
-
Note the changes made to
ordersEmitter
channel:@Inject @Channel("orders") Emitter<String> ordersEmitter;
Although this change is valid, it's important to note that the LLM is unaware of the number of consumers for
orders
channel. It assumed that there is a single consumer fororders
, but, this app has multiple consumers oforders
. Assuming there's only a single consumer can lead toio.smallrye.reactive.messaging.providers.wiring.TooManyDownstreamCandidatesException
. To avoid this, add the@Broadcast
annotation:import io.smallrye.reactive.messaging.annotations.Broadcast; @Inject @Channel("orders") @Broadcast Emitter<String> ordersEmitter;
-
Since the LLM doesn't have access to the project's
pom.xml
file, it lacks information about available dependencies. Update the import statements to the following:import org.eclipse.microprofile.reactive.messaging.Channel; import org.eclipse.microprofile.reactive.messaging.Emitter;
Although the app is deployable to any Kubernetes distribution. For the sake of simplicity we choose minikube.
Note
It is assumed that minikube is installed. If not you can follow the instructions here.
First, start minikube with the docker driver:
minikube start --driver=docker
Next, point your shell to minikube's docker daemon. Kubernetes may not be able to find the built images if they are not in the same docker daemon as minikube.
eval $(minikube docker-env)
The coolstore requires a PostgreSQL database. To install Postgres into minikube, we have added deploy scripts. run the scripts in the following order
kubectl apply -f deploy/kubernetes/persistent-volume.yaml
kubectl apply -f deploy/kubernetes/persistent-volume-claim.yaml
kubectl apply -f deploy/kubernetes/postgresql-deployment.yaml
kubectl apply -f deploy/kubernetes/postgresql-service.yaml
# Wait until the postgres pod is running
watch kubectl get all
This should setup the database ready for connections from the coolstore app.
To deploy the app, simply run the following command, it will create a docker image on the local drive and load the manifests into kubernetes to pull the image.
mvn clean compile package -Dquarkus.kubernetes.deploy=true
Once deployed, access the app via browser hitting the localhost and port. Note that it might take a minute when you open the website for the first time. To get this URL, run the following command:
minikube service list
In this demo, we showcased the capability of Kai in facilitating various types of code migrations within the Coolstore application. By leveraging Kai's capabilities, organizations can expedite the modernization process. If you are interested to learn more about our ongoing efforts and future plans, please reach out to us in the slack channel