Check Scanner using OpenShift, Object Storage and Event Streams
This sample application uses an Apache Kafka based messaging service to orchestrate long running workloads to applications. This pattern is used to decouple your application allowing greater control over scaling and performance. Event Streams can be used to queue up the work to be done without impacting the producer applications, making it an ideal system for long-running tasks.
You will simulate this pattern using a check processing example. First you will create a UI application which will be used to upload checks to Object Storage and generate messages indicating work to be done. Next, you will create a separate worker application which will asynchronously process the user uploaded checks when it receives messages.
Check Scanner is composed of:
- Check Upload UI microservice
- Check Processor worker microservice
- Object Storage for storing files
- Event Streams as a work queue
- The user uploads an image of a check using the Check Upload UI application
- File is saved in IBM Cloud Object Storage
- Message is sent to IBM Cloud Event Streams topic indicating the new file is awaiting processing.
- When ready, Check Processor application receives the message and begins processing the new image.
- When complete, it updates the image in IBM Cloud Object Storage.