Skip to content

Latest commit

 

History

History
75 lines (42 loc) · 4.17 KB

README.md

File metadata and controls

75 lines (42 loc) · 4.17 KB

Header Image


Flamingock is the evolution of Mongock, designed as a cloud-native solution for managing versioning, and auditing changes in systems that evolve alongside your application.

Whilst Mongock focused on versioning NoSQL databases, Flamingock extends this concept to all technologies, systems, and configurations, with built-in auditing and rollback capabilities. It ensures the application and its dependent components evolve together by managing configuration changes during startup to maintain version compatibility, streamline integration, and reduce conflicts at deployment time.

Flamingock also introduces new mechanisms for defining changes in an extensible and customizable manner, beyond traditional code-based methods.

Additionally, Flamingock offers multiple infrastructure setups for providing flexibility to users, as it introduces a Cloud offering whilst still retaining existing supported databases such as MongoDB, DynamoDB, or Couchbase.


🔑 Key Features

  • 🔄 Auditing & Rollback: Comprehensive auditing capabilities with support for rollback of changes to ensure consistency and control.

  • ☁️ Cloud-Native: Offers a fully managed service by hosting Flamingock’s operational data on our servers, removing the need for users to set up and manage their own databases.

  • 🔗 Extended System Support: Expands on Mongock's support to all systems, databases, technologies and configurations.

  • 🚀 Seamless Deployment: Deploy your application and systems together, ensuring version compatibility and reducing deployment friction.

  • 🧩 Flexible Migration Templates: New mechanisms for defining changes, offering a no-code option to streamline and simplify change management.

  • GraalVM Support: Enables the compilation of Java applications into native executables for improved performance.

  • 👥 Multi-Tenant Support: Designed to handle multiple tenants within the same infrastructure.

  • 🔒 Distributed Locking: Ensures synchronized deployment of multiple service instances, maintaining consistency and preventing conflicts in distributed environments.

  • 🛠️ Advanced Workflow Management: Enables multiple streams of change units that can be organized to execute sequentially, in parallel, or as a combination, providing flexibility in managing complex processes.

  • 🔀 Parallel Synchronised Execution: When workflows include parallel streams, they can be executed simultaneously by different service instances, maximizing efficiency in distributed deployments.


📂 Getting started with our examples

For full examples of how to use Flamingock in various environments, check the examples project.


🔀 Migration from Mongock

If you're transitioning from Mongock to Flamingock, we have separate migration guides for each use case:

  • Standalone Applications: Detailed instructions for migrating from Mongock to Flamingock in a standalone Java application.
  • Spring Boot Applications: Step-by-step guide for migrating from Mongock to Flamingock in a Spring Boot application.

Each guide provides specific instructions tailored to the corresponding environment. Follow the appropriate guide to ensure a smooth migration process.


📢 Contributing

We welcome contributions! If you have an idea for a new example or improvement to an existing one, feel free to submit a pull request. Check out our CONTRIBUTING.md for guidelines.


🤝 Get Involved

⭐ Star the Flamingock repository to show your support!

🐞 Report issues or suggest features in the Flamingock issue tracker.

💬 Join the discussion in the Flamingock community.


📜 License

This repository is licensed under the Apache License 2.0.


🔥 Explore, experiment, and empower your projects with Flamingock!

Let us know what you think or where you’d like to see Flamingock used next.