Cloud database

A cloud database is a database that typically runs on a cloud computing platform, access to it is provided as a service.

Database services take care of scalability and high availability of the database. Database services make the underlying software-stack transparent to the user.

Deployment models

There are two primary methods to run a database in a cloud:

Virtual machine image
Cloud platforms allow users to purchase virtual-machine instances for a limited time, and one can run a database on such virtual machines. Users can either upload their own machine image with a database installed on it, or use ready-made machine images that already include an optimized installation of a database. For example, Oracle provides a ready-made machine image with an installation of Oracle Database 11g Enterprise Edition on Amazon EC2[1] and on Microsoft Azure.[2]
Database-as-a-service (DBaaS)
With a database as a service model, application owners do not have to install and maintain the database themselves. Instead, the database service provider takes responsibility for installing and maintaining the database, and application owners are charged according to their usage of the service. For example, Amazon Web Services provides three database as a service offerings as part of its cloud portfolio: SimpleDB, a NoSQL key-value store; Amazon RDS, a relational database service that includes support for MySQL, Oracle, and more; and DynamoDB. Microsoft offers its Azure SQL Database service on its Azure cloud service platform. Cloud computing platform Rackspace offers database as a service for MySQL and MongoDB. Database as a service providers are not limited to cloud computing platforms. For example, MongoDB as a service provider mLab allows their customers to host their databases on AWS, Azure, or Google Cloud Platform. Database vendors have also launched their own services under this model. Oracle provides its own database as a service, allowing users to access Oracle Database 11g and 12c as cloud services. MongoDB recently launched its own hosted MongoDB as a service, MongoDB Atlas.[3]

Architecture and common characteristics

Data model

The design and development of typical systems utilize data management and relational databases as their key building blocks. Advanced queries expressed in SQL work well with the strict relationships that are imposed on information by relational databases. However, relational database technology was not initially designed or developed for use over distributed systems. This issue has been addressed with the addition of clustering enhancements to the relational databases, although some basic tasks require complex and expensive protocols, such as with data synchronization.[6]

Modern relational databases have shown poor performance on data-intensive systems, therefore, the idea of NoSQL has been utilized within database management systems for cloud based systems.[7] Within NoSQL implemented storage, there are no requirements for fixed table schemas, and the use of join operations is avoided. "The NoSQL databases have proven to provide efficient horizontal scalability, good performance, and ease of assembly into cloud applications."[8]

It is also important to differentiate between cloud databases which are relational as opposed to non-relational or NoSQL:

SQL databases
Such as PostgreSQL, EDB Postgres Advanced Server, NuoDB, Oracle Database, Microsoft SQL Server, MariaDB and MySQL, are one type of database which can run in the cloud, either in a virtual machine or as a service, depending on the vendor. While SQL databases are easily vertically scalable, horizontal scalability poses a challenge, that cloud database services based on SQL have started to address.[9]
NoSQL databases
Such as Apache Cassandra, CouchDB and MongoDB, are another type of database which can run in the cloud. NoSQL databases are built to service heavy read/write loads and can scale up and down easily,[10] and therefore they are more natively suited to running in the cloud.: However, most contemporary applications are built around an SQL data model, so working with NoSQL databases often requires a complete rewrite of application code.[11]
Some SQL databases have developed NoSQL capabilities including JSON, binary JSON (e.g. BSON or similar variants), and key-value store data types. These multi-model databases include PostgreSQL and EDB Postgres Advanced Server.
A multi-model database with relational and non-relational capabilities provides a standard SQL interface to users and applications and thus facilitates the usage of such databases for contemporary applications built around an SQL data model.

Vendors

The following table lists notable database vendors with a cloud database offering, classified by their deployment model – machine image vs. database as a service – and data model, SQL vs. NoSQL.

Cloud database vendors by deployment and data model
Virtual Machine Deployment Database as a Service
SQL Data Model
NoSQL Data Model

See also

