Friday, February 21, 2020

Comparing object state represented in JSON - A tree comparison techinque in Java for AUD visualization

When persisting data representing as JSON into Mongo DB would be easier, there would also be a good need to compare to object state for changes ( Addition, Updation,Deletion ) AUD, of member/atrributes.

Now comes the next challenge. What if the JSON object has nested attributes or complex java-types.

How will be compare it.
Here are some Java libraries to do the same.

[1]
https://www.baeldung.com/jackson-compare-two-json-objects

[2]

https://stackoverflow.com/questions/50967015/how-to-compare-json-documents-and-return-the-differences-with-jackson-or-gson

https://cassiomolin.com/2018/07/23/comparing-json-documents-in-java/ 

Consider the following JSON documents:
{
  "name": {
    "first": "John",
    "last": "Doe"
  },
  "address": null,
  "birthday": "1980-01-01",
  "company": "Acme",
  "occupation": "Software engineer",
  "phones": [
    {
      "number": "000000000",
      "type": "home"
    },
    {
      "number": "999999999",
      "type": "mobile"
    }
  ]
}
------------------   - - - -- - - - -- - - - - --   
{
  "name": {
    "first": "Jane",
    "last": "Doe",
    "nickname": "Jenny"
  },
  "birthday": "1990-01-01",
  "occupation": null,
  "phones": [
    {
      "number": "111111111",
      "type": "mobile"
    }
  ],
  "favorite": true,
  "groups": [
    "close-friends",
    "gym"
  ]
}
------------------   - - - -- - - - -- - - - - --   
It will produce the following output:
 
Entries only on left
--------------------------
/address: null
/phones/1/number: 999999999
/phones/1/type: mobile
/company: Acme


Entries only on right
--------------------------
/name/nickname: Jenny
/groups/0: close-friends
/groups/1: gym
/favorite: true


Entries differing
--------------------------
/birthday: (1980-01-01, 1990-01-01)
/occupation: (Software engineer, null)
/name/first: (John, Jane)
/phones/0/number: (000000000, 111111111)
/phones/0/type: (home, mobile)
 


Other experts from read ..
Everything was good until I had to compare complex JSON documents, with nested objects and arrays. A JSON document with nested objects is represented as a map of maps and Maps.difference(Map, Map) doesn’t give nice comparison results for that.
So yes this will ease up the problem.

Extension if you were to implement  JSON  Object State Change Notification, you will need to do some more post processing to get to format like

{
   "member_attr_name_1" : { "from_val" : "XYZ","to_val":"ABC"},
   "member_attr_name_2" : { "from_val" : "123","to_val":"789"},
   "member_attr_name_3" : { "from_val" : "2020-02-21T08:37:33+00:00","to_val":"2018-08-21T08:37:33+00:00"},

 ...
}



Analogy : NCS Client of CUCM , DBCNF processing of SQL records change , key functionality at informix level. if it breaks wheww , big things goes at stake.


Related thoughts :
 [1]
You may want to compare two similar mongo collections .
 https://stackoverflow.com/questions/41222805/compare-a-mongo-diff-on-two-collections/41223773

[2]
Pros:
  • you can specify subset of fields to compare.
  • you can see the actual diff of the records.
Cons:
  • to compare the full records, you need to know all possible fields.
  • mongoexport can be slow for huge databases.
To get all fields in all documents in a collection, see this answer.

Above two approaches help in solving set operation problems

[3]

From SQL Result set into JSON 
 

https://stackoverflow.com/questions/6514876/most-efficient-conversion-of-resultset-to-json
https://www.javacodegeeks.com/2018/09/streaming-jdbc-resultset-json.html
http://biercoff.com/nice-and-simple-converter-of-java-resultset-into-jsonarray-or-xml/


 Enjoy :)



Thursday, February 20, 2020

Tweaking pure RDBMS like Informix to store JSON

