Storing and Sharing Data Across Containers
Storing and Sharing Data Across Containers
Using Jelastic? Here's how to use their data storage containers. See how they work and how you can use them to store and share your information.
Join the DZone community and get the full member experience.Join For Free
Learn how to migrate and modernize stateless applications and run them in a Kubernetes cluster.
Recently we released a new version of Jelastic Cloud with the support of a certified Data Storage Container. So today we’d like to pay more attention to this instance and describe the main data sharing possibilities it provides to Jelastic customers.
Data Storage Container feature solves the issues with content duplication between several nodes that provide the same service. Also, it simplifies horizontal scaling of applications as well as enables to build more complex environment topologies easier.
Now you can get an elastic data storage right inside a container, with growing and shrinking capacity upon adding or removing content. As a result, your application receives the storage it needs, whilst you pay only for the actually consumed disk space, not for the defined limits.
Introduced Data Storage Container allows you to make multiple environments operating with data in a single storage as easy as if it was kept on the file system locally: e.g. share media files, common configs or just store backups, logs, etc. Herewith, Jelastic provides an easy access to all files within such a storage through the standard dashboard-integrated Configuration Manager.
In such a way, by using data storage container, you can apply smart organization to your projects’ topology and achieve a number of benefits, like:
- Data Persistence and Security
The data is totally safe and secure as it runs inside fully isolated containers and stored separately during application updates.
- Scalable Storage Capacity
Jelastic automatically adjusts size of your storage within predefined limit upon its filling in with data, so you use (and, of course, pay for) exactly the amount of space you currently need.
- Simplified Management
One set of configurations for multiple containers, different types of data storing, integration with Docker volumes and built-in file manager, fully automated scaling.
- Fund Savings
Shared data implies elimination from extra data copies, which results in lower disk space consumption and therefore lower costs.
Data storage container integration at Jelastic is based on network file system (NFS) protocol, used for client-server communication. Actually, the whole procedure is performed in two steps: at the first one, the data is exported (shared) from the storage container to some other instance, and at the second — the appropriate directory is mounted at a client container.
And in order to ensure the best experience while leveraging this feature, a special Dedicated Storage Container type is provided. It has a number of benefits for data storing compared to the rest of container types, such as depended software being pre-installed and enlarged amounts of allocated disk space. Besides that, any instance at Jelastic can be treated as data storage server, including custom Docker containers, where such integration is implemented based on volumes functionality.
With Jelastic Data Storage Container, you get a variety of opportunities to improve your projects’ filesystem structure, make it more reliable and flexible. To get to know more, switch to the docs below, where we consider in more details each storage type, available at Jelastic, and for what kind of data it suits the most:
This kind of storage is used to persist the data, which needs to be kept during container lifecycle, but is not required to be shared across other nodes. If drawing an analogy, basically it’s kind of a folder you create inside a server.
Such type of data storing becomes the most efficient when you don’t need to export files on different environments, but face the necessity to share your data in the confines of a single node layer. The initial (master) node of the layer is used as a storage server.
Any container in the environment can be treated as a data storage server, being assigned an additional storage role beside the main native one. Using such a kind of compound containers suits best for handling simple projects.
For more complex and loaded applications, it is worth to centralize your shared data within a single container to get more simple and flexible exports’ management. Such a dedicated storage container allows you to share files across multiple layers or even environments of a single account.
Such mounting is intended for establishing connections to a third-party NAS storage, which shares data via NFS. So, if you have your own storage server with the properly structured content being already set up, just mount it and share data across the containers, environments or multiple Jelastic installations with no need to copy or transfer it anywhere.
As you see, there are different options for storing and sharing persistent data within Jelastic Cloud, so you can choose the most suitable one according to your project needs or even mix and combine them.
Published at DZone with permission of Tetiana Markova , DZone MVB. See the original article here.
Opinions expressed by DZone contributors are their own.