Thursday, May 24, 2018

Multiple phases commit

client invokes System A
  System A performs process
  if success
    System A commits
    System A invokes System B
    System B performs process
    if success
      System B commits
      System B invokes System N..
      System N.. performs process
      if success
        System N.. commits
        System N.. rollback
        System N.. return false
      System B rollback
      System B return false
    System A rollback
    System A returns fail

to simplified the above logic,
1.    process and commit own transaction.
2.    invoke external system/process
3.1 if success, return true
3.2 if failed, return false, manual rollback the transaction.


Wednesday, May 16, 2018

Manual rollback with MongoDB

When there is a need to save different documents at the same time in microservices, or more specifically NoSql.
It is not an easy job, because NoSql does not support transaction like RDBMS.

The multiple phases commit in the previous post able to achieve the transaction-like behavior with MongoDB.

The code snippet below will be demonstrated by Play2.x, MongoDB, Morphia.

JsonNode json = request().body().asJson();
MyDocument md = Json.fromJson(json, MyDocument.class);
MyDocument mdCurrent = MyDocumentRepo.findMyDocumentById( md.getId() ); md );

boolean status = callNextService();

if(status == true) {
  // not doing anything
} else {
  // manually rollback the previous md mdCurrent );


Tuesday, May 15, 2018

How to change font in Oracle SQL Developer

Tools > Preferences... > Code Editor > Fonts

edit the Font Name, Font Size
Click OK.



Related Posts Plugin for WordPress, Blogger...