After having a quick overview in NoSQL DB, a natural thought was 
How can 
sql="insert into table(col1,col2,jsoncol) values(?,?,(?::JSON))";
pstmt = con.prepareStatement(sql);
pstmt.setString(1, '');
pstmt.setString(2, '');
pstmt.setString(3, jsondata.toJSONString().replaceAll("\\\\/","/"));
pstmt.executeUpdate();
?::JSON like this
select data::JSON from table_name
 
Please note this is
works for Informix DB alone.

Usecases for NoSQL Databases

[1]
https://www.mongodb.com/products/compass

Love these marketing slides, UI

[2]
No SQL databases has its own technical jargon
- Good choice for graph data-structutes
- Geo-spatial problem solving 

https://www.thoughtworks.com/insights/blog/nosql-databases-overview

[3]

From Business Perspective, What to Choose When 
Its a Battle
https://www.analyticsindiamag.com/nosql-vs-sql-database-type-better-big-data-applications/

Comparsion
https://blog.knoldus.com/mongodb-vs-rdbms-and-its-adavanatges/

 ..
MongoDB emphasizes on CAP theorem (Consistency, Availability, and Partition tolerance) but RDBMS emphasizes on ACID properties (Atomicity, Consistency, Isolation and Durability).

There is no support for complex joins in MongoDB but RDBMS supports complex joins which can be difficult to understand and take too much time to execute.
In MongoDB, Conversion/mapping of application objects to database objects is not needed.
..
[4] 

Maintaining Schema in a Distributed System

MemSQL implements schema by storing the metadata in small internal database and synchronously replicating the metadata to all the nodes when it is changed. It uses a two-phase commit to ensure that DDL changes propagate properly through the cluster and are built in a way so that they do not block select queries.
MemSQL supports more than just relational though. You can type a column as JSON and store a JSON document in it. If you decide there are some columns you want to query later, you can project the properties as columns and index them. MemSQL also supports Spatial types and Full-Text indexes as well. We understand that customers need a mix of data types in a system that is familiar and where all the types of data can co-exist naturally.

https://www.memsql.com/blog/why-nosql-databases-wrong-tool-for-modern-application/

Google Search
Keyword 
mongoDB vs RDBMS
and follow People Usually ask

:) 

[5]

Big Question ? Is JSON structure better than LDIF format for LDAP entry/ searches ??


https://ldap3.readthedocs.io/tutorial_searches.html

Why this question all of sudden.
- we are in 2020
- there is python thats getting more popular
- compact scripting need of hour
- results should not be maggled in special characters and unneccsary tags <> {} [ ] :

- we thought we can make life by processing DB ( RDBMS table)  change notification in 2016 but LDAP entry change notification processing , definition of rules will be needs in 2020

- Moral : known your data formats and there constraints in same way you know your programming languages their pro's and Cons

All the best
:)


Coming from pure RDBMS and SQL world, persisting object states and querying was always a challenge


Now, to give you a background, Java object state can best be represented as JSON.

- remember JPA Entity class definitions
- in pure RDBMS each of Java object would get represented as individual tables
- querying via SQL gets complex

Enter Mongo DB

Natural question 
https://softwareengineering.stackexchange.com/questions/54373/when-would-someone-use-mongodb-or-similar-over-a-relational-dbms

The immediate and fundamental difference between MongoDB and an RDBMS is the underlying data model. A relational database structures data into tables and rows, while MongoDB structures data into collections of JSON documents. JSON is a self-describing, human readable data format. Originally designed for lightweight exchanges between browser and server, it has become widely accepted for many types of applications.

Pros:
  • MongoDB has a lower latency per query & spends less CPU time per query because it is doing a lot less work (e.g. no joins, transactions). As a result, it can handle a higher load in terms of queries per second and is thus often used if you have a massive # of users.
  • MongoDB is easier to shard (use in a cluster) because it doesn't have to worry about transactions and consistency.
  • MongoDB has a faster write speed because it does not have to worry about transactions or rollbacks (and thus does not have to worry about locking).
  • MongoDB does not have a schema in case you have a special use case that can take advantage of that.
