CIS275 - Chapter 9: NoSQL Databases Flashcards
Structured data created within an organization, with sizes ranging from gigabytes to terabytes, is called _____.
transactional data
Data generated by new internet and multimedia applications is commonly called ____ and differs from transactional data.
data:image/s3,"s3://crabby-images/9a91c/9a91ce6d61d1eac6fdb1075a5a049befd1e26b9b" alt=""
big data
big data and differs from transactional data in four ways:
Volume. Typical size ranges from terabytes to petabytes (million billion bytes), occasionally reaching exabytes (billion billion bytes).
Velocity. Big data is generated at extremely high rates. Facebook users upload roughly a billion photos per day, or 10,000 per second. Twitter generates roughly 6,000 tweets per second. Click rates on popular websites can be significantly higher.
Variety. Variety means both unstructured and rapidly changing data types. Unstructured data refers to information embedded in complex data types like images, video, GPS coordinates, and natural language. Rapidly changing data means the information content of records vary greatly, as in data collected from social media. Both unstructured and rapidly changing data are common in big data.
Veracity. Transactional data is typically created by an organization’s employees or trusted partners. Big data is often generated by the general public. Consequently, the accuracy of big data varies much more than transactional data.
- Variety refers to unstructured data, such as text files, video, web logs, social media, and sensor data.
- Variety also refers to variable data structures. Ex: Facebook, LinkedIn, and Twitter contain different information about people, which might be combined in big data.
data:image/s3,"s3://crabby-images/a5cef/a5cefdb2daa434ebea53aaa9b384141d4a42aaa3" alt=""
data:image/s3,"s3://crabby-images/546bd/546bdfe79bf9d840eaa51bfb4a66611cb7062fba" alt=""
data:image/s3,"s3://crabby-images/586bc/586bcfd44134948822cca028601cf7730275c754" alt=""
_____ increases capacity by increasing speed and size of CPUs and storage devices for a limited number of machines.
data:image/s3,"s3://crabby-images/b34f0/b34f03cc6a98df415100fc9ea2c888464fd11eab" alt=""
Vertical scaling
To accommodate increasing database sizes, transactional applications commonly scale vertically, not horizontally.
Vertical scaling increases processing speed, memory, and storage of a limited number of machines.
data:image/s3,"s3://crabby-images/d8f7a/d8f7a3d65d76d0d08a48e234a00124373cd5f62d" alt=""
_____ increases capacity by adding large numbers of low-cost components like standard disk drives and CPUs.
data:image/s3,"s3://crabby-images/31eac/31eac4a12d343e266c4fc35997107e026d163bef" alt=""
Horizontal scaling
To accommodate increasing database sizes, transactional applications commonly scale vertically, not horizontally.
Horizontal scaling adds an unlimited number of machines working in parallel.
data:image/s3,"s3://crabby-images/79da6/79da6a12f064e43afd9a10a60825f08964d518db" alt=""
_____ splits large tables into separate physical files on one machine.
Partitioning
Relational databases were developed prior to big data. Historically, which of the following requirements were prioritized by relational databases?
data:image/s3,"s3://crabby-images/c3b1c/c3b1c9bb1796012f69a4a101d9a895561813a77a" alt=""
data:image/s3,"s3://crabby-images/748a0/748a049f2ef006264a5c798dad19ca3980a35902" alt=""
_____ splits data sets across multiple machines.
Sharding
data:image/s3,"s3://crabby-images/ccbb5/ccbb548e5b49bb81257a5f701e200f14a32866ff" alt=""
data:image/s3,"s3://crabby-images/db582/db5826b157ebfdfbd21c9d8845561d171a912c90" alt=""
Data is represented as a single key and an associated value. The key is used to access the value.
Key-value database
data:image/s3,"s3://crabby-images/8b9dc/8b9dce13e8727cc55d4616b13a734dbe0d5ace71" alt=""
Key-value systems support a limited set of queries, such as:
put(key, value) - Stores the value in the database, indexed by key.
get(key) - Retrieves the value associated with the key.
multiGet(key1, …, keyn) - Retrieves the values associated with keys 1 through n.
delete(key) - Deletes the value associated with the key.
also called column-based, column family, or tabular database. Data is represented as a key and multiple values. Since each record has multiple values, a descriptive name is stored with each value.
data:image/s3,"s3://crabby-images/b308e/b308e5dff58ae6489cc026094f0c34f356fa911e" alt=""
Wide column database
data:image/s3,"s3://crabby-images/5fb60/5fb601ba385c086cb38878663ba9efb0888f7af2" alt=""
Data is represented as a key and a ‘document’. Usually the document is in a structured, human-readable format such as XML or JSON.
Document database
data:image/s3,"s3://crabby-images/2a9ea/2a9eaf7da923031ab53003d77884880d70b44645" alt=""
Data is represented as a graph with nodes and edges.
Graph database
data:image/s3,"s3://crabby-images/2472c/2472cdcbd247d50c83ab7f37e26181386fe2c39a" alt=""
_____ supports the data models of several categories.
multi-model database, also called a hybrid database
data:image/s3,"s3://crabby-images/fd074/fd074c9d98533f187b51397807a9f38708d34443" alt=""
data:image/s3,"s3://crabby-images/63de5/63de505137c3e7613f693b836732dea03ae9c361" alt=""
Keys are used to identify and locate values. In this example, the key is an email address.
Values are photographs of the person associated with the email address.
Each key is associated with one value.
data:image/s3,"s3://crabby-images/d46e9/d46e906fc61e1725575de8989321a47e9bf4beb8" alt=""
Key-value logical structure
data:image/s3,"s3://crabby-images/3c212/3c212a9fbd404c6d33978b2889e4e5c5e3f73dfd" alt=""
The put() function stores a value in the database.
The get() function retrieves the value associated with a key.
data:image/s3,"s3://crabby-images/db4f4/db4f41bca406a1586d53a9c480d2d32e1a7a9cbb" alt=""
data:image/s3,"s3://crabby-images/0e1d1/0e1d18ed4aefa5403c5c495516ec4c59a539c0ea" alt=""
Values are grouped in hash buckets.
Values are replicated on multiple devices for high availability and fast access.
data:image/s3,"s3://crabby-images/6d2d9/6d2d9493b5e156c3300974653594701da3274bde" alt=""
Key-value physical structure
data:image/s3,"s3://crabby-images/24f0c/24f0ce43493371183f3c9761d37a2357fd36ddb9" alt=""
Updates to values are applied to one replica. For fast updates and high availability, additional replicas are not updated within a transaction.
If other replicas are accessed before an update is propagated, obsolete values are returned.
Eventually, the update is propagated to all replicas.
data:image/s3,"s3://crabby-images/2dad2/2dad26baf0391a252fe90958ba20271bd1ffd24a" alt=""
data:image/s3,"s3://crabby-images/e5d82/e5d82f014dd5b44acb378cd28a13db3dbca4765a" alt=""
data:image/s3,"s3://crabby-images/adbaf/adbaf6be00a2deb216625e458d68a85873bdb00f" alt=""
data:image/s3,"s3://crabby-images/2eb03/2eb03f0e0c6f3be1dd949ec94be3649501fd1f51" alt=""
data:image/s3,"s3://crabby-images/d9b51/d9b51f0f9034e326e2b9683d6d00af162b7faf07" alt=""
Expected: Webpage, User
The key must be unique. A webpage domain name and user email are unique, whereas two students may have the same age.
data:image/s3,"s3://crabby-images/f7aef/f7aefacf5a2ace460f5bb3bab9f5cf2cf15a43e5" alt=""
Expected:
Building,
Stock
The key must be unique. A building’s street address and stock symbol are unique, whereas two students may have the same age.
data:image/s3,"s3://crabby-images/5998f/5998fde37f84c7963d86ed939c00a5108992618a" alt=""
Expected:
Stock,
Employee
The key must be unique. A stock symbol and employee email are unique, whereas two patients may have the same full name.
data:image/s3,"s3://crabby-images/bb02c/bb02c3834f66f3c9756bdc76f134b9352793f6e5" alt=""
Expected: Webpage
The key must be unique. A webpage domain name is unique, whereas two students may have the same age, or two employees may have the same title.
data:image/s3,"s3://crabby-images/27f42/27f427cc625fcefefa1bc30ac6da6e00dc25a254" alt=""
Expected:
‘/User/pics/flower3.jpg’ get(‘mike@email.com’) retrieves the value associated with the key ‘mike@email.com’, which is ‘/User/pics/flower3.jpg’.
data:image/s3,"s3://crabby-images/4c6b5/4c6b504f2d1edcf80133301fac395dda2fe5e3e1" alt=""
Expected: New value added, Existing value replaced ‘joe@email.com’ is not a key, so put(‘joe@email.com’, ‘/User/pics/cat4.jpg’) adds a new key ‘joe@email.com’ with value ‘/User/pics/cat4.jpg’. ‘matt@email.com’ is already a key, so put(‘matt@email.com’, ‘/User/pics/puppy7.jpg’) updates the value ‘/User/pics/puppy7.jpg’ for key ‘matt@email.com’.
_____ databases store multiple versions of each value. Each version is marked with the date and time the version is created, called a timestamp.
timestamp
data:image/s3,"s3://crabby-images/78d8a/78d8ab38b5dbe25a109367e7fa61303bb572a59c" alt=""
To access older values, the timestamp must be specified in a query. If a query does not specify a timestamp, the database selects the most recent version.
In a wide column database, a specific value is accessed with a combination of table name, key, column family name, column name, and optional timestamp.
data:image/s3,"s3://crabby-images/bf7fe/bf7fe8a9fbfa28ddf6b30df63b41198f9fe986cd" alt=""
data:image/s3,"s3://crabby-images/1c2f9/1c2f94d94fc09bada503fd4de02a1ef722c30b94" alt=""
data:image/s3,"s3://crabby-images/4d122/4d122077b7289c58f870591851c6e7658d07d9e4" alt=""
data:image/s3,"s3://crabby-images/3904a/3904a145798228a993992826bb5e3f22c1a50a2c" alt=""
All columns of a family are stored together for fast access via the key.
Different column families are physically separated.
data:image/s3,"s3://crabby-images/18e1b/18e1b1881821b5a661c31ec3015484f72d8f40a4" alt=""
Wide column databases are not optimized to access multiple column families within one query.
data:image/s3,"s3://crabby-images/fe858/fe8587286839e515c4ac312fac6692b1f10f805f" alt=""
data:image/s3,"s3://crabby-images/13109/13109b51f5cfa84a3f5fd737367469ef85ef1ef6" alt=""
data:image/s3,"s3://crabby-images/34be0/34be0ef780c2cfaf79779f1a7f481872f8e4ed55" alt=""
data:image/s3,"s3://crabby-images/cb9da/cb9da4c9ac8a4e73b96bf59c08ba5fd1ee66273d" alt=""
data:image/s3,"s3://crabby-images/3600a/3600a78e43db2eae18229a002acb72b1f9e2e88e" alt=""
data:image/s3,"s3://crabby-images/4e5bf/4e5bff369148ba122042646758548479121d34a0" alt=""
Expected:
Table name Contact
Key ajf@acm.org
Column family name Description
Column name Status
The table ‘Contact’ contains rows indexed by a key. The table has column families ‘Name’, ‘Address’, and ‘Description’. The columns in each column family can vary from one row to another.
So, the ‘Status’ of ‘Arnold J. Fourier’ is found by looking in the ‘Status’ column of the ‘Description’ column family of the row indexed by the key ‘ajf@acm.org’.
data:image/s3,"s3://crabby-images/ffa0b/ffa0b095e39ce644cd26ad7becbedeffb1d04153" alt=""
Expected:
Table name Contact
Key ajf@acm.org
Column family name Address
Column name State
The table ‘Contact’ contains rows indexed by a key. The table has column families ‘Name’, ‘Address’, and ‘Description’. The columns in each column family can vary from one row to another.
So, the ‘State’ of ‘Arnold J. Fourier’ is found by looking in the ‘State’ column of the ‘Address’ column family of the row indexed by the key ‘ajf@acm.org’.
data:image/s3,"s3://crabby-images/522d9/522d9daf1eeff1331f820f8c5afa3f36d213897f" alt=""
Expected: manufacturing
First, the row with key ‘sales@corp.com’ is located. Then, the column family ‘Description’ is accessed. Finally, the value of the column ‘Category’ within the column family ‘Description’, which is ‘manufacturing’, is accessed.
A _____ stores data as a collection of documents.
document database
A document database may contain multiple collections, just as a relational database may contain multiple tables.
- The Flight collection consists of documents describing scheduled airline flights, in JSON format.
- Documents may have a different number of values with different names.
- Usually all documents in a collection share common value names, to facilitate queries.
data:image/s3,"s3://crabby-images/802a0/802a056c5e200fafc5904f96f324ba52d9e28eb7" alt=""
- The Flight collection consists of documents describing scheduled airline flights, in JSON format.
- Documents may have a different number of values with different names.
- Usually all documents in a collection share common value names, to facilitate queries.
data:image/s3,"s3://crabby-images/705b1/705b1d50025fa17c85a0949e96045583593153e6" alt=""
Flight
{
identifier: “cb20896a-eea8-b55c-7a22-08d885640c96”,
FlightNumber: “8809”,
Airline:”United”,
DepartureAirportCode: “JFK”,
ArrivalAirportCode: “ATL”,
}
{
identifier: “bha5678cdbd9e3a587de9b814578dba1”,
FlightNumber: “44”,
Airline: “American”,
DepartureAirportCode: “OAK”,
ArrivalAirportCode: “DFW”,
}
{
identifier: “41b3b38cdbd9e3a587de9b8145111aab”,
FlightNumber: “239”,
Airline:”United”,
DepartureAirportCode: “SFO”,
ArrivalAirportCode: “ORD”
}
data:image/s3,"s3://crabby-images/6aed7/6aed74857504ae138fdcc19c898a919dc36fe937" alt=""
data:image/s3,"s3://crabby-images/9b777/9b7778d00dba06dd8bce5049e1e06e4cdec652e9" alt=""
Documents are assigned to a shard based on a _____.
shard key
The shard key is either the document identifier or some other value. If the shard key is a value, an index of shard key values is created so the database can quickly locate documents.
With a _____, each shard contains a contiguous range of shard key values.
range function
Ex: If the shard key for the Flight collection is Airline, documents for airlines beginning with ‘A’ might be in one shard, ‘B’ in another, and so on.
- The database designer selects either the identifier or an indexed value as the shard key. Airline is chosen as the shard key.
- Documents can be assigned to a shard based on a hash function on the shard key.
data:image/s3,"s3://crabby-images/e1b08/e1b0876aa23797c1f7497a06e4bd6911c123ca21" alt=""
- Alternatively, documents can be assigned to a shard based on a range function.
data:image/s3,"s3://crabby-images/fd4f2/fd4f2854dd28c96330369bab806264f5bc8e9d0b" alt=""
data:image/s3,"s3://crabby-images/e0b47/e0b47323aa1a174c7dbbe5afbf37e265bd1351b3" alt=""
data:image/s3,"s3://crabby-images/c43c3/c43c316387dc6289f6fed54cea5022ae5437a392" alt=""
data:image/s3,"s3://crabby-images/3721b/3721ba5fd7d3d0a3caebfa93309097b4b1d64766" alt=""
data:image/s3,"s3://crabby-images/6a401/6a40123a2ab167c8aaab8b00c3a24990d1d241ae" alt=""
data:image/s3,"s3://crabby-images/58fca/58fcab782eaf9a3edc0ca85ed261d744b32c3293" alt=""
Expected: No documents are selected
No documents have the key Credits.
data:image/s3,"s3://crabby-images/b1d16/b1d16fbad5ff70348addf86406f75ea74a57bfc9" alt=""
data:image/s3,"s3://crabby-images/9cb64/9cb64f1b7e08ea28e04322d2690bc65200e6654d" alt=""
data:image/s3,"s3://crabby-images/f89dd/f89dd538560b93153c4e9b83dbc3ec71978c355f" alt=""
data:image/s3,"s3://crabby-images/2e07d/2e07d4a5f5233cee14f91b5e1ef953dcff6e3c74" alt=""
a hub where network lines converge.
A vertex, also called a node
data:image/s3,"s3://crabby-images/d330e/d330ed1be690bf0c1b9c05875e3cb9835aaf0331" alt=""
a connection between two vertices.
An edge, also called a link
data:image/s3,"s3://crabby-images/86fed/86fedd53220e3ab271f59b7506ad9c76e120d08f" alt=""
descriptive information associated with vertices and edges.
property
In a _____, edges have a starting and ending vertex and are depicted as arrows.
directed graph
data:image/s3,"s3://crabby-images/d6054/d60545588fa856122b62d9af9428f4250646b52c" alt=""
In an _____, edges have no direction and are depicted as lines.
undirected graph
data:image/s3,"s3://crabby-images/2b862/2b86230b48e5249f085442c646e3fdbdf1771d56" alt=""
data:image/s3,"s3://crabby-images/f64a3/f64a3c2f20384e7e1c6b0fa7ace8db72d79e3cce" alt=""
data:image/s3,"s3://crabby-images/f6862/f68620551079912bfce1f0d674336c03bcd7316f" alt=""
data:image/s3,"s3://crabby-images/fe23a/fe23a38d710d0bccf5fed181cc5d3d68011ae912" alt=""
data:image/s3,"s3://crabby-images/fdd0b/fdd0b8699494667988b1e63f4c0deec007ea2f1c" alt=""
- Vertex labels are collections of objects, like entity types or tables.
- A vertex is an individual object, like an entity instance or table row. An edge is a relationship between individual objects.
- Properties are name-value pairs for vertices and edges.
data:image/s3,"s3://crabby-images/65b19/65b1956538622d5224f3110b42b4bceafd017a81" alt=""
- Property graphs have flexible schema. Different vertices and edges can have different properties.
data:image/s3,"s3://crabby-images/80b5d/80b5d74f34d1db25d24e9c3d44c42a13132d674f" alt=""
data:image/s3,"s3://crabby-images/95b25/95b25980d81de074241b92a6fe8067644ec1c60b" alt=""
data:image/s3,"s3://crabby-images/db97f/db97f49eae19f21c96e552a11b2a37f6146b20ea" alt=""
- g.addV().property() adds a vertex with label ‘Passenger’ to graph g.
- g.addV().property() adds a vertex with label ‘Flight’ to graph g.
data:image/s3,"s3://crabby-images/57524/575241fed4adaabeb7d6e212b18ebce15d94b7c8" alt=""
- g.V().addE().to() adds an edge between two vertices.
- out() traverses edges from start to end vertex, like a relational join.
data:image/s3,"s3://crabby-images/7c874/7c8742610b56c9cef00a21dd66be0fd51e246542" alt=""
data:image/s3,"s3://crabby-images/af814/af81410df01071087345b70b97fc66509360ca21" alt=""
data:image/s3,"s3://crabby-images/028f8/028f84090fd24c5c5b090b4fce108138354da7ba" alt=""
- In a relational database, a relationship is stored as a foreign key value in an index, along with a pointer to the location of the row containing related data.
- With index-free adjacency, a pointer is stored within the start vertex. Queries that traverse edges require fewer reads.
data:image/s3,"s3://crabby-images/ed62f/ed62f3047e8b225fdaa7b7b10b3f4a547d72859b" alt=""
- A pointer is also stored within the end vertex to enable traversal in any direction.
data:image/s3,"s3://crabby-images/dd86a/dd86a3967c12dd56e0540e72a7b6102ce9fb804b" alt=""
data:image/s3,"s3://crabby-images/4eecc/4eecc62396748971abaecd13eb29f4e5a66787ab" alt=""
data:image/s3,"s3://crabby-images/9b4ae/9b4ae024544979a9ef97a1e605c65f365cadbbc6" alt=""
data:image/s3,"s3://crabby-images/788c5/788c5019e331f713741a920c6bcf3beeb0a85fb0" alt=""
data:image/s3,"s3://crabby-images/9dae1/9dae1bce76368885ed706a76f71b363156e76608" alt=""
data:image/s3,"s3://crabby-images/27085/2708556c3e0b5379d2160ca22df7405c74f9ec20" alt=""
Expected: Jen Choi, $266
Person is an Entity type, so a vertex label. Same for Payment.
Jen Choi is a Person instance, so a vertex.
$266 is a Payment instance, so a vertex.
Kim Soto-Makes-$66 is a connection between two vertices, so an edge.
data:image/s3,"s3://crabby-images/dbb3c/dbb3cc0c4aef2a08217aeb8d96a7c76f5a2012c0" alt=""
Expected:
Jan West-Makes-$142
Payment is an Entity type, so a vertex label, not an edge.
Fay Choi-Pays-$152 could not be an edge as Pays is not a relationship type shown in the graph.
The graph is directed and the arrow points from Person to Payment, so $227-MadeBy-Pat Reid could not be an edge.
The graph is directed and the arrow points from Person to Payment, so $91-MadeBy-Tia Hale could not be an edge.
The graph is directed and the arrow points from Person to Payment, so $268-MadeBy-Del Hall could not be an edge.
Jan West-Makes-$142 is a connection between two vertices, so could be an edge.
data:image/s3,"s3://crabby-images/4824e/4824ed84c05daf764f85a3162922fc05441554ab" alt=""
Expected:
Rob Ross-Teaches-English
Ina West-Teaches-English
Rob Ross-Teaches-English is a connection between two vertices, so could be an edge.
Course is an Entity type, so a vertex label, not an edge.
Instructor is an Entity type, so a vertex label, not an edge.
Ina West-Teaches-English is a connection between two vertices, so could be an edge.
The graph is directed and the arrow points from Instructor to Course, so Databases-TaughtBy-Zoe Rios could not be an edge.
Teaches is a Relationship type, so an edge label.
data:image/s3,"s3://crabby-images/b1162/b1162c8ebff4fb678f2cf4ca9d1b96e6cd45fb31" alt=""
Expected:
NumberOfTerminals: 5
FlightNumber: 3572
MealPreference is a property name without a value, so not a property.
5 is a property value without a name, so not a property.
FlightNumber is a property name without a value, so not a property. NumberOfTerminals: 5 is a name-value pair, so a property.
Rob Wood is a property value without a name, so not a property.
Default is a property value without a name, so not a property. FlightNumber: 3572 is a name-value pair, so a property.
data:image/s3,"s3://crabby-images/948f8/948f88fba0dc51c3e2eb59bf814fcf9d41b94fe4" alt=""
Expected:
PhoneNumber: (171) 736-1461
Gate: 29
DateOfBirth is a property name without a value, so not a property.
10 is a property value without a name, so not a property.
First is a property value without a name, so not a property. PhoneNumber: (171) 736-1461 is a name-value pair, so a property.
Duration is a property name without a value, so not a property. ArrivalDateTime is a property name without a value, so not a property. Gate: 29 is a name-value pair, so a property.
data:image/s3,"s3://crabby-images/623fb/623fb4f17d26e9a41014344fb76b2630b2e199eb" alt=""
Expected:
g. addV(‘Flight’).property(‘FlightNumber’, ‘3416’).property(‘AirlineName’, ‘Delta’)
g. V(‘Gus King’).addE(‘Books’).to(g.V(‘3416’))
g. V(‘Gus King’).out(‘Books’)
g.addV(‘Flight’) adds a vertex with label ‘Flight’ to graph g. property(‘FlightNumber’,’3416’) adds name-value pair FlightNumber: 3416 to graph g.
property(‘AirlineName’, ‘Delta’) adds name-value pair AirlineName: Delta to graph g.
g. V(‘Gus King’).addE(‘Books’).to(g.V(‘3416’)) adds an edge between vertices Gus King and 3416.
g. V(‘Gus King’).out(‘Books’) traverses edge ‘Books’, merges data from 3416 and Delta, and displays the result.
- A single student is represented as a document with field:value pairs. The name field is assigned a BSON string, gpa is a double, and interests is an array.
- Documents may be nested. The student document contains a nested address document.
data:image/s3,"s3://crabby-images/283de/283dea23a3a2ea84a734a885935565fae2d4238a" alt=""
- MongoDB organizes documents into collections. A group of students is stored in a single collection.
data:image/s3,"s3://crabby-images/5b7c2/5b7c2430e614aa06e346c0db1fc6de47aef75da4" alt=""
data:image/s3,"s3://crabby-images/e1d6b/e1d6bb779110d8091d7b612fa14bc21b1711907a" alt=""
data:image/s3,"s3://crabby-images/6eaeb/6eaebe6c5e469122da45f8adcd742d623d3ce5d6" alt=""
data:image/s3,"s3://crabby-images/791fe/791fe35fc17b32b7d0df49f80c0f4da2b2aa98cb" alt=""
data:image/s3,"s3://crabby-images/a93e7/a93e7f774912ef7c958a72a6f38090a00bb567fa" alt=""
data:image/s3,"s3://crabby-images/7accf/7accfc20c8d0c4afa48100ad70bb1ec559c1bfcb" alt=""
data:image/s3,"s3://crabby-images/eb8ec/eb8ecb84450516c367cd86e34d8e3164906721b9" alt=""