scaling drupal @ imoney - drupalcamp singapore 2014

75
Scaling Drupal @ iMoney Edmund Kwok - CTO P/S We’re hiring!!

Upload: imoneytech

Post on 06-Jul-2015

121 views

Category:

Technology


6 download

DESCRIPTION

How we use Drupal @ iMoney, the challenges we face as we scaled to 6 different countries, and the learnings along the way.

TRANSCRIPT

Page 1: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Scaling Drupal @ iMoneyEdmund Kwok - CTO

P/S We’re

hiring!!

Page 2: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

About me..• Started off as Freelance Drupal Site Builder /

Developer / Themer, first dabbled in Drupal 4.7

• Full time as iMoney CTO, Employee #2 in January 2013

• Email: [email protected]

• D.O.: https://drupal.org/user/44079

Page 3: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Started in Malaysia, to make online applications a reality

Page 4: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 5: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 6: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 7: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 8: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 9: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 10: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 11: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 12: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 13: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 14: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 15: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 16: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 17: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 18: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Product Marketing

Tech

Page 19: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Product Marketing

Tech3+

Drupal Devs

Page 20: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 21: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 22: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 23: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 24: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 25: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 26: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Native mobile app

Page 27: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Code Infrastructure

Process / People

Page 28: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Code

!Infrastructure

!Process /

People

1. Shared code base 2. Think components

3. Automate ^ 3 4. Cache it like it’s hot

5. Empower others 6. Go lean

Page 29: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

1. Shared codebase

Page 30: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

sites/defaultBase theme

Country theme

Country modules

Content

Common modules

Product page theme

sites/www.my sites/www.sg sites/www.ph sites/www.id sites/www.thiMoney

Webapp repo

Database

iMoney Shared Code base Drupal Multisite

Page 31: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

2. Think components

Page 32: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 33: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 34: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 35: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Desktop Mobile

Page 36: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Insights CRM

Insights DB

Publishers

Mobile App

Call Operators

Mortgage Consultants

Webapp

Analytics

Mortgage Admin

Management

Leads DB

Emails API

Leads Collector

Page 37: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Insights CRM

Publishers

Mobile App

Webapp

Call Operators

Mortgage Consultants

Analytics

Mortgage Admin

Management

Leads DB

Page 38: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

3. Automate ^ 3

Page 39: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 40: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Okay, I will instruct Behat to run these tests and

format the results nicely for you.

Page 41: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Okay, I will instruct Behat to run these tests and

format the results nicely for you.

&

Page 42: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Okay, I will instruct Behat to run these tests and

format the results nicely for you.

&

Page 43: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 44: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 45: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 46: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Okay, I will do the following:

1. Pull the latest code from repo

2. Gzip the files 3. SSH into the staging

server 4. Backup the DB with drush 5. Backup the existing

staging root directory 6. Deploy to staging root

Page 47: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Okay, I will do the following:

1. Pull the latest code from repo

2. Gzip the files 3. SSH into the staging

server 4. Backup the DB with drush 5. Backup the existing

staging root directory 6. Deploy to staging root

Whatever he said

Page 48: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Okay, I will do the following:

1. Pull the latest code from repo

2. Gzip the files 3. SSH into the staging

server 4. Backup the DB with drush 5. Backup the existing

staging root directory 6. Deploy to staging root

Whatever he said

Page 49: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 50: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

4. Cache it like it’s hot

Page 51: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Drupal Cache

APC

Boost

nginxPagespeed

Varnish

Page 52: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Varnish rp1

nginxweb1

nginx web2

MySQL db1

IT’S TIME..

FOR A NEW HOUSE

Why?

Page 53: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Varnish rp1

nginxweb1

nginx web2

MySQL db1

nginx web3

nginx web..

Page 54: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Varnish rp1

nginxweb1

nginx web2

MySQL db1

nginx web3

nginx web4

Varnish rp2

HAProxy lb1

MySQL db2

Replication

Page 55: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Drupal Cache APC Boost nginx Pagespeed

“Eh I can’t see the page live”“Did you clear the Boost cache”

“Yeaaa, I did!”“ Hmm, maybe it’s the APC Cache”

“Cleared that too!”“Okay, try clearing Drupal Cache, then APC,

Boost, then Varnish. Oh and nginx Pagespeed!”

“WTFOMGBBQ!@#$”

Varnish

Page 56: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Drupal Cache APC Boost nginx Pagespeed

“Eh I can’t see the page live”“Did you clear the Boost cache”

“Yeaaa, I did!”“ Hmm, maybe it’s the APC Cache”

“Cleared that too!”“Okay, try clearing Drupal Cache, then APC,

Boost, then Varnish. Oh and nginx Pagespeed!”

“WTFOMGBBQ!@#$”

Varnish

Page 57: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 58: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

At least we haven’t flush Varnish’s cache ;)

Page 59: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

5. Empower others

Page 60: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 61: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 62: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 63: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

https://github.com/edmundkwok/varnish-inspector

Page 64: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

The less time you spend maintaining existing features or content, the more time you will have

to build newer, cooler, stuff

Page 65: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

6. Go Lean

Page 66: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 67: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Code

!Infrastructure

!Process /

People

1. Shared code base 2. Think components

3. Automate ^ 3 4. Cache it like it’s hot

5. Empower others 6. Go lean

Page 68: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 69: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Join us!! :DSenior Drupal

Developer • Engineer solutions for pain

points, build cool stuff

• Continuous learning and growth - get off the Drupal island! AngularJS, Symfony2, Node.JS, Python?

• Make the world a better place

Page 70: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Join us!! :DSenior Drupal

Developer • Engineer solutions for pain

points, build cool stuff

• Continuous learning and growth - get off the Drupal island! AngularJS, Symfony2, Node.JS, Python?

• Make the world a better place

Page 71: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 72: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014
Page 73: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

http://im.my/hiremelah (We want to confirm someone by tonight!)

Page 74: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

–Steve Jobs

“A lot of times, people don’t know what they want until you show it

to them.”

Page 75: Scaling Drupal @ iMoney - DrupalCamp Singapore 2014

Email: [email protected]

Thank you! Questions? :)

http://im.my/hiremelah