Skip to main content

Navigating the world of software development, static code analysis tools for Java have become indispensable for me. Through checker tools, I've employed frameworks plugins from Android to Linux, and dabbled in languages from TypeScript to Objective-C and PL/SQL. Whether you're in Visual Studio, dealing with XML or HTML modules, the right code review tool is transformational. Essentially, it sifts through Java code to pinpoint vulnerabilities early on.

The payoff? A considerable reduction in debugging time and a consistent code quality. If unnoticed coding errors or compatibility concerns are holding you back, these tools might be your answer. I've walked this path, and it's a choice I stand by.

What Is A Static Code Analysis Tools for Java?

Static code analysis tools for Java refer to specialized software designed to scrutinize Java code without executing it, aiming to detect potential flaws, vulnerabilities, or deviations from coding standards. These tools play an instrumental role for software developers, quality assurance teams, and security professionals in ensuring the robustness, security, and maintainability of Java applications.

By leveraging these tools, organizations can identify and rectify issues early in the development lifecycle, thereby reducing the cost of post-deployment fixes and enhancing the overall quality of the software.

Best Static Code Analysis Tools for Java Summary

Tool Best For Trial Info Price
1
Aikido Security

Aikido offers security scans for code environments like Java, with a dashboard that displays vulnerabilities and their severity levels.

Best for custom security rules

Free plan available (up to 2 users)

From $314/month (billed annually, up to 10 users) Website
2
Codacy

Here's the Codacy dashboard, which automatically identifies new static analysis issues, code coverage, code duplication, and code complexity evolution in every commit and pull request.

Best for automated code quality reviews

14-day free trial

From $15/user/month (billed annually) Website
3
JArchitect

The metrics view lets you browse the structure in JArchitect.

Best for detailed code architecture visualization

Not available

From $12/user/month (billed annually) Website
4
Coverity

Here's the actionable remediation guidance feature in Coverity, which enables developers to address potential security vulnerabilities.

Best for detection of software defects in development

Not available

Pricing upon request Website
5
Codiga

Here's an image of Codiga's code analysis, which gives you an overview of your code and detects security, safety, and best practice issues.

Best for code consistency and maintenance

Not available

From $10/user/month (billed annually) Website
6
Snyk

Here's Synk's static analysis scanner, which checks your code for quality and security issues in real time and provides fix advice in your IDE.

Best for open-source vulnerability management

Free plan available

From $25/product/month Website
7
SonarQube

Here's SonarQube's issues tab, which displays the category, severity level, tag(s), and the calculated effort it will take to rectify an issue.

Best for continuous inspection of code quality

A free, open-source solution is also available.

From $10/user/month (billed annually) Website
8
Azul Platform Core

Here's the screenshot of the Azul Platform Core website.

Best for Java runtime customization

Not available

Pricing upon request Website
9
Parasoft JTest

Here's Parasoft Jtest's centralized reporting dashboard.

Best for comprehensive Java testing

Not available

From $20/user/month (billed annually) Website
10
PMD

Here's a screenshot of the PMD duplicate code detector feature.

Best for quick identification of common coding flaws

Free

Open source project and available for free. Website

Best Static Code Analysis Tools for Java Reviews

Best for custom security rules

  • Free plan available (up to 2 users)
  • From $314/month (billed annually, up to 10 users)
Visit Website
Rating: 4.7/5

Aikido Security is an application security platform offering comprehensive solutions to protect applications from code to cloud. It encompasses features like cloud posture management, open source dependency scanning, secrets detection, and both static and dynamic application security testing.

Why I Picked Aikido Security:

Aikido lets you create custom security rules that fit your specific needs, giving your team more control over how you protect your Java code. It’s flexible enough to allow tailored configurations, so you don’t have to rely on generic rule sets that might not fit your project. Aikido scans code in real-time, catching vulnerabilities before they escalate. With its ability to enforce these custom rules automatically, your team can easily adapt it to match your code standards and security policies, ensuring more precise security monitoring.

Standout Features and Integrations:

Other features include secrets detection, which is vital for checking code for leaked and exposed API keys, passwords, and encryption keys, and auto-triaging known safe secrets. It also offers DAST for web applications to identify vulnerabilities through simulated attacks.

