How would you design a hosted web application? I'm looking at applications like Basecamp, Campaign Monitor, Freshbooks, etc... where users can sign up online and the application is hosted for them.
- Would you use 1 big database to store all your customer's data or would you handle data differently? Would you use more than 1 database? Would you make a database for each customer?
- Would you duplicate your code base for each signup/customer or would you use 1 codebase to handle all customers?
- Are there other design elements I should think about?
- Any web sites or books out there that talk about this?
Edit: I found an MSDN article that discussed multi-tenant Data Architecture: http://msdn.microsoft.com/en-us/library/aa479086.aspx#mlttntda_topic4
Refer to 37signals -- they are experts in this field and have a lot of articles where they answer community questions (many like yours should come up).
High Scalability = 37signals Architecture
Ask 37signals: How do you process credit cards?
In regards to number of databases, from David Heinemeier Hansson in What do you want to know?