References

  1. 1 2 Amazon Machine Images - Oracle Database 11g Release 2 (11.2.0.1) Enterprise Edition - 64 Bit, Amazon Web Services, Retrieved 2011-11-9.
  2. List of Oracle VM Images (MSDN), Retrieved 2014-9-22
  3. "MongoDB Atlas - Hosted MongoDB as a Service". Retrieved 2016-09-01.
  4. "AWS Management Console, Amazon RDS Features", Amazon Web Services, Retrieved 2011-11-10.
  5. "Amazon Relational Database Service, Features, Detailed Description", Amazon Web Services, Retrieved 2011-11-10.
  6. A. Anjomshoaa and A. Tjoa, "How the cloud computing paradigm could shape the future of enterprise information processing", Proceedings of the 13th International Conference on Information Integration and Web-based Applications and Services - iiWAS'11, pp. 7-10, 2011.
  7. S. Cass, "Designing for the Cloud", MIT Technology Review, 2009. [Online]. Available: https://www.technologyreview.com/s/414090/designing-for-the-cloud/. Retrieved 2016-10-04.
  8. "NoSQL", Wikipedia, 2016. Retrieved 2016-10-04.
  9. Dave Rosenberg, Are databases in the cloud really all that different?, CNET, Retrieved 2011-11-6
  10. Agrawal, Rakesh; et al. (2008). "The Claremont report on database research" (PDF). SIGMOD Record. ACM. 37 (3): 9–19. ISSN 0163-5808. doi:10.1145/1462571.1462573.
  11. Ken North, "SQL, NoSQL or SomeSQL?", Dr. Dobb's, Retrieved 2011-11-9.
  12. Deploy your database applications and projects on the cloud, IBM.com, Retrieved 2011-9-1
  13. Chris Kanaracus, "Ingres rolls out cloud database offerings", Infoworld.com, Retrieved 2011-8-28.
  14. "Amazon Web Services Announces Two New Database Services – AWS Database Migration Service and Amazon RDS for MariaDB, Amazon Press Releases, retrieved 2015-11-17
  15. "MariaDB Enterprise Cluster + MariaDB MaxScale, Microsoft Azure, retrieved 2015-11-17
  16. "Running MySQL on Amazon EC2 with EBS (Elastic Block Store), Amazon Web Services, retrieved 2011-11-20
  17. Swoyer, Stephen. "NuoDB: A Database for the Cloud." TDWI. Nov. 13, 2012. Retrieved Nov. 26, 2012
  18. "Oracle Database in the Cloud", Oracle.com, Retrieved 2011-11-9.
  19. Chris Kanaracus, "EnterpriseDB Adding New Cloud Option for PostgreSQL Database", PCWorld, retrieved 2011-8-28
  20. "AWS | SAP HANA". Amazon Web Services, Inc. Retrieved 2016-07-07.
  21. "SAP Solutions | Microsoft Azure". azure.microsoft.com. Retrieved 2016-07-07.
  22. "SAP HANA Enterprise Cloud". hana.sap.com. Retrieved 2016-07-07.
  23. https://finance.yahoo.com/news/clustrix-enters-rackspace-partner-program-120500944.html
  24. 1 2 EnterpriseDB#cite note-10
  25. "Cloud SQL - MySQL Relational Database Service". Retrieved 2016-11-28.
  26. "Announcing Heroku PostgreSQL Database Add-on", Heroku Blog, Retrieved 2011-11-9.
  27. Noel Yuhanna, SQL Azure Raises The Bar On Cloud Databases, Forrester, Retrieved 2011-11-9.
  28. Klint Finley, "7 Cloud-Based Database Services", ReadWriteWeb, Retrieved 2011-11-9.
  29. "Setting up Cassandra in the Cloud", Cassandra Wiki, Retrieved 2011-11-10.
  30. "Google Cloud Platform Blog: Click to Deploy Apache Cassandra on Google Compute Engine". Retrieved 2016-11-28.
  31. "Clusterpoint Database Virtual Box VM Installation Guide Archived 2015-03-10 at Archive.is", Clusterpoint, Retrieved 2015-03-08.
  32. "Amazon Machine Images, CouchDB 0.10.x 32 bit Ubuntu", Amazon Web Services, Retrieved 2011-11-10.
  33. "CouchDB Cloud Hosting on Google Cloud Platform". Retrieved 2016-11-28.
  34. "Amazon Machine Image, Hadoop AMI", Amazon Web Services, Retrieved 2011-11-10.
  35. "Cloud Dataproc - Managed Spark & Managed Hadoop Service". Retrieved 2016-11-28.
  36. "Hadoop at Rackspace", Rackspace Big Data Platforms, Retrieved 2014-02-24.
  37. "MarkLogic Developer 8 (HVM) on AWS Marketplace". aws.amazon.com. Retrieved 2016-03-31.
  38. marklogic.com. "Flexible Deployment" (PDF). Retrieved 2016-11-28.
  39. "MongoDB on Amazon EC2, MongoDB.org, Retrieved 2011-11-10.
  40. "Deploying MongoDB on Google Compute Engine". Retrieved 2016-11-28.
  41. "MongoDB on Azure, MongoDB.org, Retrieved 2011-11-10.
  42. "Easily Scale MongoDB at Rackspace", Managed MongoDB ObjectRocket by Rackspace, Retrieved 2014-02-24.
  43. "Neo4J in the Cloud Archived 2011-09-25 at the Wayback Machine.", Neo4J Wiki, Retrieved 2011-11-10.
  44. "Announcing Neo4J on Windows Azure", Neo4J Blog, Retrieved 2011-11-10.
  45. Andrew Brust, "Cloudant Makes NoSQL as a Service Bigger", ZDNet, Retrieved 2012-5-22.
  46. "Bigtable - Scalable NoSQL Database Service". Retrieved 2016-11-28.
  47. "Datastore - NoSQL Schemaless Database". Retrieved 2016-11-28.
  48. "MongoDB Atlas - Hosted MongoDB as a Service". Retrieved 2016-08-30.
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.