Integrations include Amazon Web Services (AWS), Google Cloud, Microsoft Azure Cloud, Drata, Vanta, AWS Elastic Container Registry, Docker Hub, Jira, Asana, and GitHub.

Pros and cons

Pros:

  • Scalable for growing teams
  • Has a comprehensive dashboard and customizable reports
  • Code-to-cloud security

Cons:

  • Ignores vulnerabilities if no fix is available
  • Supports English only

Best for automated code quality reviews

  • 14-day free trial
  • From $15/user/month (billed annually)
Visit Website
Rating: 4.5/5

Codacy is a prominent static code analysis tool that focuses on automating code quality reviews. By streamlining the code review process, it ensures that development teams deliver high-quality code consistently.

Why I Picked Codacy:

In the vast domain of static code analysis tools, choosing Codacy was a deliberate decision. When determining which tools to highlight, Codacy stood out due to its potent automated review capabilities. I chose Codacy because I believe its emphasis on automating quality reviews is paramount, positioning it as an essential asset for teams desiring to ensure consistent quality without manual oversight.

Standout Features and Integrations:

Codacy shines with its ability to identify a broad range of issues, from coding errors and code smells to security issues. It offers detailed dashboards that provide a snapshot of the overall code quality, aiding in the rapid identification of problem areas.

As for integrations, Codacy blends perfectly with platforms like GitHub, GitLab, and Bitbucket. This ensures code reviews and quality checks throughout the development process.

Pros and cons

Pros:

  • Automated reviews reduce manual oversight and human errors.
  • Strong integrations with popular repositories, improving the development workflow.
  • Efficient source code analyzer detecting a wide array of issues.

Cons:

  • Annual billing may not cater to all teams or projects.
  • Potential for occasional false positives in code reviews.
  • Some users might find certain features slightly complex.

Best for detailed code architecture visualization

  • From $12/user/month (billed annually)

JArchitect is a leading tool among the static code analysis tools for Java realm, excelling in visualizing Java code architecture. When complexity emerges in programming projects, it provides a structured and graphical representation, emphasizing intricacies in the source code.

Why I Picked JArchitect:

In my process of selecting the crème de la crème of static code analysis tools for Java, JArchitect stood out. I chose JArchitect after judging its capabilities, comparing it with its peers, and determining it had an edge in presenting code architecture with unmatched clarity.

This tool's emphasis on detailed visualization is the reason I believe it's best for developers and teams diving deep into the structural intricacies of their Java projects.

Standout Features and Integrations:

JArchitect boasts a unique code querying functionality using CQLinq, allowing in-depth inspections of Java source code and revealing subtle coding errors or potential security issues. Furthermore, the tool's dashboards adeptly illustrate technical debt, code smells, and other metrics that development teams deem crucial.

As for integrations, JArchitect integrates with platforms like GitHub, improving code reviews and pull requests. It also supports continuous integration through Jenkins, adding to its utility in a modern DevOps environment.

Pros and cons

Pros:

  • Excellent integration capabilities, especially with GitHub and Jenkins.
  • Offers invaluable insights into technical debt and code smells.
  • Proficient at representing intricate Java code structures.

Cons:

  • Requires a fair bit of configuration for optimal results.
  • Certain functionalities may appear redundant for basic projects.
  • Some users might find the interface slightly daunting initially.

Best for detection of software defects in development

  • Pricing upon request

Coverity, by Synopsys, offers meticulous static code analysis, aiming to pinpoint software defects during the development phase. Recognized for its precision, it aligns with the commitment to reduce coding errors and improve overall software robustness.

Why I Picked Coverity:

In my quest for a robust static analysis tool, Coverity continually emerged as a prominent choice, mainly due to its deep source code analysis capabilities. While selecting and comparing tools, I was especially impressed by the granularity with which Coverity detects software defects, setting it apart from many of its counterparts.

I believe it truly shines when used in development, making it best for spotting and rectifying software defects before they escalate.

Standout Features and Integrations:

Coverity showcases a deep-rooted functionality in detecting intricate coding errors, vulnerabilities, and other software defects across multiple programming languages, including Java, JavaScript, and Python. Its dashboards provide development teams with insightful data, easing the code review process.

Integration-wise, Coverity plugs into the majority of development environments, partnering effortlessly with platforms like GitHub, GitLab, Jenkins, and more, which simplifies the workflow in the DevOps and continuous integration realm.

