How to design scalable applications? [closed]

夙愿已清 提交于 2019-12-17 17:19:16

问题


How do you design/architect a scalable application? Any suggestion of books or websites that could help to understand how to scale out applications?

Thanks


回答1:


Over the past year I've had to come up to speed on this question for a project my company's working on, and I've found these resources extremely helpful: Todd Hoff's highscalability.com; Scalable Internet Architectures, by Theo Schlossnagle; and Building Scalable Web Sites, by Cal Henderson. Highscalability.com in particular will point you to many good presenations, tutorials, books, and papers, and is a great place to start. All of the advice is practical, and based on experience at sites like Flickr, Twitter, and Google.

BTW, scalability is not performance. A perfectly scalable system is one that has a fixed marginal cost to add additional users or capacity.




回答2:


This is a nice read on livejournal and how they've scaled their application over time.

danga.com/words/2004_mysqlcon/mysql-slides.pdf[PDF]

It might not be the sort of thing you're looking for, but it's one of the better "This is what we did and why" overviews on scaling.




回答3:


  • I tend to think that scalability is closely related to maintainability. And it seems to be often overlooked that people spend only a short time developing applications and the rest of the time maintaining it.

  • Also, scaling has almost certainly to do with data (which is more agile than code - so you like to have more and more of it), thats why your storage access cost should stay between O(1) and O(n).

  • The perfectly scalable application for me is one that I could copy from an environment to another (similar) environment, configure a few values and run it to extend the execution realm of the whole application.




回答4:


There are already some great answers posted here. In some of the books and links you will find a few common thinking patterns.

  • Write as little code as possible

  • Reuse code as much as possible

  • Don't over, or under abstract your design

  • Break things into modular areas that can run on seperate, or multiple systems. Heavy processing should be left to a seperate system.




回答5:


Before you start with technique you should know the application scope dead cold. What does the customer / business unit expect in terms of performance, and what are the critical areas of failure? Scott Hanselman had a great podcast regarding the subject.

Some of tidbits offered: don't use caching unless you have to; serving up files is faster than assembling fragments from a database; know how to handle peek server times; know what your peaks will be.

Again, know the scope of the usage first in order to know if you should scale.




回答6:


Whatever you do you cannot design the system right from the start to be scalable for all your needs. Often once you have your system running you will find bottlenecks where you least expect them (ie: local network bandwidth). Anyway, my advice is definitely highscalability.com as well :)




回答7:


I would suggest this book for that:

http://www.amazon.com/Scalable-Internet-Architectures-Developers-Library/dp/067232699X/ref=sr_1_1?ie=UTF8&s=books&qid=1243267630&sr=8-1

Even though this is primarily a PHP book, the ideas are the same for any web stack.




回答8:


This is exactly what you need! Application Architecture Guide was created by Microsoft Patterns and Practices team to help architects...




回答9:


This is a good intro to the subject: IBM developerWorks had a couple of interesting tutorials about using architecture patterns for applications that scale: here and here.



来源:https://stackoverflow.com/questions/907260/how-to-design-scalable-applications

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!