Cons:
  • MongoDB does not support transactions. This is how it obtains most of its benefits.
  • In general, MongoDB creates more work (e.g. more CPU cost) for the client server. For example, to join data one has to issue multiple queries and do the join on the client.
  • Even here in 2017 there is less tooling support for MongoDB than there is for relational databases simply because it is newer. There are also fewer MongoDB experts than their relational counterparts.
Points Often Misunderstood:
  • Both MongoDB and relational databases support indexing. Their query performance is similar in terms of executing large queries.
  • MongoDB does not remove the need for migrations or more specifically, updating your existing data as your schema evolves. For example: If you have an application that relies on a users table to contain certain data, and you modify that table to contain different data (let's say you add a profile picture field), then you will still need to either:
    • Write you application to handle objects for which this property is undefined OR
    • Write a one-time migration to put in a default value for this property OR
    • Write code to provide a default value at query time if this field is not present OR
    • Handle the missing field in some other way

Future Links


[1]
short for Bin­ary JSON, is a bin­ary-en­coded seri­al­iz­a­tion of JSON-like doc­u­ments.

http://bsonspec.org/ 

[2]
CRUD operations

https://docs.mongodb.com/guides/server/insert/
https://docs.mongodb.com/guides/server/read_operators/
https://docs.mongodb.com/guides/server/update/
https://docs.mongodb.com/guides/server/delete/

[3]
Query operations in Mongo and analogies with good old RDBMS SQL
https://docs.mongodb.com/manual/tutorial/query-documents/ 

Please note : above link has a good Mongo DB Web Shell to quickly try out commands.
So no need to hunt for VM box and install tarball and put env variable sttings
or pull  a docker image and try out.

You just have to give it try right there
What a way to learn.
LaaS
Learning on Cloud
:)

[4]
Now come in Python
Scripting language to do No SQL Mongo DB operations ( analogical to PL/SQL or .sql files in pure RDBMS world that you did using Oracle Sql Worksheet )

https://api.mongodb.com/python/current/tutorial.html

[5]
New generation needs and reporting and Overview

https://info-mongodb-com.s3.us-east-1.amazonaws.com/MongoDB_Architecture_Guide.pdf

Good read here.
Some experts..
is the best way to create visualizations of MongoDB data anywhere. Build visualizations quickly and easily to analyze complex, nested data. Embed individualcharts into any web application or assemble them into livedashboards for sharing.

Kubernetes Integration

Kubernetes is the industry leading container orchestration platform. It provides you with a consistent automation andmanagement experience anywhere from on-premises infrastructure to the public cloud. Kubernetes users can use theMongoDB Enterprise Operator for Kubernetesthatintegrates with MongoDB Ops Manager to automate andmanage MongoDB clusters. You have full control over yourMongoDB deployment from a single Kubernetes controlplane. You can use the operator with upstream Kubernetes,or with any popular distribution such as Red Hat OpenShiftand Pivotal Container Service (PKS).
[6]

Analogical comparsion with SQL
https://docs.mongodb.com/manual/reference/sql-comparison/


Word of Caution : Do not get carried away by technology and charts.

[7]
Now to integrating Mongo DB queries into Java code
https://www.mongodb.com/blog/post/getting-started-with-mongodb-and-java-part-i

http://central.maven.org/maven2/org/mongodb/mongo-java-driver/


    
        org.mongodb
        mongo-java-driver
        2.12.3
    
 