Pros and cons

Pros:

  • Deep source code analysis helps reduce technical debt and false positives.
  • Integrates effortlessly with popular development and CI/CD tools.
  • Comprehensive detection of software defects across several programming languages.

Cons:

  • Some configurations can be intricate, requiring in-depth knowledge.
  • As a premium tool, the pricing might be on the higher end for some teams.
  • Might be overwhelming for newcomers due to its extensive feature set.

Best for code consistency and maintenance

  • From $10/user/month (billed annually)

Codiga is a proficient static code analysis tool tailored for those who prioritize maintaining consistency across their codebase. Its specialization in identifying inconsistencies ensures a streamlined development process and easier code maintenance.

Why I Picked Codiga:

When I ventured into selecting the most effective tools in the realm of static code analysis, Codiga captured my attention. Judging from its unique functionalities, and after comparing it to its peers, it stood out due to its dedication to promoting code consistency.

I chose Codiga because, in my view, its focus on maintaining consistent coding practices is unparalleled, making it the top choice for teams aiming for uniform codebases.

Standout Features and Integrations:

Codiga excels with its in-depth source code analysis that can effectively detect code smells, coding errors, and technical debt. Additionally, it provides dashboards that offer a clear visual representation of the codebase's health.

For integrations, Codiga effortlessly syncs with platforms like GitHub, GitLab, and Bitbucket, ensuring that it embeds into the workflow of development teams.

Pros and cons

Pros:

  • Provides intuitive dashboards for code health visualization.
  • Integrates smoothly with popular repositories like GitHub.
  • Comprehensive source code analyzer detecting inconsistencies.

Cons:

  • Some features might be overkill for very small projects.
  • Annual billing might not be ideal for all teams.
  • Might have a steeper learning curve for novices.

Best for open-source vulnerability management

  • Free plan available
  • From $25/product/month

Snyk stands at the forefront of identifying and rectifying vulnerabilities in open-source projects and dependencies. With its sharp focus on securing open-source software, it offers a much-needed shield against potential security breaches.

Why I Picked Snyk:

In my continuous search for tools that ensure software robustness, Snyk caught my attention due to its dedicated focus on open-source vulnerabilities. When determining and comparing static code analysis tools, Snyk's specialization in tracking and managing open-source project vulnerabilities made it stand out.

I determined that, in the realm of open-source software, Snyk is undoubtedly best for vulnerability management, providing an invaluable service to the development community.

Standout Features and Integrations:

One of Snyk's prime features is its extensive database of open-source vulnerabilities, making it a vital tool for developers leveraging open-source projects. Furthermore, its dashboards offer comprehensive insights, enabling development teams to quickly identify and address potential threats.

When it comes to integrations, Snyk effortlessly ties in with popular repositories like GitHub and Bitbucket. It also smoothly integrates with CI/CD pipelines, including Jenkins, improving the DevOps workflow.

Pros and cons

Pros:

  • Offers insights and actionable solutions through its dashboards.
  • Integration with popular repositories and CI/CD tools.
  • Comprehensive database catering specifically to open-source vulnerabilities.

Cons:

  • Pricing and tiers can be complex for teams with varied needs.
  • The granularity of its features might require a learning curve for some users.
  • While it specializes in open-source, it might not cover all proprietary software vulnerabilities.

Best for continuous inspection of code quality

  • A free, open-source solution is also available.
  • From $10/user/month (billed annually)

SonarQube is a standout open-source platform designed for continuously inspecting the quality of source code. Through its capabilities, developers can identify and fix code smells, coding errors, and other potential pitfalls, aligning with the objective of consistent code quality assurance.

Why I Picked SonarQube:

In the maze of static code analysis tools available, SonarQube caught my attention for its comprehensive and continuous approach to inspecting code. In determining the right tool, I compared various platforms, and SonarQube's reputation for fostering better coding practices by highlighting technical debt made it stand out.

I chose this tool because its continuous inspection methodology aligns perfectly with today's agile development processes, making it best for ensuring code quality at every phase of development.

Standout Features and Integrations:

SonarQube is equipped with a potent dashboard that aggregates the various metrics of code quality, from code smells to coding errors, offering development teams a holistic view. With support for multiple programming languages, including Java, Javascript, Python, and Ruby, its functionality is vast.

