blob: f99fccb054a4dcad7e09cf8415ca15775ecfe07f [file] [log] [blame]
pwielebs30355d92019-04-24 11:44:37 +02001.. This work is licensed under a Creative Commons Attribution 4.0 International License.
2.. http://creativecommons.org/licenses/by/4.0
3
Piotr Marcinkiewicz73aec242020-08-18 16:14:33 +02004SDK Overview
pwielebs30355d92019-04-24 11:44:37 +02005============
6
Piotr Marcinkiewicz73aec242020-08-18 16:14:33 +02007.. toctree::
8 :maxdepth: 3
9
10Architecture
pwielebs30355d92019-04-24 11:44:37 +020011------------
Piotr Marcinkiewicz73aec242020-08-18 16:14:33 +020012
13Introduction
14~~~~~~~~~~~~
15As most services and collectors deployed on DCAE platform relies on similar microservices a common Software Development Kit has been created. It contains utilities and clients which may be used for getting configuration from CBS, consuming messages from DMaaP, etc. SDK is written in Java.
pwielebs30355d92019-04-24 11:44:37 +020016
VENKATESH KUMAR7cfaea22020-04-22 17:31:32 -040017Some of common function across different services are targeted to build as separate library.
pwielebs30355d92019-04-24 11:44:37 +020018
19Reactive programming
Piotr Marcinkiewicz73aec242020-08-18 16:14:33 +020020~~~~~~~~~~~~~~~~~~~~
pwielebs30355d92019-04-24 11:44:37 +020021Most of SDK APIs are using Project Reactor, which is one of available implementations of Reactive Streams (as well as Java 9 Flow). Due to this fact SDK supports both high-performance, non-blocking asynchronous clients and old-school, thread-bound, blocking clients. Reactive programming can solve many cloud-specific problems - if used properly.
22
Piotr Marcinkiewicz73aec242020-08-18 16:14:33 +020023Before using DCAE SDK, please take a moment and read `Project Reactor documentation <https://projectreactor.io/docs/core/release/reference/>`_. You should also skim through methods available in `Flux <https://projectreactor.io/docs/core/release/api/reactor/core/publisher/Flux.html>`_ and `Mono <https://projectreactor.io/docs/core/release/api/reactor/core/publisher/Mono.html>`_.
pwielebs30355d92019-04-24 11:44:37 +020024
Piotr Marcinkiewicz73aec242020-08-18 16:14:33 +020025Rx short intro
26++++++++++++++
27For general introduction please read `3rd section of Reactor Documentation <https://projectreactor.io/docs/core/release/reference/#intro-reactive>`_.
pwielebs30355d92019-04-24 11:44:37 +020028
Piotr Marcinkiewicz73aec242020-08-18 16:14:33 +020029Some general notes:
30 - In Project Reactor you have two reactive streams' types at your disposal: Mono which may emit at most 1 element and Flux which may emit 0, finite or infinite number of elements.
31 - Both of them may end with error. In such situation the stream ends immediately. After stream is terminated (normally or because of error) it won't emit any new elements. You may use retry operators to resubscribe to events in case of error. In cloud environment retryWhen is especially usable: you may use it together with `reactor-extra retry functionality <https://projectreactor.io/docs/extra/release/api/reactor/retry/Retry.html>`_ in order to support more advanced reaction to unreachable peer microservice.
32 - If you do not have any background in functional operators like map, flatMap, please take a time to understand them. The general meaning is similar as in Java 8 Streams API. They are the most common operators used in reactive applications. Especially flatMap is very powerful despite its simplicity.
33 - There is a large group of operators which deal with time dimension of the stream, eg. buffer, window, delay*, timeout etc.
34 - Be aware that calling aggregation operators (count, collect, etc.) on infinite Flux makes no sense. In worst case scenario you can end JVM with OoM error.
35 - There is a nice intro to operators in `Appendix A of Reactor Documentation <https://projectreactor.io/docs/core/release/reference/#which-operator>`_. You should also learn how to read Marble Diagrams which concisely describe operators in a graphical form. Fortunately they are quite easy to grasp.
36 - Do not block in any of handlers which are passed to operators defined by Reactor. The library uses a set of Schedulers (think thread-pools) which are suitable for different jobs. `More details <https://projectreactor.io/docs/core/release/reference/#schedulers>`_ can be found in the documentation. If possible try to use non-blocking APIs.
37 - Most of operators support back-pressure. That means that a demand for new messages will be signalized from downstream subscribers. For instance if you have a flux.flatMap(this::doThis).map(this::doThat).subscribe() then if doThis is very slow it will not request many items from source flux and it will emit items at it's own pace for doThat to process. So usually there will be no buffering nor blocking needed between flux and doThis.
38 - (Almost) nothing will happen without subscribing to the Flux/Mono. These reactive streams are lazy, so the demand will be signaled only when subscription is being made ie. by means of subscribe or block* methods.
39 - If you are going to go fully-reactive then you should probably not call subscribe/block anywhere in your code. For instance, when using Reactor Netty or Spring Web Flux you should return Mono/Flux from your core methods and it will be subscribed somewhere by the library you are using.
40 - Return Mono<Void> in case you want to return from the method a listener to some processing being done. You may be tempted to return Disposable (result of subscribe()) but it won't compose nicely in reactive flow. Using then() operator is generally better as you can handle onComplete and onError events in the client code.
41
42Handling errors in reactive streams
43+++++++++++++++++++++++++++++++++++
44As noted above a reactive stream (Flux/Mono) terminates on first exception in any of the stream operators. For instance if Flux.map throws an exception, downstream operators won't receive onNext event. onError event will be propagated instead. It is a terminal event so the stream will be finished. This fail-fast behavior is a reasonable default but sometimes you will want to avoid it. For instance when polling for the updates from a remote service you may want to retry the call when the remote service is unavailable at a given moment. In such cases you might want to retry the stream using `one of retry* operators <https://projectreactor.io/docs/core/release/api/reactor/core/publisher/Flux.html#retry-->`_.
45
46.. code-block:: java
47
48 // Simple retry on error with error type check/
49 // It will immediately retry stream failing with IOException
50 public Mono<String> fetchSomething() {
51 Mono<Response> restResponse = ...
52 return restResponse
53 .retry(ex -> ex instanceof IOException)
54 .map(resp -> ...);
55 }
56
57 // Fancy retry using reactor-extra library
58 // It will retry stream on IOException after some random time as specified in randomBackoff JavaDoc
59 public Mono<String> fetchSomething() {
60 Mono<Response> restResponse = ...
61 Retry retry = Retry.anyOf(IOException.class)
62 .randomBackoff(Duration.ofMillis(100), Duration.ofSeconds(60));
63 return restResponse
64 .retryWhen(retry)
65 .map(resp -> ...);
66 }
67
68Libraries
69~~~~~~~~~~
pwielebs30355d92019-04-24 11:44:37 +020070
71DmaaP-MR Client
Piotr Marcinkiewicz73aec242020-08-18 16:14:33 +020072+++++++++++++++
pwielebs30355d92019-04-24 11:44:37 +020073 * Support for DmaaP MR publish and subscribe
74 * Support for DmaaP configuration fetching from Consul
75 * Support for authenticated topics pub/sub
76 * Standardized logging
77
pwielebs30355d92019-04-24 11:44:37 +020078ConfigBindingService Client
Piotr Marcinkiewicz73aec242020-08-18 16:14:33 +020079+++++++++++++++++++++++++++
pwielebs30355d92019-04-24 11:44:37 +020080 Thin client wrapper to invoke CBS api to fetch configuration based on exposed properties during deployment. Provides option to periodically query and capture new configuration changes if any should be returned to application.
81
Piotr Marcinkiewicz73aec242020-08-18 16:14:33 +020082Crypt Password
83++++++++++++++
Michal Bankad628e672020-08-21 13:36:37 +020084 Library to generate and match cryptography password using BCrypt algorithm.
pwielebs30355d92019-04-24 11:44:37 +020085
Piotr Marcinkiewicz73aec242020-08-18 16:14:33 +020086High Volume VES Collector Client Producer
87+++++++++++++++++++++++++++++++++++++++++
88 A reference Java implementation of High Volume VES Collector client. This library is used in xNF simulator which helps us test HV VES Collector in CSIT tests. You may use it as a reference when implementing your code in non-JVM language or directly when using Java/Kotlin/etc.
Michal Bankad628e672020-08-21 13:36:37 +020089
90External Schema Manager
91+++++++++++++++++++++++++++++++++++++++++
92 Library to validate JSON with mapping of external schemas to local schema files.