| Andrew Cooke | Contents | Latest | RSS | Twitter | Previous | Next


Welcome to my blog, which was once a mailing list of the same name and is still generated by mail. Please reply via the "comment" links.

Always interested in offers/projects/new ideas. Eclectic experience in fields like: numerical computing; Python web; Java enterprise; functional languages; GPGPU; SQL databases; etc. Based in Santiago, Chile; telecommute worldwide. CV; email.

Personal Projects

Lepl parser for Python.

Colorless Green.

Photography around Santiago.

SVG experiment.

Professional Portfolio

Calibration of seismometers.

Data access via web services.

Cache rewrite.

Extending OpenSSH.

C-ORM: docs, API.

Last 100 entries

Small Success With Go!; Re: Quick message - This link is broken; Adding Reverb To The Echo Chamber; Sox Audio Tools; Would This Have Been OK?; Honesty only important economically before institutions develop; Stegangraphy via PS4; OpenCL Mess; More Book Recommendations; Good Explanation of Difference Between Majority + Minority; Musical Chairs - Who's The Privileged White Guy; I can see straight men watching this conversation and laffing; When it's Actually a Source of Indignation and Disgust; Meta Thread Defending POC Causes POC To Close Account; Indigenous People Of Chile; Curry Recipe; Interesting Link On Marginality; A Nuclear Launch Ordered, 1962; More Book Recs (Better Person); It's Nuanced, And I Tried, So Back Off; Marx; The Negative Of Positive; Jenny Holzer Rocks; Huge Article on Cultural Evolution and More; "Ignoring language theory"; Negative Finger Counting; Week 12; Communication Via Telecomm Bids; Finding Suspects Via Relatives' DNA From Non-Crime Databases; Statistics and Information Theory; Ice OK in USA; On The Other Hand; (Current Understanding Of) Chilean Taxes / Contributions; M John Harrison; Playing Games on a Cloud GPU; China Gamifies Real Life; Can't Help Thinking It's Thoughtcrime; Mefi Quotes; Spray Painting Bike Frame; Weeks 10 + 11; Change: No Longer Possible To Merge Metadata; Books on Old Age; Health Tree Maps; MRA - Men's Rights Activists; Writing Good C++14; Risk Assessment - Fukushima; The Future of Advertising and Surveillance; Travelling With Betaferon; I think I know what I dislike so much about Metafilter; Weeks 8 + 9; More; Pastamore - Bad Italian in Vitacura; History Books; Iraq + The (UK) Governing Elite; Answering Some Hard Questions; Pinochet: The Dictator's Shadow; An Outsider's Guide To Julia Packages; Nobody gives a shit; Lepton Decay Irregularity; An Easier Way; Julia's BinDeps (aka How To Install Cairo); Good Example Of Good Police Work (And Anonymity Being Hard); Best Santiago Burgers; Also; Michael Emmerich (Vibrator Translator) Interview (Japanese Books); Clarice Lispector (Brazillian Writer); Books On Evolution; Looks like Ara (Modular Phone) is dead; Index - Translations From Chile; More Emotion in Chilean Wines; Week 7; Aeon Magazine (Science-ish); QM, Deutsch, Constructor Theory; Interesting Talk Transcripts; Interesting Suggestion Of Election Fraud; "Hard" Books; Articles or Papers on depolarizing the US; Textbook for "QM as complex probabilities"; SFO Get Libor Trader (14 years); Why Are There Still So Many Jobs?; Navier Stokes Incomplete; More on Benford; FBI Claimed Vandalism; Architectural Tessellation; Also: Go, Blake's 7; Delusions of Gender (book); Crypto AG DID work with NSA / GCHQ; UNUMS (Universal Number Format); MOOCs (Massive Open Online Courses); Interesting Looking Game; Euler's Theorem for Polynomials; Weeks 3-6; Reddit Comment; Differential Cryptanalysis For Dummies; Japanese Graphic Design; Books To Be Re-Read; And Today I Learned Bugs Need Clear Examples; Factoring a 67 bit prime in your head; Islamic Geometric Art; Useful Julia Backtraces from Tasks; Nothing, however, is lost with less discomfort than that which, when lost, cannot be missed

© 2006-2015 Andrew Cooke (site) / post authors (content).

Cloud Computing

From: andrew@...

Date: Fri, 9 Jul 2010 18:13:57 -0400

This is a short summary of Cloud Computing and various related ("trendy")

The driving force for much of these ideas seems to have come from Amazon and
Google as they have dealt with scaling their businesses (it's strange how much
Amazon is involved in this, rather than Microsoft, for example). The simple
idea behind Cloud Computing is that computers, and the basic functionality
they provide, are becoming "comoditized". The usual comparison is with an
Electric Company, that supplies electricity. Just as you don't care exactly
what generator is used, so you shouldn't need to care what hardware is used to
run your software.

There are two main approaches to this, one taken by Amazon, and the other by

Amazon's approach is "Infrastructure as a Service" (Amazon Web Services,
AWS). By that, they mean that they provide basic infrastructure as the
"commodity". So you can configure a "machine" and then run N instances, where
N varies depending on the current load. Similarly, you can access "databases"
and "permanent stores". So this is very like "normal" computing, except that
you have services that are "elastic" - they scale as required, typically by
adding instances.

Google's approach is "Platform as a Service". By that, they mean that they
offer a set of APIs that you can use to write a webservice, and then they will
run that service for you, scaling as necessary. So you work at a higher level
of abstraction: you write code that handles a single thread; Google will make
sure that as many threads as necessary run. For data storage, you save data to
a kind-of database (more like a hash table) and you don't care about the lower
level details.

So Google's "App Engine" approach is easier to use (although you need to learn
a whole new API in either Python or Java), but more limiting. In very simple
terms, Amazon's approach is like owning an expandable set of virtual machines
while Google's approach is more like having an infinitely powerful single
machine. One cool detail about Google's approach is that, for small services,
it's free.

And of course there are many more providers, generally doing things like
Amazon (partly because no-one apart from Google is big enough that it's worth
learning a new API just to use their service).

Now, tangentially related to that, are the spin-off technologies. Two are
particularly important, and are related: MapReduce and NoSQL.

To understand both, and how they are related, it's probably easiest to start
with Google. As you can imagine, Google's web search is a huge database spread
across many machines. And to run a search they need to run tasks on each
machine and then collect the results. This process is called MapReduce: "map"
is related to dividing the work out, doing the same thing on various machines;
"reduce" is the process of collecting the results together.

Now MapReduce doesn't make much sense without data. So the flip side of
MapReduce is the distributed data. And that implies some kind of distributed
database. It turns out that databases can do 2 out of 3 things well, where the
3 things are: availability; consistency; partitions. SQL databases are "AC",
but aren't so good at P. Spreading data across various machines requires
partitioning (P), so new technologies have appeared that are either "AP"
(don't always give consistent results) or "CP" (are not guaranteed
available). These tend not to use SQL and are collectively called "NoSQL".

Curiously, Google, who invented MapReduce, don't actually let the public use
it. However, Amazon do support it as a service, and there are many 3rd party
solutions that you can also run yourself (most famously, CouchDB, MongoDB,
HBase and Cassandra). All of these support MapReduce implementations. And
Google's App Engine (its PaaS - see above) does have support for something
similar, but it's not the same MapReduce that Google use internally. 


More on CAP

From: andrew cooke <andrew@...>

Date: Mon, 12 Jul 2010 05:23:39 -0400

This clarifies CAP -


Comment on this post