As for integrations, SonarQube ties into the DevOps ecosystem, connecting effortlessly with platforms like GitHub, GitLab, Bitbucket, and Jenkins, to weave code quality checks into the CD pipeline.

Pros and cons

Pros:

  • Open-source nature with a large community, fostering frequent updates and shared best practices.
  • Comprehensive integrations with popular development tools and repositories.
  • Robust source code analysis that detects a broad range of coding issues.

Cons:

  • Complexity can be a challenge for smaller teams without dedicated DevOps personnel.
  • Some false positives might arise, necessitating thorough review.
  • The initial setup might require some technical expertise.

Best for Java runtime customization

  • Pricing upon request

Azul Platform Core is a sophisticated tool tailored for Java runtime environments, allowing intricate customization. Given the diverse needs of Java developers, its strength in facilitating Java runtime adjustments positions it as a leader in its niche.

Why I Picked Azul Platform Core:

In my quest to identify specialized tools, Azul Platform Core emerged as a unique offering, compelling me to choose it for its robust customization capabilities for Java runtimes. The process of selecting and comparing various tools reinforced my belief in its stand-out nature, primarily rooted in its expertise in Java.

Through careful judgment, I've determined that for developers seeking deep Java runtime adjustments, Azul Platform Core is unequivocally the best.

Standout Features and Integrations:

Azul Platform Core is renowned for its advanced Java source code analysis, ensuring optimal performance and security. Its dashboards provide a clear overview of the Java runtime environment, highlighting potential issues and offering insights into improvements.

When it comes to integrations, Azul Platform Core interfaces with development tools such as Eclipse and IntelliJ IDEA and also supports a broad range of repositories, including GitHub and Bitbucket.

Pros and cons

Pros:

  • Comprehensive dashboards for clear oversight of Java runtime dynamics.
  • Broad compatibility with popular development environments such as Eclipse and IntelliJ IDEA.
  • Proficient in Java source code analysis to maximize runtime performance.

Cons:

  • Might not cater to languages outside of Java as comprehensively.
  • Pricing tiers could be intricate for varied team needs.
  • Might have a steep learning curve for developers unfamiliar with intricate Java runtime customization.

Best for comprehensive Java testing

  • From $20/user/month (billed annually)

Parasoft Jtest is a powerhouse among static code analysis tools for Java, specifically tailored for Java environments. Its deep-rooted commitment to ensuring thorough Java testing makes it an invaluable asset for development teams.

Why I Picked Parasoft Jtest:

In the vast landscape of static code analysis tools for Java, selecting Parasoft Jtest was a deliberate decision shaped by its unrivaled depth in Java testing. After determining and comparing its capabilities with others, I appreciated its unique blend of comprehensive testing tools and advanced features.

It stands out primarily for its commitment to Java, ensuring that teams obtain a holistic testing experience. Thus, I confidently opine that it's the best for thorough Java testing.

Standout Features and Integrations:

One of Parasoft Jtest's standout features is its ability to detect and rectify code smells and coding errors early in the development process. It’s also commendable for its source code analysis which digs deep into the Java source code, providing actionable insights.

When it comes to integrations, Parasoft Jtest smoothly works with popular platforms such as GitHub, GitLab, and Jenkins, bolstering its role in continuous integration workflows.

Pros and cons

Pros:

  • Strong integrations with platforms like GitHub and Jenkins.
  • Effective detection of code smells and technical debt.
  • Comprehensive Java testing, covering various aspects of code quality.

Cons:

  • Might be overkill for smaller projects with limited Java components.
  • Configuration may be cumbersome for certain projects.
  • Some of the advanced features may require a steep learning curve for beginners.

Best for quick identification of common coding flaws

  • Free
  • Open source project and available for free.

PMD is a well-regarded static code analysis tool that offers developers the capability to rapidly identify frequent coding flaws across various programming languages. Its forte lies in its proficiency to swiftly pinpoint such issues, making it indispensable for those who prioritize swift code reviews.

Why I Picked PMD:

Navigating through the diverse field of static code analysis tools, choosing PMD became an evident choice after determining its strengths and comparing them with its peers. The tool's inherent capability to swiftly uncover common coding flaws made it stand out, distinguishing it from the vast array of options available.

I picked it because, in my judgment, PMD excels at rapidly identifying coding flaws, ensuring that development teams can make quick rectifications.

