Is Apache Tomcat an Application Server?

posted by avanabs on June 9, 2010 09:22 PM

In a word, Yes. Tomcat is an "Application Server" for certain types of applications, including a large percentage of the applications being developed today. The answer depends, of course, on your definition of “Application Server”. It also depends on whether you think Tomcat is limited to the Apache Tomcat Project, or whether Tomcat also includes all the add-ons and plug-ins that have been made available through open source or commercially.

In any case, I assert that Tomcat is indeed an Application Server, all by itself. Tomcat becomes a much richer Application Server as you modularly (the only sane approach, IMHO) add functionality as required by your specific application.

So, what’s an “Application Server”?

I frequently hear the questions “What’s an application server?, “Is (or isn’t) XYZ an application server?”, and “Do I really need an application server?”. These questions also show up in various internet FAQ’s, blogs, etc. Some of the resulting discussions are almost hilarious, with firmly held beliefs sometimes swamping rational thought and one recent discussion at a major client bordered on open warfare. I too have some opinions, though perhaps not as vehemently held, based on years building applications across many architectures and technologies.

Initially “application servers” were the hardware and operating system for running application code in a two tier environment. The other server was the database server, typically running on another machine. Later on, as web applications evolved, the user interface moved to the client machine, the business logic stayed on the “application server”, and the database remained on its own server. Later yet, Java application servers were introduced which are based on the Java™ 2 Platform, Enterprise Edition (J2EE™). J2EE typically uses a multi-tier distributed model. This model generally includes a Client Tier, a Middle Tier, and a Data Tier. The Client Tier consists of one or more applications and/or browsers. The J2EE Platform is in the Middle Tier and consists of at least a Web Server, Servlet engine, and an EJB lots and lots of other "stuff". (For more information if you need a separate Web Server, see Mark Thomas' article on Myth or truth: One should always use Apache httpd in front of Apache Tomcat to improve performance?) The servers are also called "containers". There can be, and often are, additional sub-tiers in the middle tier, particularly in today's service architectures. The Data Tier has existing applications providing data services and/or databases.

To be clear, application servers are definitely NOT required to build sophisticated applications. In the past, I’ve coded TCP/IP and a FTP-like service directly into an electronic publishing application, for example, and I have re-invented data access/caching too many times over the years. Also, sophisticated frameworks like Spring provide rich JAVA application services, but they do not require a JEE application server to function. All that said, I definitely do not want to have to re-create those services ever again and in my wildest nightmares wouldn’t contemplate developing them from scratch myself. Application servers absolutely do make development easier, and far more productive, when building sophisticated application software. Even extremely powerful frameworks like Spring can benefit from the integrated services that an application server provides, so “Application Servers” will be with us for the foreseeable future.

There are many definitions (a Google search returns almost a million references) for “Application Server” floating around the industry; in all too many cases these are promulgated by vendor marketing departments with the primary objective being the assertion that “we are and they aren’t”. So, what do we think of when we talk about an "Application Server"?

Common Characteristics of an Application Server

  • Fits between the OS (or JVM) layer and the application layer…e.g. it’s “middleware” or a "framework"
  • Provides “services” (sometimes called "components") to the application, eliminating the need for the application developer to create or attempt to integrate and manage these (often complex) services from scratch
  • Services are invoked (implicitly or explicitly ) by the application as needed, rather than being coded into the application
  • Supports multiple applications simultaneously
  • Typically, but not always, includes an administrative/configuration function for managing both the environment and its applications

Thus, an application server is the code (also called a “framework” or a “container”) that sits between the OS and the application and provides a suite of services for the application (except with Microsoft, of course, where services are embedded in the OS and into the IDE’s). An “application server” is not necessarily a “JEE Application Server”, vendor marketing not withstanding, although many people do think they are synonymous.

For our purposes, we are specifically focusing on the world of JAVA, although the most widely used “application server” in the world is arguably Microsoft Windows, which provides many application services beyond the typical OS, coupled with any of the Microsoft Visual IDE’s. The big boys in the JAVA/JEE server space were BEA (now gone…sigh, acquired by Oracle), IBM, Oracle, SUN (also now gone, acquired by Oracle), and more recently jBoss (acquired by RedHat), Geronimo, and the like. The other big boy in JAVA applications servers, at least for the foreseeable future, is Tomcat, which offers many technological and business advantages over the commercial JEE Application Servers, as well as having some limitations.

How Much Application Server is Enough?

Today’s commercial JEE servers provide massive functional overkill for most applications, leading to needless cost and complexity. This is because the JEE application server vendors (and indeed the JEE specification itself) were being driven over a period of years by the best/most demanding customers to provide products that did absolutely everything for everybody. Commercial application servers also vary considerably in the range and quality of the services they offer to the IT function, a portion of which of which are based on “standards” (JEE, CORBA, etc).

These application servers are highly sophisticated, feature rich, and very expensive/complex. Additionally, much of the functionality in these products is outside of the JEE specifications, thus making each of them proprietary to some degree and particularly so in the areas of administration. Other JEE application servers, such as jBoss, SUN, and Geronimo, also meet the minimum of the JEE standard, but provide a much less broad suite of application services and some are notably lacking in operations/management tooling.

JEE Application Servers are widely used (some studies show over 80-90%) for the development of web and web services applications. In these, the application server’s services act as a set of components accessible to the software developer through an API. The services/components are usually executed in the same machine where the web server is running, and their main job is to support the construction of dynamic pages and deliver rich GUI, although increasingly service oriented architectures are being utilized to partition the business logic across multiple instances of lighter weight servers, frequently isolating web page creation from the underlying business logic.

Without doubt, the most widely utilized Java application server is Apache Tomcat (yes, Tomcat is an “application server”), which for many years was the reference implementation of the Java servlet specification, till SUN pulled it back. While Tomcat doesn’t offer all of the services of a commercial JEE Application Server, it includes the most commonly used services and it supports “plug-ins” and “add-ons” to enable enhancing Tomcat with specific services required by your application. The benefit of Tomcat’s architecture is that you use what you need, and leave out what you don’t. jBoss also was a lean and mean architecture originally, with the ability to leave out what you didn’t want, but sadly under RedHat it’s adopted the “mega-blob” approach of the other JEE vendors and it has become increasingly difficult to separate services from the blob.

The Apache Tomcat community continues to develop and support Tomcat, with regular releases that add sophisticated functionality, and improve security/stability, while maintaining 100% standard compliance and high reliability/performance. The Tomcat community has done a very good job of maintaining the focus, thus far avoiding the tendency to create a “mega-blob” application server like the commercial vendors did. It will be interesting to see what happens to Tomcat as multiple vendors start to create and deliver commercialized versions of Tomcat. Hopefully the community will retain their focus…they have done a good job so far, even while Tomcat became embedded in many commercial products, including several JEE Application Servers.

So, what are the quick answers to the FAQ I posed earlier?

What’s an Application Server? An Application Server provides services and infrastructure for developing, deploying, and running applications. There are many different application servers available today and, with sophisticated application frameworks, the line between the IDE and the Application Server is blurring. JEE servers are still widely used, while Tomcat and various JAVA frameworks are being adopted for many (most!) new applications and architectures.

Isn’t Tomcat an Application Server? Yes, it is, and many of today’s applications (and virtually all “web services”) can be built on top of Tomcat with pluggable services and add-ons. Aside from administration, Tomcat is often a much better choice, both technically and for TCO, to build today’s development and deployment architectures than yesterday’s “mega-blob” JEE servers. By adding administrative services, available from vendors like VMware (Spring), MuleSoft, etc, IT operations requirements can also be met…sometimes better than by the JEE vendors.

Do I really need an application server? No you don’t, but you almost certainly want one unless you are programming for a “device” (router, cell phone, PDA, etc) or you have a professional death wish. This is because most of today’s applications need a range of services and it’s very very costly and very very time consuming to re-invent these services each time. The more important question should be “which Application Server best meets the requirements of my application?”

In many (perhaps most) situations, the answer is likely to be Tomcat ++, where the ++ is some combination of the required plug-in/add-on services and a commercial management framework. You can do without, and/or do it yourself, but the advantages of leveraging sophisticated components which are available at bargain costs generally outweigh other considerations.

Author's note: As readers of my blogs already know, I’m NOT a big fan of the major commercial JEE Application Servers for most applications, even after using (and developing one of) them for many years. I believe that both JEE and JEE Application Servers started out as a wonderful vision, but lost their way as they evolved into mega-blobs that try to do everything for everybody. So, take this post with a grain of salt, depending on your particular prejudices and/or situation.

Andy has recently decided to make the jump from individual consulting to join the Spring Source team. He will continue to be working with major clients to assist them with IT architecture evolution, now as a member of a large and growing organization. His first project will be leveraging Tomcat, Spring, and a Tomcat based data grid/cache called GemFire. He’s looking forward to sharing the lessons learned with the tomcatexpert community. Andy has been architecting, designing, and building enterprise infrastructure and applications software for most of his career. He’s been responsible for BEA’s “Blended Source” initiative, combining the best of Open Source (including both Tomcat and Spring) with WebLogic, BEA’s WebLogic Enterprise Security product family, MEI Software’s financial systems, Netegrity’s SiteMinder security product, Camex’s electronic publishing systems, mainframe applications for Bell Telephone, and many others. During that time his hands on technology experience has ranged from octal coding into neon lighted switches all the way through JAVA and beyond, including many generations of “the best and final thing we will ever need”, and he looks forward to working on the even better things coming in the future. He was involved in the early days of Open Source software as a contributor to EMACS and refocused on Open Source during his tenure as Director of Product Management with BEA Systems, combined with a fascination for the rapidly evolving application deployment architectures and technologies driving today’s development. Andy has provided architecture and technology guidance for both vendors and IT organizations and he shares what he is learning through consulting services and through his web site, Enterprise Software Trends (


Nice one!

This kind of post is always good to read, to clarify ours thoughts about App Servers.

I had this kind of discussion in my office, at take ours to us to get in a conclusion. Windows App Server, as Microsoft called, is always in ours discussion if IIS is an App Server or "IIS + COM" is the App Server or if only the hole Windows Server is the App Server.

Congrats for your post,

Willian Leite

Willian Leite



Thank you very much for writing such an interesting article on this topic. This has really made me think and I hope to read more.
top health blogs


You have a good point here!I totally agree with what you have said!!Thanks for sharing your views...hope more people will read this article!!!


The information you have posted is very useful. The sites you have referred was good. Thanks for sharing...
how to improve website ranking


I found this is an informative and interesting post so i think so it is very useful and knowledgeable. I would like to thank you for the efforts you have made in writing this article.
Dissertation Topics


This article gives the light in which we can observe the reality. This is very nice one and gives indepth information. Thanks for this nice article.
online marketing company


Thank you for such a well written article. It’s full of insightful information and entertaining descriptions. Your point of view is the best among many.
Packaging Supplies


I have recently started a blog, the info you provide on this site has helped me greatly. Thanks for all of your time & work.
buy instagram likes

Thanks for the nice blog. It

Thanks for the nice blog. It was very useful for me. I'm happy I found this blog. Thank you for sharing with us,I too always learn something new from your post.
Manufactured Home Lenders

Positive site, where did u

Positive site, where did u come up with the information on this posting? I'm pleased I discovered it though, ill be checking back soon to find out what additional posts you include.
Buy Followers on Twitter

Thanks for the nice blog. It

Thanks for the nice blog. It was very useful for me. I'm happy I found this blog. Thank you for sharing with us,I too always learn something new from your post.
pheromone perfume


I just found this blog and have high hopes for it to continue. Keep up the great work, its hard to find good ones. I have added to my favorites. Thank You.
trust flow backlinks

I was looking at some of your

I was looking at some of your posts on this website and I conceive this web site is really instructive! Keep putting up..
miami seo

Thanks for this great post, i

Thanks for this great post, i find it very interesting and very well thought out and put together. I look forward to reading your work in the future.


Great post I would like to thank you for the efforts you have made in writing this interesting and knowledgeable article.

Keep up the good work , I

Keep up the good work , I read few posts on this web site and I conceive that your blog is very interesting and has sets of fantastic information.

I have been checking out a

I have been checking out a few of your stories and i can state pretty good stuff. I will definitely bookmark your blog
coaching leadership

I am glad you take pride in

I am glad you take pride in what you write. winder This makes you stand way out from many other writers that push poorly written content.

Great Article it its really

Great Article it its really informative and innovative keep us posted with new updates. its was really valuable. thanks a lot.
company website

This is a great inspiring

This is a great inspiring article.I am pretty much pleased with your good work.You put really very helpful information...
hoverboard cheap online

It is imperative that we read

It is imperative that we read blog post very carefully. I am already done it and find that this post is really amazing.
find out more here

Very interesting blog. Alot

Very interesting blog. Alot of blogs I see these days don't really provide anything that I'm interested in, but I'm most definately interested in this one. Just thought that I would post and let you know.

hello!! Very interesting

hello!! Very interesting discussion glad that I came across such informative post. Keep up the good work friend. Glad to be part of your net community.

Your work is very good and I

Your work is very good and I appreciate you and hopping for some more informative posts. Thank you for sharing great information to us.
mortgage calculator with pmi

Its a great pleasure reading

Its a great pleasure reading your post.Its full of information I am looking for and I love to post a comment that "The content of your post is awesome" Great work.
nyc flowers

I really like your writing

I really like your writing style, great information, thankyou for posting.
quinoa online india


Good article, but it would be better if in future you can share more about this subject. Keep posting.
Mikes Foreign Car Repair Kendall Park NJ

Nice post! This is a very

Nice post! This is a very nice blog that I will definitively come back to more times this year! Thanks for informative post.
Copy Buffett


Your work is very good and I appreciate you and hopping for some more informative posts. Thank you for sharing great information to us.
naltrexone implants clinics los angeles

Great post, you have pointed

Great post, you have pointed out some excellent points, I as well believe this is a very superb website.
Movers in Calgary

I appreciate everything you

I appreciate everything you have added to my knowledge base.Admiring the time and effort you put into your blog and detailed information you offer.Thanks.
nyc flowers

Thanks for a wonderful share.

Thanks for a wonderful share. Your article has proved your hard work and experience you have got in this field. Brilliant .i love it reading.
jockstrap for sale


Thanks for sharing the post.. parents are worlds best person in each lives of individual..they need or must succeed to sustain needs of the family.
Text The Romance Back Review

I went over this website

I went over this website discover Kccatl and I believe you have a lot of wonderful information, saved to my bookmarks


i am for the first time here. I found this board and I in finding It truly helpful & it helped me out a lot. I hope to present something back and help others such as you helped me.
Bruidsfotografie Kasteel


I am happy to find your distinguished way of writing the post. Now you make it easy for me to understand and implement the concept. Thank you for the post.
drug and alcohol rehab florida


Great Information sharing .. I am very happy to read this article .. thanks for giving us go through info.Fantastic nice. I appreciate this post.
cogniflex pill review


This article gives the light in which we can observe the reality. This is very nice one and gives indepth information. Thanks for this nice article.
fire and water damage cleanup services


Nice post! This is a very nice blog that I will definitively come back to more times this year! Thanks for informative post.
the best dallas seo company


This article gives the light in which we can observe the reality. This is very nice one and gives indepth information. Thanks for this nice article.
Window Repair Glendale


This is a great inspiring article.I am pretty much pleased with your good work.You put really very helpful information. Keep it up. Keep blogging. Looking to reading your next post.
hgh sale


Excellent article. Very interesting to read. I really love to read such a nice article. Thanks! keep rocking.
Vape Milk e Juice


You have a good point here!I totally agree with what you have said!!Thanks for sharing your views...hope more people will read this article!!!
ferjetur langs norge


I found your this post while searching for information about blog-related research ... It's a good post .. keep posting and updating information.
top article


Pretty nice post. I just stumbled upon your weblog and wanted to say that I have really enjoyed browsing your blog posts. After all I’ll be subscribing to your feed and I hope you write again soon!
voyance gratuite en ligne


Very good points you wrote here..Great stuff...I think you've made some truly interesting points.Keep up the good work.
Calgary Movers


I have read your blog it is very helpful for me. I want to say thanks to you. I have bookmark your site for future updates.
luxura linen

jboss bloated?

JBoss is not bloated, there are three versions of the appserver starting from the shrink-wrapped one called JBoss Web Server, and building up the more complex Web Platform and Application Platform.


Komposisinya adalah buah-buahan dari hutan Amazon, di Amerika Selatan yang dikombinasikan dengan manggis, ratu buah asal Indonesia yang juga memiliki kandungan super antioksidan tinggi, juga ada buah Zaitun yang kaya akan zat Hydroxytyrosol.

Karena amazon Obat Herbal Asam Urat Alamiah mempunyai dampak yang aman untuk kesehatan serta tidak menyebabkan efek negatif. Pada umumnya banyak pasien yang memakai pengobatan sakit asam urat dengan obat barat. Tetapi, tak jarang pengobatan modern justru memiliki efek negatif yang misalkan masalah pada lambung. Oleh dari itu, tidak ada salahnya bila kita menggunakan amazon Obat Herbal Asam Urat Alami. obat asam urat paling manjur

Akan tetapi tidak serupa penyakit kanker payudara yang lain, jenis penyakit menunjukkan ada benjolan. Tanda-tanda berawal yang ditunjukkan sejenis radang seperti bekas gigitan serangga.Kanker ini termasuk dalam jenis yang berbahaya. obat kanker payudara paling ampuh

GlassFish offers a great balance

GlassFish 3 and Java EE 6 deliver good balance as a lightweight offering with production manageability - all in open source. Start with the 29MB Web Profile download (or download just the kernel), and add the (OSGi) modules you need to deliver on application functionality. Only the modules required to service running applications are actually started, which is why GlassFish 3 starts in seconds. The nice thing about the combination of GlassFish and Java EE 6 is that there is less reason to go out to a multitude of third party frameworks - and the multitude of vendors that support them - because the Java EE platform is inherently feature rich.

Post new comment

This question is for testing whether you are a human visitor and to prevent automated spam submissions.