mirror of
https://github.com/MichaelCade/90DaysOfDevOps.git
synced 2025-01-18 16:29:23 +07:00
Day 63 - An introduction to databases
This commit is contained in:
parent
514947a3db
commit
a8bb6d9eb9
134
2023/day63.md
134
2023/day63.md
@ -0,0 +1,134 @@
|
||||
# An introduction to databases
|
||||
|
||||
Welcome to the 90DaysOfDevOps database series. Over the next seven days we’ll be talking about all things database related!
|
||||
|
||||
The aim of this series of blog posts is to provide an introduction to databases and their various concepts so that you will be able to make an informed choice when deciding how to store data in your future projects.
|
||||
|
||||
Here’s what we’ll be covering: -
|
||||
|
||||
- An introduction to databases
|
||||
- Querying data in databases
|
||||
- Backing up databases
|
||||
- High availability and disaster recovery
|
||||
- Performance tuning
|
||||
- Database security
|
||||
- Monitoring and troubleshooting database issues
|
||||
|
||||
We’ll also be providing examples to accompany the concepts discussed. In order to do so you will need Docker Desktop installed. Docker can be downloaded here (https://www.docker.com/products/docker-desktop/) and is completely free.
|
||||
|
||||
Alternatives to Docker Desktop can be used (such as Rancher Desktop or Finch) but the examples will focus on Docker.
|
||||
|
||||
We'll be using a custom PostgreSQL image in the examples and connecting with pgAdmin: -
|
||||
https://www.pgadmin.org/
|
||||
|
||||
<br>
|
||||
|
||||
# About Us
|
||||
|
||||
<b>Andrew Pruski</b><br>
|
||||
Andrew is a Field Solutions Architect working for Pure Storage. He is a Microsoft Data Platform MVP, Certified Kubernetes Administrator, and Raspberry Pi tinkerer. You can find him on twitter @dbafromthecold, LinkedIn, and blogging at dbafromthecold.com
|
||||
|
||||
<b>Taylor Riggan</b><br>
|
||||
Taylor is a Sr. Graph Architect on the Amazon Neptune development team at Amazon Web Services. He works with customers of all sizes to help them learn and use purpose-built NoSQL databases via the creation of reference architectures, sample solutions, and delivering hands-on workshops. You can find him on twitter @triggan and LinkedIn.
|
||||
|
||||
<br>
|
||||
|
||||
# Why databases?
|
||||
|
||||
The total amount of data created worldwide is predicted to reach 181 zetabytes by 2025.
|
||||
|
||||
That’s 181 billion terabytes!
|
||||
|
||||
![](images/day63-1.png)
|
||||
|
||||
source - https://www.statista.com/statistics/871513/worldwide-data-created/
|
||||
|
||||
|
||||
Imagine if all that data was stored in flat files, for example excel sheets! OK, storing that data might not be such an issue, just save the file on a networked drive and all good! But what about when it comes to retrieving that data? What about updating a single record amongst hundreds, thousands, millions of files?
|
||||
|
||||
This is where database technologies come into play. Databases give us the ability to not only store data but to easily retrieve, update, and delete individual records.
|
||||
|
||||
<br>
|
||||
|
||||
# Relational databases
|
||||
|
||||
When it comes to databases, there are two main types...relational and non-relational (or NoSQL) databases.
|
||||
|
||||
SQL Server, Oracle, MySQL, and PostgreSQL are all types of relational databases.
|
||||
|
||||
Relational databases were first described by Edgar Codd in 1970 whilst he was working at IBM in a research paper , “A Relation Model of Data for Large Shared Data Banks”.
|
||||
|
||||
This paper led the way for the rise of the various different relational databases that we have today.
|
||||
|
||||
In a relational database, data is organised into tables (containing rows and columns) and these tables have “relationships” with each other.
|
||||
|
||||
For example, a Person table may have an addressID column which points to a row within an Address table, this allows for an end user or application to easily retrieve a record from the Person table and the related record from the Address table.
|
||||
|
||||
The addressID column is a unique “key” in the Address table but is present in the Person table as a “foreign key”.
|
||||
|
||||
The design of the tables and the relations between them in a relational database is said to be the database schema. The process of building this schema is called database normalisation.
|
||||
|
||||
Data is selected, updated, or deleted from a relational database via a programming language called SQL (Structured Query Language).
|
||||
|
||||
In order to support retrieving data from tables in a relational database, there is the concept of “indexes”. In order to locate one row or a subset of rows from a table, indexes provide a way for queries to quickly identify the rows they are looking for, without having to scan all the rows in the table.
|
||||
|
||||
The analogy often used when describing indexes is an index of a book. The user (or query) uses the index to go directly to the page (or row) they are looking for, without having to “scan” all the way through the book from the start.
|
||||
|
||||
Queries accessing databases can also be referred to as transactions…a logical unit of work that accesses and/or modifies the data. In order to maintain consistency in the database, transactions must have certain properties. These properties are referred to as ACID properties: -
|
||||
|
||||
A - Atomic - all of the transaction completes or none of it does<br>
|
||||
C - Consistency - the data modified must not violate the integrity of the database<br>
|
||||
I - Isolation - multiple transactions take place independently of one another<br>
|
||||
D - Durability - Once a transaction has completed, it will remain in the system, even in the event of a system failure.
|
||||
|
||||
We will go through querying relational databases in the next blog post.
|
||||
|
||||
<br>
|
||||
|
||||
# Non-Relational databases
|
||||
|
||||
The downside of relational databases is that the data ingested has to "fit" to the structure of the database schema. But what if we're dealing with large amounts of data that doesn't match that structure?
|
||||
|
||||
This is where non-relational databases come into play. These types of databases are referred to as NoSQL (non-SQL or Not Only SQL) databases and are either schema-free or have a schema that allows for changes in the structure.
|
||||
|
||||
Apache Cassandra, MongoDB, and Redis are all types of NoSQL databases.
|
||||
|
||||
Non-relational databases have existed since the 1960s but the term “NoSQL” was used in 1998 by Carlo Strozzi when naming his Strozzi NoSQL database, however that was still a relational database. It wasn’t until 2009 when Johan Oskarsson reintroduced the term when he organised an event to discuss “open-source distributed, non-relational databases”.
|
||||
There are various different types of NoSQL databases, all of which store and retrieve data differently.
|
||||
|
||||
For example: -
|
||||
|
||||
Apache Cassandra is a wide-column store database. It uses tables, rows, and columns like a relational database but the names and formats of the columns can vary from row to row in the same table. It uses Cassandra Query Language (CSQL) to access the data stored.
|
||||
|
||||
MongoDB is a document store database. Data is stored as objects (documents) within the database that do not adhere to a defined schema. MongoDB supports a variety of methods to access data, such as range queries and regular expression searches.
|
||||
|
||||
Redis is a distributed in-memory key-value database. Redis supports many different data structures - sets, hashes, lists, etc. - https://redis.com/redis-enterprise/data-structures/
|
||||
The records can be identified using a unique key. Redis supports various different programming languages in order to access the data stored.
|
||||
|
||||
NoSQL databases generally do not comply with ACID properties but there are exceptions.
|
||||
|
||||
Each has pros and cons when it comes to storing data, which one to use would be decided on the type of data that is being ingested.
|
||||
|
||||
<br>
|
||||
|
||||
# When to use relational vs non-relational databases
|
||||
|
||||
This is an interesting question and the answer, unfortunately, is it depends.
|
||||
|
||||
It all depends on the type of data being stored, where it is to be stored, and how it is to be accessed.
|
||||
|
||||
If you have data that is highly structured, stored in a central location, and will be accessed by complex queries (such as reports), then a relational database would be the right choice.
|
||||
|
||||
If however, the data is loosely-structured, needs to be available in multiple regions, and will be retrieved with a specific type of query (e.g.- a quick lookup in a key/value store), then a non-relational database would be the right choice.
|
||||
|
||||
There is a massive caveat with the statements above however…there are types of non-relational databases that can handle large, complex queries likewise relational databases have features that allow for data to be available in multiple regions.
|
||||
|
||||
It also comes down to the skillset of the people involved, for example, Andrew is a former SQL Server DBA…so we know what his default choice would be when choosing a type of database!
|
||||
|
||||
While, in contrast, Taylor works on the development team for one of the more popular, cloud-hosted, graph databases, so he is more likely to start with a NoSQL data store.
|
||||
|
||||
The great thing about databases is that there are so many choices to choose from within the realm of commercial offerings, cloud services, and the open-source ecosystem. The amount of choice, however, can be daunting for someone new to this space
|
||||
|
||||
Join us tommorrow when we'll be talking about querying databases.
|
||||
|
||||
Thanks for reading!
|
BIN
2023/images/day63-1.png
Normal file
BIN
2023/images/day63-1.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 43 KiB |
Loading…
Reference in New Issue
Block a user