20
Architectural Anti Patterns Notes on Data Distribution and Handling Failures Gleicon Moraes http://zenmachine.wordpress.com http://github.com/gleicon @gleicon

Architectural anti patterns_for_data_handling

Embed Size (px)

DESCRIPTION

My presentation at QCON SP 2010 (Sao Paulo, Brazil)

Citation preview

Page 1: Architectural anti patterns_for_data_handling

Architectural Anti PatternsNotes on Data Distribution and Handling Failures

Gleicon Moraes

http://zenmachine.wordpress.comhttp://github.com/gleicon

@gleicon

Page 2: Architectural anti patterns_for_data_handling

Required Listening: Frank Zappa - One size fits all

Page 3: Architectural anti patterns_for_data_handling

Anti Patterns

Evolution from SQL Anti Patterns (NoSQL:br May 2010)More than just RDBMSLarge volumes of dataDistributionArchitectureResearch on other toolsMessage Queues, DHT, Job Schedulers, NoSQLIndexing, Map/Reduce

Page 4: Architectural anti patterns_for_data_handling

RDBMS Anti Patterns Not all things fit on a relational database, single ou distributed

The eternal table-as-a-tree Dynamic table creationTable as cache Table as queue Table as log fileStoned ProceduresRow AlignmentExtreme JOINsYour scheme must be printed in an A3 sheet.Your ORM issue full queries for Dataset iterations

Page 5: Architectural anti patterns_for_data_handling

Doing it wrong, Junior !

Page 6: Architectural anti patterns_for_data_handling

The eternal treeProblem: Most threaded discussion example uses something like a table which contains all threads and answers, relating to each other by an id. Usually the developer will come up with his own binary-tree version to manage this mess.

id - parent_id -author - text1 - 0 - gleicon - hello world2 - 1 - elvis - shout !

Alternative: Document storage:{ thread_id:1, title: 'the meeting', author: 'gleicon', replies:[ { 'author': elvis, text:'shout', replies:[{...}] } ]}

Page 7: Architectural anti patterns_for_data_handling

Dynamic table creationProblem: To avoid huge tables, one must come with a "dynamic schema". For example, lets think about a document management company, which is adding new facilities over the country. For each storage facility, a new table is created:

item_id - row - column - stuff1 - 10 - 20 - cat food2 - 12 - 32 - trout

Now you have to come up with "dynamic queries", which will probably query a "central storage" table and issue a huge join to check if you have enough cat food over the country.

Alternatives: - Document storage, modeling a facility as a document- Key/Value, modeling each facility as a SET

Page 8: Architectural anti patterns_for_data_handling

Table as cacheProblem: Complex queries demand that a result be stored in a separated table, so it can be queried quickly. Worst than views

Alternatives: - Really ?

- Memcached

- Redis + AOF + EXPIRE

- De-normalization

Page 9: Architectural anti patterns_for_data_handling

Table as queueProblem: A table which holds messages to be completed. Worse, they must be ordered bytime of creation.

Corolary: Job Scheduler table

Alternatives: - RestMQ, Resque

- Any other message broker

- Redis (LISTS - LPUSH + RPOP)

- Use the right tool

Page 10: Architectural anti patterns_for_data_handling

Table as log fileProblem: A table in which data gets written as a log file. From time to time it needs to be purged. Truncating this table once a day usually is the first task assigned to new DBAs.

Alternative:

- MongoDB capped collection

- Redis, and RRD pattern

- RIAK

Page 11: Architectural anti patterns_for_data_handling

Stoned proceduresProblem: Stored procedures hold most of your applications logic. Also, some triggers are used to - well - trigger important data events.

SP and triggers has the magic property of vanishing of our memories and being impossible to keep versioned.

Alternative: - Now be careful so you dont use map/reduce as modern stoned procedures. Unfit for real time search/processing

- Use your preferred language for business stuff, and let event handling to pub/sub or message queues.

Page 12: Architectural anti patterns_for_data_handling

Row AlignmentProblem: Extra rows are created but not used, just in case. Usually they are named as a1, a2, a3, a4 and called padding.

There's good will behind that, specially when version 1 of the software needed an extra column in a 150M lines database and it took 2 days to run an ALTER TABLE. But that's no excuse.

Alternative:

- Quit being cheap. Quit feeling 'hacker' about padding

- Document based databases as MongoDB and CouchDB, has no schema. New atributes are local to the document and can be added easily.

Page 13: Architectural anti patterns_for_data_handling

Extreme JOINsProblem: Business stuff modeled as tables. Table inheritance (Product -> SubProduct_A). To find the complete data for a user plan, one must issue gigantic queries with lots of JOINs.

Alternative:

- Document storage, as MongoDB might help having important information together.

- De-normalization

- Serialized objects

Page 14: Architectural anti patterns_for_data_handling

Your scheme fits in an A3 sheetProblem: Huge data schemes are difficult to manage. Extreme specialization creates tables which converges to key/value model. The normal form get priority over common sense.

Product_A Product_Bid - desc id - desc

Alternatives: - De-normalization- Another scheme ? - Document store for flattening model- Key/Value- See 'Extreme JOINs'

Page 15: Architectural anti patterns_for_data_handling

Your ORM ...Problem: Your ORM issue full queries for dataset iterations, your ORM maps and creates tables which mimics your classes, even the inheritance, and the performance is bad because the queries are huge, etc, etc

Alternative:

- Apart from denormalization and good old common sense, ORMs are trying to bridge two things with distinct impedance.

- There is nothing to relational models which maps cleanly to classes and objects. Not even the basic unit which is the domain(set) of each column. Black Magic ?

Page 16: Architectural anti patterns_for_data_handling

No silver bullet

- Think about data handling and your system architecture

- Think outside the norm

- De-normalize

- Simplify

- Know stuff (Message queues, NoSQL, DHT)

Page 17: Architectural anti patterns_for_data_handling

Cycle of changes - Product A

1. There was the database model2. Then, the cache was needed. Performance was no good.3. Cache key: query, value: resultset4. High or inexistent expiration time [w00t]

(Now there's a turning point. Data didn't need to change often. Denormalization was a given with cache)

5. The cache needs to be warmed or the app wont work.6. Key/Value storage was a natural choice. No data on MySQL anymore.

Page 18: Architectural anti patterns_for_data_handling

Cycle of changes - Product B

1. Postgres DB storing crawler results.2. There was a counter in each row, and updating this counter

caused contention errors.3. Memcache for reads. Performance is better.4. First MongoDB test, no more deadlocks from counter

update.5. Data model was simplified, the entire crawled doc was

stored.

Page 19: Architectural anti patterns_for_data_handling

Stuff to think about

Think if the data you use aren't de-normalized somewhere (cached)

Most of the anti-patterns signals that there are architectural issues instead of only database issues.

The NoSQL route (or at least a partial NoSQL route) may simplify it.

Are you dependent on cache ? Does your application fails when there is no cache ? Does it just slows down ?

Think about the way to put and to get back your data from the database (be it SQL or NoSQL).

Page 20: Architectural anti patterns_for_data_handling

Thanks

http://scienceblogs.com/evolgen/upload/2007/04/rube_back_scratch.gifhttp://en.wikipedia.org/wiki/Rube_Goldberg_machine