Tomcat Manager Application and HTTP 404 Error
Solution 1
I had the same situation wherein tomcat manager did not start. I found this exception in my logs/manager.DDD-MM-YY.log:
org.apache.catalina.core.StandardContext filterStart
SEVERE: Exception starting filter CSRF
java.lang.ClassNotFoundException: org.apache.catalina.filters.CsrfPreventionFilter
at java.net.URLClassLoader$1.run(URLClassLoader.java:202)
...
This exception was raised because I had used a version of tomcat that didn't have the CSRF prevention filter.
Tomcat 6.0.24 doesn't have the CSRF prevention filter in it. The first version that has it is the 6.0.30 version (at least according to the changelog).
As a result, Tomcat Manager was incompatible with version of Tomcat that I used. I've found this description of this issue.
Steps to fix it:
- Check version of tomcat installed by running "sh version.sh" from your tomcat/bin directory
- Download corresponding version of tomcat
- Stop tomcat
- Remove your webapps/manager directory and copy manager application from distributive that you've downloaded.
- Start tomcat
Now you should be able to access tomcat manager.
Solution 2
404 meaning is you don't have file to access. I installed tomcat 7 on Amazon EC2 and received 404 message. The default didn't ship with manager package and docs.
sudo yum install tomcat6-webapps tomcat6-docs-webapp tomcat6-admin-webapps
Solution 3
Access directly /manager/html
instead. Worked for me.
Related videos on Youtube
David
I'm a UNIX and Linux System Administrator, mostly specializing in Linux and HP-UX and Solaris, but also familiar with OpenVMS. I've worked with Debian, Ubuntu, Red Hat, Fedora, FreeBSD, and OpenBSD on multiple platforms including Mac PowerPC, HP-9000, and Intel.
Updated on September 18, 2022Comments
-
David almost 2 years
I am trying to set up the admin application for a Tomcat 6.0.24 instance. None of the searches I've done turn up anything I can use. I am using this configuration for Apache 2.2.14:
Alias /manager /usr/share/tomcat6-admin/manager <Directory "/usr/share/tomcat6-admin/manager"> Options Indexes FollowSymLinks AllowOverride None allow from all </Directory> ProxyPass /manager ajp://localhost:8009/manager
In the tomcat-users.xml I have this:
<tomcat-users> <role rolename="tomcat"/> <role rolename="admin"/> <role rolename="operator"/> <role rolename="manager"/> <user username="admin" password="nopasswordforyou" roles="admin,tomcat,manager"/> <user username="operator" password="nevermind" roles="operator"/> </tomcat-users>
I found the docs that suggested I needed
manager-gui
role installed and defined, but that appears to be Tomcat 7, not Tomcat 6.The manager.xml is the default provided with Ubuntu Lucid Lynx 10.04:
<Context path="/manager" docBase="/usr/share/tomcat6-admin/manager" antiResourceLocking="false" privileged="true" />
If I access
/manager
from a web browser, I get a 404 error from Tomcat: "requested resource not available." If I access/manager/images
I get the same thing. If I access/manager/401.jsp
I get the actual page.In addition, the server.xml has not only the usual Realm (
UserDatabaseRealm
) but also one for MySQL authentication (JDBCRealm
). Investigating this showed that the role ofmanager
was not present there for the useradmin
; I fixed that by doing:INSERT USER_ROLE_DB SET USER_NAME='admin', ROLE_NAME='manager';
I restarted Tomcat, although I suspect that was overkill. No change. I don't see any errors in catalina.out or in localhost.* log files.
What am I missing? What is the interaction between the different realms? How do I get the manager application working?