aws-samples / aws-big-data-blog
Components & Dependencies

An overview of source code logical components.

Intro

Logical decomposition is a representation of the organization of the main source code, where every and each file is put in exactly one logical component.

  • A software system can have one or more logical decompositions.
  • A logical decomposition can be defined in two ways in Sokrates.
  • First approach is based on the folders structure. Components are mapped to folders at defined folder depth relative to the source code root.
  • Second approach is based on explicit definition of each component. In such explicit definitions, components are explicitly named and their files are selected based on explicitly defined path and content filters.
  • A logical decomposition is considered invalid if a file is selected into two or more components.This constraint is introduced in order to facilitate measuring of dependencies among components.
  • Files not assigned to any component are put into a special "Unclassified" component.
Learn more...
Logical Decompositions Overview

Analyzed system has 1 logical decomposition:

  • primary (35 components)

Logical Decomposition #1: PRIMARY

The decompositions is based on the folder structure (relative to the source code root), with automatically defined folder depth to have at least 10 components.

Bubble Chart | Tree Map
Components
The "primary" logical decomposition has 35 components.
  • 166 files, 11,873 lines of code (71.7% vs. main code).
  • "aws-blog-kinesis-data-visualization" is biggest, containing 17.95% of code.
  • "aws-blog-campanile" is smallest, containing 0.06% of code.


aws-blog-kinesis-data-visualization2131 LOC (12%) 27 files
BDB-701-Moving-From-Transactional-to-Stateful-Batch-Processing1559 LOC (9%) 12 files
aws-blog-hbase-on-emr1240 LOC (7%) 15 files
aws-blog-lambda-map-reduce-streaming847 LOC (5%) 6 files
aws-blog-vpcflowlogs-athena-quicksight483 LOC (2%) 13 files
aws-blog-jobserver-emr482 LOC (2%) 5 files
aws-blog-s3-index-with-lambda-ddb478 LOC (2%) 6 files
aws-blog-kinesis-beanstalk-workers472 LOC (2%) 8 files
aws-blog-spark-parquet-conversion427 LOC (2%) 4 files
aws-blog-firehose-lambda-elasticsearch-near-real-time-discovery-platform400 LOC (2%) 8 files
aws-blog-kinesis-storm-clickstream-app396 LOC (2%) 7 files
aws-blog-real-time-in-memory-oltp-and-analytics-with-apache-ignite360 LOC (2%) 7 files
aws-blog-sparkr-geospatial-analysis357 LOC (2%) 3 files
aws-blog-mirth-healthcare-hub315 LOC (1%) 4 files
aws-blog-event-driven-batch-analytics295 LOC (1%) 2 files
aws-blog-multi-az-multi-region-redshift219 LOC (1%) 1 files
aws-blog-firehose-lambda180 LOC (1%) 3 files
aws-blog-bigtop-application-emr166 LOC (1%) 4 files
aws-blog-titan-graph-database156 LOC (<1%) 1 files
aws-blog-athena-importing-hive-metastores110 LOC (<1%) 4 files
aws-blog-machine-learning-with-spark94 LOC (<1%) 4 files
aws-blog-strata201689 LOC (<1%) 2 files
aws-blog-sparkstreaming-from-kafka87 LOC (<1%) 2 files
aws-blog-retain-redshift-stl81 LOC (<1%) 1 files
aws-blog-elasticsearch-cascading-commoncrawl75 LOC (<1%) 3 files
aws-blog-nodejs-on-emr72 LOC (<1%) 2 files
aws-blog-athena-genomics53 LOC (<1%) 1 files
aws-blog-end-to-end-emrencyrption48 LOC (<1%) 2 files
aws-blog-iot-athena-quicksight-bi40 LOC (<1%) 1 files
aws-blog-emrencyrption37 LOC (<1%) 2 files
aws-blog-analyzing-using-ipython-notebook33 LOC (<1%) 2 files
aws-blog-real-time-clickstream32 LOC (<1%) 1 files
aws-blog-sqoop26 LOC (<1%) 1 files
aws-blog-redshift-python-udf-tutorial26 LOC (<1%) 1 files
aws-blog-campanile7 LOC (<1%) 1 files
Dependencies
Dependencies among components are static code dependencies among files in different components.

No component dependencies found.



2022-01-31 15:39