MongoClient mongoClient = new MongoClient(new MongoClientURI("mongodb://localhost:27017")
 
MongoClient mongoClient = new MongoClient();

Where are my tables?

MongoDB doesn’t have tables, rows, columns, joins etc. There are some new concepts to learn when you’re using it, but nothing too challenging.
While you still have the concept of a database, the documents (which we’ll cover in more detail later) are stored in collections, rather than your database being made up of tables of data. But it can be helpful to think of documents like rows and collections like tables in a traditional database. And collections can have indexes like you’d expect.
DB database = mongoClient.getDB("TheDatabaseName");
 
DBCollection collection = database.getCollection("TheCollectionName");
 
person = {
  _id: "jo",
  name: "Jo Bloggs",
  age: 34,
  address: {
    street: "123 Fake St",
    city: "Faketon",
    state: "MA",
    zip: “12345”
  }
  books: [ 27464, 747854, ...]
} 
 
List books = Arrays.asList(27464, 747854);
DBObject person = new BasicDBObject("_id", "jo")
                            .append("name", "Jo Bloggs")
                            .append("address", new BasicDBObject("street", "123 Fake St")
                                                         .append("city", "Faketon")
                                                         .append("state", "MA")
                                                         .append("zip", 12345))
                            .append("books", books);
 
 
MongoClient mongoClient = new MongoClient();
DB database = mongoClient.getDB("Examples");
DBCollection collection = database.getCollection("people");
collection.insert(person);
 
 
> use Examples
switched to db Examples
> show collections
people
system.indexes
> _ 
  
 
> db.people.findOne()
{
    "_id" : "jo",
    "name" : "Jo Bloggs",
        "age": 34,
    "address" : {
        "street" : "123 Fake St",
        "city" : "Faketon",
        "state" : "MA",
        "zip" : "12345"
    },
    "books" : [
        27464,
        747854
    ]
}
> _
     
[8]
  
Alternatively 
http://zetcode.com/java/mongodb/
 
Enjoy :) 
 
  



Wednesday, February 19, 2020

Exposure to functional programming languages like Python / Scala opens more opps

[1]

Python is among the fastest-growing and most popular programming languages out there today. Here are a few ways to use the coding language across industries.

https://www.techrepublic.com/article/python-5-use-cases-for-programmers/

1. Insurance

Top use: Creating business insights with machine learning
Case study: One American multinational finance and insurance corporation faced competition from smaller companies that were introducing services driven by machine learning. To compete, the insurer allowed teams to develop new applications and services using machine learning; however, with too many sets of data science tools involved, a number of different versions of Python and compatibility issues arose. The company settled on one version of Python to deliver all of the machine learning capabilities needed.

2. Retail banking

Top use: Flexible data transformation and manipulation
Case study: A large American department store chain with an in-store banking arm collects data centrally in a warehouse, and then shares it with multiple applications to enable its supply chain, retail banking, and analytics and reporting needs. While the company standardized on Python for data manipulation, each team created its own version, which created problems. The company decided on a single, standard Python build to increase engineering speed and decrease support costs.

3. Aerospace

Top use: Meeting software system deadlines
Case study: An American multinational aerospace, military, and defense corporation was contracted to provide a number of systems for the International Space Station. While aerospace software focused on critical safety systems is typically written in a language like Ada, those older languages do not lend themselves well to scripting tasks, GUI creation, or data science analysis. Selecting a single Python version offered a larger contract value and no exposure.

4. Finance

Top use: Data mining identify cross-sell opportunities
Case study: An American multinational financial services corporation wanted to mine complex customer and prospect behavioral data as part of a digital transformation project. The company used Python to initiate different data science and machine learning initiatives to examine the structured data it had been collecting for years, and correlated it with unstructured data from the web and social media to increase cross-selling and reclaim resources.

5. Business services

Top use: API access to financial information
Case study: A privately-held financial data and media company had previously provided partners with access to financial information through different electronic resources. Partners wanted to build desktop applications in a variety of languages, including Python, to incorporate the customer's API directly into their own, and created a Python Software Development Kit (SDK) for their financial information API, leading to increased revenue and customer satisfaction.


[2]

https://stackabuse.com/functional-programming-in-python/

