week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · week 11. title: microsoft...

35
0 Computer Science 50 Introduction to Computer Science I Harvard College David J. Malan [email protected] Week 11

Upload: others

Post on 09-Jun-2020

2 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

0

Computer Science 50Introduction to Computer Science I

Harvard College

David J. [email protected]

Week 11

Page 2: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

1

Life After 50

CS 51: Introduction to Computer Science IITuTh 1 – 2:30, Spring 2009

CS 105: Privacy and TechnologyTuTh 2:30 – 4, Spring 2009

CS 124: Data Structures and AlgorithmsTuTh 11:30 – 1, Spring 2009

CS 171: VisualizationMW 1 – 2:30, Spring 2009

Page 3: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

2

Life After 50

CS 61: Systems Programming and Machine OrganizationTuTh 2:30 – 4, Fall 2009

CS 121: Introduction to Formal Systems and ComputationTuTh 10 – 11:30, Fall 2009

CS 141: Computing HardwareMW 1 – 2:30, Fall 2009

Page 4: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

3

Life After 50

Anthropology 1010: Introduction to ArchaeologyMW(F) 10 – 11, Fall 2009

Dramatic Arts 101: Introduction to TheatreM 1:30 – 3:30, Fall 2009

Government 1540: The American PresidencyTuTh 11:30 – 1, Fall 2009

Page 5: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

4

Domain Names

Page 6: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

5

Top-Level Domains (TLDs)

.biz

.com

.edu

.gov

.info

.int

.mil

.name

.net

.org

.aero

.asia

.cat

.coop

.jobs

.mobi

.museum

.pro

.tel

.travel

.us

...

Page 7: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

6

DNS Records

Image from http://computer.howstuffworks.com/web-server1.htm.

ACNAMEMXNS...

Page 8: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

7

DNS Records

Image from http://computer.howstuffworks.com/web-server1.htm.

Page 9: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

8

DNS Lookups

Image from http://computer.howstuffworks.com/web-server1.htm.

Page 10: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

9

Web Hosting

. . .

Page 11: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

10

Vertical Scaling

CPUcores, L2 Cache, ...

DiskPATA, SATA, SAS, ...RAID

RAM. . .

Page 12: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

11

Horizontal Scaling

Image from singlehop.com.

Page 13: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

12

Horizontal Scaling

Image from singlehop.com.

Page 14: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

13

Virtualization

Xenhttp://www.xen.org/download/

VMwarehttp://www.vmware.com/download/server/[email protected]

Parallels (Virtuozzo)http://www.parallels.com/download/

Virtual PChttp://www.microsoft.com/windows/downloads/virtualpc/

...http://en.wikipedia.org/wiki/Comparison_of_virtual_machines

Page 15: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

14

Cloud Computing

Page 16: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

15

PHP Acceleration

Code OptimizationOpcode Caching. . .

Page 17: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

16

PHP Accelerators

Alternative PHP Cache (APC)http://pecl.php.net/package/APCeAcceleratorhttp://eaccelerator.net/XCachehttp://xcache.lighttpd.net/Zend Platformhttp://www.zend.com/en/products/platform/. . .

Page 18: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

17

Load Balancing at Layer 4

Image from Building Scalable Websites.

Page 19: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

18

Load Balancing with BIND

cnn.com. IN A 157.166.224.25

cnn.com. IN A 157.166.224.26

cnn.com. IN A 157.166.226.25

cnn.com. IN A 157.166.226.26

Page 20: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

19

Load Balancing at Layer 7

Image from Building Scalable Websites.

Page 21: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

20

Sticky Sessions

Layer-7 Load Balancing?Shared Storage?FC, iSCSI, NFS, etc.

Cookies?

Page 22: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

21

Load BalancersSoftware

LVSPerlbalPirhanaPoundUltra Monkey...

HardwareCiscoCitrixF5...

Page 23: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

22

Caching.html

MySQL Query Cachememcached. . .

Page 24: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

23

.html

Page 25: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

24

MySQL Query Cache

query_cache_type = 1

http://dev.mysql.com/doc/refman/5.0/en/query-cache.html

Page 26: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

25

memcached$memcache = memcache_connect(HOST, PORT);

$user = memcache_get($memcache, $id);

if (is_null($user))

{

mysql_connect(HOST, USER, PASS);

mysql_select_db(DB);

$result = mysql_query("SELECT * FROM users WHERE id=$id");

$user = mysql_fetch_object($result, User);

memcache_set($memcache, $user->id, $user);

}

http://www.danga.com/memcached/

http://us2.php.net/memcache

Page 27: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

26

MySQL

Image from High Performance MySQL.

Page 28: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

27

MySQL

Excerpted from http://dev.mysql.com/tech-resources/articles/storage-engine/part_3.html.

Page 29: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

28

Replication: Master-Slave

Excerpted from High Performance MySQL.

Page 30: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

29

Replication: Master-Master

Excerpted from High Performance MySQL.

Page 31: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

30

Load Balancing + Replication

Excerpted from High Performance MySQL.

Page 32: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

31

... + Partitioning

Excerpted from High Performance MySQL.

Page 33: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

32

High Availability

Excerpted from High Performance MySQL.

Page 34: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

33

MySQL Cluster

Excerpted from http://www.mysql.com/news-and-events/on-demand-webinars/cluster-20061116.pdf.

Page 35: Week 11 - cdn.cs50.netcdn.cs50.net/2008/fall/lectures/11/week11.pdf · Week 11. Title: Microsoft PowerPoint - week11.ppt Created Date: 12/1/2008 9:30:40 AM

34

Computer Science 50Introduction to Computer Science I

Harvard College

David J. [email protected]

Week 11