Standout Features and Integrations:

PMD is celebrated for its broad support for multiple programming languages, including Java, JavaScript, and Apex, which grants it a versatility not all tools possess. Its source code analysis is robust, and the ability to detect code smells and coding errors promptly is commendable.

As for integrations, PMD incorporates popular platforms like GitHub, GitLab, and Jenkins, aligning itself perfectly with the development process of many teams.

Pros and cons

Pros:

  • Robust integrations with platforms like GitHub and Jenkins.
  • Quick and effective detection of common coding flaws.
  • Broad support for multiple programming languages.

Cons:

  • Being open-source, it might lack some commercial-level support or features.
  • The UI might not be as intuitive for beginners.
  • Might require some configuration for specific projects.

Other Static Code Analysis Tools for Java

Below is a list of additional static code analysis tools for Java that I shortlisted, but did not make it to the top 10. These are definitely worth checking out.

  1. Klocwork

    For real-time security vulnerability detection

  2. Fortify on Demand

    For cloud-based security assessments

  3. Checkmarx

    For in-depth source code scanning

  4. Infer

    Good for mobile app static analysis

  5. Fortify Static Code Analyzer

    Good for end-to-end vulnerability management

  6. Veracode Static Analysis (SAST)

    Good for scalable threat detection in binaries

  7. CodeSonar

    Good for detecting complex programming errors

  8. SpotBugs

    Good for bite-sized code bug spotting

  9. Checkstyle

    Good for Java coding standard adherence

  10. Semmle

    Good for data-driven code exploration

  11. CodeRush

    Good for in-IDE code visualization

  12. FindBugs

    Good for bytecode-based Java bug detection

  13. Kiuwan Code Security

    Good for code security with business metrics

Selection Criteria For Static Code Analysis Tools For Java

When diving into the vast world of static code analysis tools for Java, it's essential to have a clear criterion in mind for evaluation. Throughout my journey, I've evaluated dozens of these tools, seeking out those that deliver the best in terms of functionality, features, and user experience.

In this particular case, my focus was majorly on their capabilities to integrate with modern development environments, provide concrete insights into the codebase, and ensure a smooth user experience. Below, I detail the criteria that became my guideposts.

Core Functionality

  • Code Scanning: Ability to comprehensively scan Java source code to identify potential vulnerabilities or issues.
  • Real-time Feedback: Offer immediate feedback during code writing, not just after code commits.
  • Language Support: Beyond Java, the tool should be capable of supporting other languages like JavaScript, TypeScript, or even older languages like Cobol when necessary.
  • Integration with CI/CD: Tools need to plug into Continuous Integration/Continuous Deployment (CI/CD) pipelines to automate the code analysis process.
  • API Checks: Ability to analyze API calls and identify potential security threats or misconfigurations.

Key Features

  • Semantic Analysis: Beyond syntax checks, the tool should understand code semantics to identify deeper issues.
  • Annotations Support: Recognize and validate custom annotations in the codebase, ensuring they're applied correctly.
  • Custom Rule Definition: Allow developers to define custom rules specific to their project's needs or company policies.
  • Historical Analysis: Provide insights into how code quality has changed over time, helping teams understand their progress.
  • Framework-specific Checks: Recognize and validate common frameworks, ensuring their proper usage.
  • Visual Reports: Deliver insights through easy-to-read, visual reports, preferably integrating with tools like Visual Studio for easy access.

Usability

  • Intuitive Interface: A straightforward dashboard that provides quick insights without the need to navigate through countless menus.
  • Role-based Access: Essential for larger teams or enterprise solutions, ensuring that only the right people can make specific changes or access certain data.
  • Easy Filtering or Tagging: When dealing with thousands of potential issues, the ability to filter or tag is crucial. This could be based on severity, the developer responsible, or the part of the application affected.
  • Comprehensive Support and Training: With such technical tools, a comprehensive knowledge base, learning library, or onboarding training is crucial. It accelerates the onboarding process and acts as a reference for developers.

Having these criteria in mind will not only streamline your search but also ensure that the tool you select aligns with your team's needs and the specific demands of your projects.

Most Common Questions Regarding Static Code Analysis Tools for Java (FAQs)

What are the benefits of using static code analysis tools for Java?