Functional Programming is a programming paradigm with software primarily composed of functions processing data throughout its execution. Although there's not one singular definition of what is Functional Programming, we were able to examine some prominent features in Functional Languages: Pure Functions, Immutability, and Higher Order Functions.
Python allows us to code in a functional, declarative style. It even has support for many common functional features like Lambda Expressions and the map and filter functions.
However, the Python community does not consider the use of Functional Programming techniques best practice at all times. Even so, we've learned new ways to solve problems and if needed we can solve problems leveraging the expressivity of Functional Programming.

 [3]
Historical evaluation of python evolution


https://python-history.blogspot.com/2009/04/origins-of-pythons-functional-features.html

"..It is also worth nothing that even though I didn't envision Python as a functional language, the introduction of closures has been useful in the development of many other advanced programming features. For example, certain aspects of new-style classes, decorators, and other modern features rely upon this capability.

Lastly, even though a number of functional programming features have been introduced over the years, Python still lacks certain features found in “real” functional programming languages. For instance, Python does not perform certain kinds of optimizations (e.g., tail recursion). In general, because Python's extremely dynamic nature, it is impossible to do the kind of compile-time optimization known from functional languages like Haskell or ML.
.."


[4]

Tutorial: Python Functions and Functional Programming

https://www.dataquest.io/blog/introduction-functional-programming-python/

In this post, we will:
  • Explain the basics of functional programming by comparing it to object-oriented programming.
  • Cover why you might want to incorporate functional programming in your own code.
  • Show you how Python allows you to switch between the two.
  • The Lambda Expression
  • The Map Function
  • The Filter Function
  • The Reduce Function
  • Rewriting with list comprehensions
  • Writing Function Partials
[5]
 Another link to get started with language syntax

 Concluding thoughts

Getting to know your programming language of choice well by exploring its features, libraries and internals will undoubtedly help you debug and read code faster. Knowing about and using ideas from other languages or programing language theory can also be fun, interesting, and make you a stronger and more versatile programmer. However, being a Python power-user ultimately means not just knowing what you *could* do, but understanding when which skills would be more efficient. Functional programming can be incorporated into Python easily. To keep its incorporation elegant, especially in shared code spaces, I find it best to use a purely functional mindset to make code more predictable and easy, all the while maintaining simplicity and idiomaticity.

[6] Another good and concise one to get started

A practical introduction to functional programming

 

 

 





If you were to start with Scala -- Here's some starting point


[1] https://www.quora.com/How-does-Scala-compare-to-Java-8/answer/Denis-Kalinin

How does Scala compare to Java 8?


When presenting a new version of Java, Brian Goetz said that while Java is getting lambdas, it still feels like Java. I would argue that this could be seen as both advantage and disadvantage at the same time.
The main problem for me is that Java is still an imperative language. The if statement is still a statement (so you need variables to define the control flow), the HashMap still returns null, throwing and catching exceptions is still the most common way to deal with dangerous code. Introducing the Optional class doesn’t change anything for legacy code if it already relies on nulls.
In contrast, Scala has had the Option type since 2007 (version 1.1), so pretty much everything in Scala, including the standard library, uses it. There are type-safe ways for dealing with dangerous code such as the Try type or ScalaZ disjunctions. Finally, “everything is an expression”, so you don’t need variables most of the time.
Here I’m not even talking about more advanced Scala features like pattern matching or for comprehensions, which don’t exist in Java at the moment.
The only two advantages Java still has is
  • performance
  • market share
I would argue, performance differences between Scala and Java are irrelevant for many (if not most) projects. As for the market share, Scala is quite easy to grasp (see my recent article The fastest way to learn Scala
). Finally, many former Ruby/PHP/etc developers will not consider Java as a viable option exactly because of its “Java feeling”, but they can easily switch to Scala because it’s ”a statically typed language that feels dynamic” (see this presentation about switching from Rails to Scala - From a monolithic Ruby on Rails app to the JVM
).

