|
From: Joe Pluta <joepluta@PlutaBrothers.com> > I was going to let this slide, but Leif, you're just not being accurate. > The benefit of a server over a monolithic program is in the fact that, when > servicing multiple clients, a server job stays resident and a monolithic > program does not, because it runs in the same job as the client. I am NOT > talking about calling the same program over and over from the same job, but > the concept of multiple client jobs executing the same business logic. By > definition, a monolithic program must go through initialization (such as > opening files, and so on) when it is called. This initialization is > repeated for every client. Such initialization is not repeated for the > server when it processes multiple client requests. QED, the server is more > efficient. > The initialization is usually a minor part of the application and the time lost in a monolithic program to do this is often offset by the communication overhead in a C/S approach. By the virtue of being monolithic, a traditional application will initialize only once for a given user, who then may work for hours on end with the application. The communication cost is borne throughout the use of the application. What I'm saying is that the cost of initialization versus communication is application and usage dependent and thus not inherently a C/S versus monolithic issue. No QED here, the more accurate characterization is : "it depends". > If the initialization overhead is larger > than the overhead of the messaging API, the server design is more efficient > than a non-server design. and if it is smaller, then it is the other way around. Again: "it all depends". > Nope. Won't remove more, but I'll remove the capitalization. It depends on > the server design as to how efficient it is, but if you apply even basic > server design philosophies, you can usually make a server more efficient > than multiple client calls. > "usually ... more" is better than the uncategorical "more" you had before. ------- When you have the same server servicing multiple clients queuing theory becomes important. The worst you can do is to have a single- server queue. You can counter this with having multiple servers (maybe with dynamic creation and destruction as needed), but that adds complication (maybe only once as you may be able to reuse the code), but there is also operational complexity (locking, deadlocks, error handling, etc) that come into play. Again, it is not ALWAYS true that C/S is more efficient than Monolithic, it depends. But efficiency is not so important in face of all the other benefits from C/S. I would recommend a C/S solution regardless.
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.