Static code analysis tools for Java provide a multitude of advantages:

  1. Early Bug Detection: These tools can detect potential coding errors and vulnerabilities in the early stages of the development cycle, minimizing the cost of late-stage corrections.
  2. Improved Code Quality: They ensure adherence to coding standards and help identify code smells, ensuring better maintainability and performance.
  3. Security Assurance: By identifying security issues, such as OWASP top vulnerabilities, they help in building secure applications, thereby protecting sensitive data and operations.
  4. Efficient Code Review: Automated analysis makes code reviews more focused and efficient, as developers can concentrate on the logic rather than syntax or minor mistakes.
  5. Integration Capabilities: Most tools integrate with popular IDEs like Eclipse, IntelliJ IDEA, and repositories like GitHub, allowing for continuous code checking within the development workflow.

How much do static code analysis tools for Java typically cost?

The pricing for these tools can vary significantly based on their feature set, the size of the organization, and specific requirements. Some tools may have a subscription-based model priced per user/month, while others might charge based on the lines of code being analyzed or the number of projects.

What are the typical pricing models for these tools?

The common pricing models include:

  • Subscription-based: Priced per user/month or year.
  • Perpetual Licenses: One-time purchase with periodic maintenance fees.
  • Lines of Code (LOC) Based: Pricing determined by the volume of code to be analyzed.
  • Project-based: Pricing based on the number of projects being analyzed.

What is the typical range of pricing for static code analysis tools?

The pricing can start as low as $10/user/month for basic tools and can go up to several thousand dollars for enterprise-grade solutions with extensive features and support.

Which are the cheapest and most expensive static code analysis tools for Java?

The cheapest tools might include open-source options like Checkmarx, while the more expensive ones with a broader range of features and extensive support could be tools like SonarQube Enterprise or Fortify. It’s essential to note that the “most expensive” doesn’t necessarily mean the best; it’s more about the features and support offered.

Are there any free static code analysis tools for Java?

Yes, there are several open-source and free tools available. Some of the notable ones include:

  • SpotBugs: An open-source tool that looks for bugs in Java code.
  • PMD: It finds common programming flaws in Java, JavaScript, and more.
  • SonarQube Community Edition: Offers a free version with essential code quality and security features.

It’s crucial to understand that while free tools can offer great value, they might lack some advanced features or integrations found in their paid counterparts.

Other Code Analysis Tool Reviews

Summary

In the realm of software development, especially for Java, the right static code analysis tool can dramatically influence the overall quality, security, and maintainability of your projects. These tools not only preemptively catch vulnerabilities and bugs but also ensure your code adheres to the highest standards.

Given the variety in pricing models, features, and integrations, selecting the ideal tool requires a deep understanding of both your project's requirements and each tool's offerings.

Key Takeaways

  1. Understand your needs: Not every project requires the most extensive tool on the market. Assess your project's size, security requirements, and integration needs before making a choice.
  2. Consider total costs: While pricing is crucial, don't let it be the sole deciding factor. Factor in potential future costs like training, upgrades, or changes in team size. Sometimes, investing a bit more initially can save considerable resources in the long run.
  3. Explore integration and support: Ensure the tool integrates with your existing development workflow, repositories, and IDEs. Also, look into the kind of support and community backing each tool has, as this can influence ease of troubleshooting and continuous learning.

By keeping these points in mind, you can confidently navigate the landscape of static code analysis tools and select one that elevates your Java development endeavors.

What Do You Think?

I've tried to cover the most impactful static code analysis tools for Java in this guide. However, the tech landscape is vast and ever-evolving. If there's a tool you've found invaluable and think it deserves a mention, I'd love to hear about it! Your suggestions and experiences can greatly benefit the community. Please share your recommendations in the comments below or reach out directly. Let's learn and grow together!

Paulo Gardini Miguel
By Paulo Gardini Miguel

Paulo is the Director of Technology at the rapidly growing media tech company BWZ. Prior to that, he worked as a Software Engineering Manager and then Head Of Technology at Navegg, Latin America’s largest data marketplace, and as Full Stack Engineer at MapLink, which provides geolocation APIs as a service. Paulo draws insight from years of experience serving as an infrastructure architect, team leader, and product developer in rapidly scaling web environments. He’s driven to share his expertise with other technology leaders to help them build great teams, improve performance, optimize resources, and create foundations for scalability.