Search code examples
asp.netvb.netarchitecturedeployment

A solution for a large-scare ASP.NET application


We have an ASP classic ERP (very large application) that we want to rewrite using ASP.NET.

I am looking for a way to organize the application so we are going to be able to separate every program/webpage (over 400) from each other. Every program needs to be independent because many developers will work on the project at the same time.

Visual Studio seems to make a DLL for every assembly so I was wondering if it’s a good idea to make a huge solution with one project per DLL.

Ex. :

  • Customers.aspx + Customers.aspx.vb (compiled) for presentation
  • Customers.DLL for the object entity
  • CustomersManager.DLL for business logic
  • CustomersData.DLL for data access

This way, we would be able to deploy every program separately without altering the others. We would also have over a thousand DLL to manage…

Does it seem to be a good solution for a large-scale application? Anyone has a better idea?


Solution

  • Source control was invented exactly for the purpose of having multiple develops concurrently work on large solutions. I do appreciate the value of having components that can be deployed independently, but perhaps the value is lost as the number of independent components that require maintenance approaches the hundreds and thousands?

    Separating the application into separate presentation/business logic/DAL DLLs does make sense on a per-module basis, but not usually on a per page basis.

    Consider the different functional areas of your application that are likely to share code and start there (one set of projects for each).