Still, I wouldn't blame Java architects for the decisions they've made, because they are doing the best they can given the circumstances. Microsoft seemed to have taken a completely different approach to introducing new features, but they also had questionable results.


[2]
A good comparison - less than 5 min read /analysis  


[3]
Books 

You see world is getting more into functional programming.


Tuesday, February 11, 2020

Linux and bash scripting not to be forgetten in technology proliferated world

Having worked on multiple OS platforms its very easy to get confused with syntax of Linux commands that your were so good at years ago.

Thanks to the following
https://alvinalexander.com/unix/edu/examples/grep.shtml
https://alvinalexander.com/blog/post/linux-unix/unix-linux-shell-script-reference-cheat-sheet

you donot have to google multiple times.
Spend time on this page and you will find yourself recollecting some techniques 

This is best part of being in software community.
Ahamam bramhasmi





Containerization via Docker. - Howto - Whento - WhenNotto

Over previous few days was taking a look at this technology.
Clearly it gives some benefits and could easily foresee this drawbacks, in enterprise applications which involve distributed data and their is a clear and definitive need for data replication/synchronicity

Here are good links, if you have to review some readings

HOW TO 
http://jasonwilder.com/blog/2014/10/13/a-simple-way-to-dockerize-applications/ 

Good usecases this solves
WHEN TO 
https://www.airpair.com/docker/posts/8-proven-real-world-ways-to-use-docker

Drawbacks/Concerns in containerizing database
WHEN NOT TO
https://vsupalov.com/database-in-docker/
https://www.channelfutures.com/open-source/when-not-to-use-docker-understanding-the-limitations-of-containers

Good qoutes
"..Docker is also not necessarily a great packaging system either. You can make something that will run on many Linux distributions but it wont be fast, efficient nor guaranteed to be entirely compatible..."

"..you can end up shipping something that as an RPM would be 10KB, becomes 100MB using docker."


Now also like to say Google search page gives this info quick on hit page with
Keyword
"drawbacks for dockerization in distributed databases application"
Enjoy

Here are just some of the use cases that provide a consistent environment at low overhead with the enabling technology of Docker.
  • Simplifying Configuration. ...
  • Code Pipeline Management. ...
  • Developer Productivity. ...
  • App Isolation. ...
  • Server Consolidation. ...
  • Debugging Capabilities. ...
  • Multi-tenancy.
Here are examples of things Docker can't do or can't do well:
  1. Run applications as fast as a bare-metal server. Docker containers have less overhead than virtual machines. ...
  2. Provide cross-platform compatibility. ...
  3. Run applications with graphical interfaces. ...
  4. Solve all your security problems.
Popularity & Benefits of Using Docker
  • Return on Investment and Cost Savings. The first advantage of using docker is ROI. ...
  • Standardization and Productivity. ...
  • CI Efficiency. ...
  • Compatibility and Maintainability. ...
  • Simplicity and Faster Configurations. ...
  • Rapid Deployment. ...
  • Continuous Deployment and Testing. ...
  • Multi-Cloud Platforms.
Until next time..







Saturday, February 8, 2020

Microservices -- Orchestration in distributed systems - challenges


A good write up by Bernd Bucker  @ Camunda
https://www.youtube.com/watch?v=GPgOeK-QytA 
A good write up in whitepaper format 
https://thenewstack.io/5-workflow-automation-use-cases-you-might-not-have-considered/

My Work around this time line
- Automated provisioning platform 

Most of these challenges, were thought off , implemented using Spring technologies
- Centralized database workflow tables tracking status of request   (be it synchronous or asynchronous , bulk or single )
- In -memory database structures for Spring boot actuators metrics
- Logging onto to filesystem in standard format at every point in execution
  (checks, validations, external system interactions )

The SRD was indeed drafted in BPMN notation and signed off  by PO in communication with client.


Followers