real world clojure sean corfield world singles

doing boring stuff with an exciting language

clojure is good for? • big data & analytics • logic programming & pattern matching • heavy concurrency & massive scale • hard problems!

clojure is also... • "It endeavors to be a general-purpose

language suitable in those areas where Java is suitable."

• -- http://clojure.org/rationale

world singles • internet dating platform • multi-lingual: half dozen languages • multi-tenant: 50 sites, one code base

clojure & us • needed to process large amounts of data • (irony: one of clojure's touted strengths) • 2009 introduced scala for "heavy lifting" • not a good cultural fit for our team • 2010 started evaluating clojure • 2011 first production usage

introducing clojure • pick small, low-level components • reusable from java / other languages • :gen-class / clojure.lang.RT • logging (tools.logging, log4j) • environment control (dev/ci/qa/prod)

clojure & us • email (html generation & sending) • environment control • geo location • i18n • logging • persistence • search engine interaction (json/xml)

clojure & us • time is short - focus on • persistence • search engine interaction

persistence • crud wrapper around clojure.java.jdbc • (get-by-id :table id) • (find-by-keys f :table {:key val}) • (save-row :table {:id pk ...}) • (execute f "sql statement" [params])

persistence

persistence

persistence • same crud wrapper around congomongo! • (except for "execute") • abstraction allows us to mix'n'match mysql data and mongodb documents

persistence

persistence • generic application code uses mysql or

mongodb transparently based on :table

• (get-by-id :table id) • (find-by-keys f :table {:key val}) • (save-row :table {:id pk ...})

search engine • discovery by transparensee • powerful, fast, fuzzy searching • http post xml searchable data • http post json queries, returns json

search engine • scan database for changed profiles • create xml via hiccup • posted via clj-http • (heavy lifting we introduced scala for)

search engine

search engine

search engine • json created via clojure.data.json • posted via clj-http • result parsed via clojure.data.json

search engine

search engine

search engine

search engine

clojure & us • email (html generation & sending) • environment control • geo location • i18n • logging • persistence • search engine interaction (json/xml)

libraries we use • clojure contrib • data.json, java.jdbc, tools.cli, tools.logging • other clojure • clj-http, clj-time, clojure-csv, congomongo, date-clj, enlive, hiccup

• java • c3p0, log4j, javax.mail, mysql

code stats • 35 src .clj files • 3,435 lines • 19 test .clj files • 746 lines • lein multi test against 1.3.0 & 1.4.0

clojure benefits • performs well • scales well for data complexity • immutable data provides thread safety • maintenance / flexibility is good

clojure & the future • training more of our team • clojure code base is growing • most new backend code will be clojure • looking at cascalog

we're hiring! http://bit.ly/worldsinglesjob

questions? / contact • @seancorfield • [email protected] • http://worldsingles.com • http://corfield.org

sean corfield world singles - GitHub

clojure & us. • email (html generation & sending). • environment control. • geo location. • i18n. • logging. • persistence. • search engine interaction (json/xml) ...

958KB Sizes 3 Downloads 227 Views

Recommend Documents

Men's Singles
Gregory, Elijah. Collins, Charles. Collins. Bye. Ngo, Chih. Van Hoy, Matt. Domanski, Chris. CHAMPION. Hendrix, Lee. Mullis, Kevin. Hursey, David. Lane, Chip.

C++ Seasoning - Sean Parent
2013 Adobe Systems Incorporated. All Rights Reserved. No Raw Loops. 10 ...... Open sourced, runs on Linux and Android. ▫ Intel TBB - many platform. 51 ...

Dungeon World Monster Cards - GitHub
[DW 313, 227]. ADVENTURER. HP: 3. Armor: 1. Intelligent ~ Horde. Sword (d6 damage). Close .... calls of a scout or sentry with a keen ear. A few extra seconds ..... gruesome way, the dark powers of Dungeon World might bring them back to a ...

Punk - Sean Albiez
(Magazine, Joy Division); who self-professedly and cynically used punk to gain record company backing by extending the ... Cult, Danse Society, Specimen, Sex Gang Children).1 Additionally, in-between were a variety of bands who had a large (if not a

IFP_63_Sep15_(singles).pdf
Page 2 of 92. Reasons to choose. SAPPHIRE... ...#2 where safety is a top priority. SAPPHIRE systems are ideal for use in occupied areas. SAPPHIRE uses 3MTM. NovecTM 1230 Fire Protection Fluid which is very low in acute and chronic toxicity. When comp

The Singles Ward.pdf
Retrying... Download. Connect more apps... Try one of the apps below to open or edit this item. The Singles Ward.pdf. The Singles Ward.pdf. Open. Extract.

Jamiroquai: High Times - Singles
high times the singles 1992. Awall Ð ̧Ð1⁄2Ñ„Ð3⁄4Ñ€Ð1⁄4ацÐ ̧Ñ, ÐoÐ3⁄4Ð1⁄2цÐμрты. Ð ̧ бÐ ̧Ð3⁄4Ð3рафÐ ̧Ñ jamiroquai. Page 1 of 3 ...

The World Hitler Never Made - GitHub Pages
(New Studies in European History) having great arrangement in word and layout, so you will not really feel uninterested in reading. PDF File: The World Hitler ...

Reimagining IT for an omnichannel world - GitHub
Figure 1: IT budgets are growing rapidly, and most of the expansion is in new projects. 25%. CAGR. Ratio. 2.4x. Indexed IT hours by project type. Note: Run category includes IT services, maintenance, admin, PMO admin and training time; grow category

dj sean paul.pdf
There was a problem previewing this document. Retrying... Download. Connect more apps... Try one of the apps below to open or edit this item. dj sean paul.pdf.

sean jameson pdf
File: Sean jameson pdf. Download now. Click here if your download doesn't start automatically. Page 1 of 1. sean jameson pdf. sean jameson pdf. Open. Extract.

2017 Singles Player List.pdf
Retrying... Download. Connect more apps... Try one of the apps below to open or edit this item. 2017 Singles Player List.pdf. 2017 Singles Player List.pdf. Open.

Uk Top 40 Singles Chart.pdf
Loading… Page 1. Whoops! There was a problem loading more pages. Uk Top 40 Singles Chart.pdf. Uk Top 40 Singles Chart.pdf. Open. Extract. Open with.

Spring 2016 Singles Waiver.pdf
There was a problem previewing this document. Retrying... Download. Connect more apps... Try one of the apps below to open or edit this item. Spring 2016 Singles Waiver.pdf. Spring 2016 Singles Waiver.pdf. Open. Extract. Open with. Sign In. Main menu

Boys Tennis Singles Strategies.pdf
There was a problem previewing this document. Retrying... Download. Connect more apps... Try one of the apps below to open or edit this item. Boys Tennis ...

1 Supplemen tal Materials - Sean McKenna
Research Methods for Human-Computer Interaction. Cambridge University ... Conference on Human Factors in Computing Systems, pages 17–24. ACM, 2003.

Singles 2: Triple Trouble.pdf
Retrying... Download. Connect more apps... Try one of the apps below to open or edit this item. Singles 2: Triple Trouble.pdf. Singles 2: Triple Trouble.pdf. Open.

Lee-Sean Huang 21 February 2011
Feb 21, 2011 - JETAANY “JET-AH-NEE” - a bold, dynamic, genki brand, embodying the best of Japan, JET, and NYC. The Apple a symbol of New York City as ...

Sean Shiang Whelan Resume.pdf
There was a problem previewing this document. Retrying... Download. Connect more apps... Try one of the apps below to open or edit this item. Sean Shiang ...Missing:

writing about Japanese culture - Lee-Sean Huang
Apr 8, 2002 - http://www.japanvisitor.com/index.php? .... Equally interesting are Shimbo's coverage of the basics from making sushi rice and nabe one-pot ... language and is more than just a cookbook; it is a monument to his culinary skill.

writing about Japanese culture - Lee-Sean Huang
Apr 8, 2002 - ... JapanVisitor.com http://www.japanvisitor.com/index.php? .... language and is more than just a cookbook; it is a monument to his culinary skill.

sean jon go west.pdf
Kardashian memes take over twitter as kanye west announces. Coronation street star sean ward hasauditioned for game of. Jay sean. do you remember ft. sean ...