缺少JRE导致的404错误

简介:

初学web开发,今天安装了一个tomcat,运行正常,但访问的时候显示空白页,并在日志

localhost_access_log.xxxx-xx-xx.txt中出现类似错误:

192.168.1.100 - - [15/Apr/2016:19:48:58 +0800] "GET /examples/index.html HTTP/1.1" 200 1253


baidu了几个小时也没解决问题,最后打开安装包中的运行说明(RUNNING.txt),重新下载jre并安装,才解决该问题.

之前安装的jre实际上是针对普通用户的,可以提供运行环境,但没有开发环境,因此如果打开这个jre目录只能发现bin和lib2个子目录.


如果使用yum查看: yum list | grep java

java-1.7.0-openjdk-1.7.0.85-2.6.1.3.el6_7.x86_64 

这是jdk的开发包,它里面包含一个jre,但这个jre不能用于开发,否则会出现上面的错误.


下面附上一个tomcat7的安装说明

这里以apache-tomcat-7.0.68.tar.gz为例

可以从这里下载tomcat7

这里tomcat7的官方文档.

下载之后解压,有一个RUNNING.txt目录,这里给出了安装说明:

一,运行环境

下载JDK  Java Development Kit (JDK)并安装

JRE 必须是6及以后版本.jre下载

注意,这里安装的jre是单独的安装包,不能是JDK携带的那个,如果不安装单独的jre安装包,虽然可以启动tomcat,浏览器访问的时候出现空白页,并且会在

localhost_access_log.xxxx-xx-xx.txt文件中出现类似于下面的错误:

192.168.1.181 - - [15/Apr/2016:16:41:17 +0800] "GET /sample/index.html HTTP/1.1" 404 -


二,安装tomcat.

这里下载的tomcat是apache-tomcat-7.0.68.tar.gz.

解压到/usr/local/apache-tomcat-7.0.68下


三,设置环境变量

假如安装的jre是jre-8u77-linux-x64.rpm,安装到了/usr/java/jre1.8.0_77/目录下.

安装的jdk是java-1.7.0-openjdk-1.7.0.85-2.6.1.3.el6_7.x86_64,安装在/usr/lib/jvm/java-1.7.0-openjdk-1.7.0.85.x86_64


必须要设置的环境变量:

CATALINA_HOME="/usr/local/apache-tomcat-7.0.68"

JRE_HOME="/usr/java/jre1.8.0_77/"

JAVA_HOME="/usr/lib/jvm/java-1.7.0-openjdk-1.7.0.85.x86_64"


可选设置的环境变量:

CATALINA_BASE="/usr/share/apache-tomcat-7.0.68"

可以设置,如不设置就使用CATALINA_HOME的值.最好设置.

其它如JAVA_OPTS,CATALINA_OPTS,CATALINA_PID,最好不要设置.


四,启动tomcat:

$CATALINA_HOME/bin/startup.sh 或 $CATALINA_HOME/bin/catalina.sh start

可以看到如下输出:

Using CATALINA_BASE:   /usr/local/apache-tomcat-7.0.68

Using CATALINA_HOME:   /usr/local/apache-tomcat-7.0.68

Using CATALINA_TMPDIR: /usr/local/apache-tomcat-7.0.68/temp

Using JRE_HOME:        /usr/java/jre1.8.0_77/

Using CLASSPATH:       /usr/local/apache-tomcat-7.0.68/bin/bootstrap.jar:/usr/local/apache-tomcat-7.0.68/bin/tomcat-juli.jar

Tomcat started.


需要注意防火墙和相关目录的权限.如果都设置正常,在浏览器中访问:

http://192.168.1.210:8080/examples/index.html

可以看到正常页面











本文转自jetyi51CTO博客,原文链接:http://blog.51cto.com/jetyi/1764291 ,如需转载请自行联系原作者

相关文章
|
IDE Java 编译器
在此环境中不提供编译器也许是在JRE而不是JDK上运行?
在此环境中不提供编译器也许是在JRE而不是JDK上运行?
|
编译器 开发工具 Windows
VS2015编译OpenJDK8:找不到libcmt.lib的解决办法
VS2015编译OpenJDK8:找不到libcmt.lib的解决办法
108 0
提示缺少D3Dcompiler_47.dll的解决办法及kb4019990下载
提示缺少D3Dcompiler_47.dll的解决办法及kb4019990下载
127 0
提示缺少D3Dcompiler_47.dll的解决办法及kb4019990下载
|
Linux Windows
cygwin编译x264:extras/avisynth_c.h 未知类型错误 'HMODULE'
cygwin编译x264:extras/avisynth_c.h 未知类型错误 'HMODULE'
67 0
|
Android开发
AS打包APK时,一直缺失so库的解决办法
AS打包APK时,一直缺失so库的解决办法
143 0
|
Java
编译OpenJDK12:运行提示缺少freetype
编译OpenJDK12:运行提示缺少freetype
79 0
|
C++
提示缺少msvcpNNN.dll怎么办
提示缺少msvcpNNN.dll怎么办
78 0
DeepStream运行范例出错,提示缺少libnvinfer.so怎么办?
DeepStream运行范例出错,提示缺少libnvinfer.so怎么办?
180 0
|
Android开发
由于Eclipse版本不符造成的异常
前几天把GEF版本从3.0.1升级到了3.1M6,发现以前运行正常的GEF程序现在总出现下面这个异常,例如在我移动一个节点时,或者创建一个新节点时。 !ENTRY org.eclipse.ui 4 0 2005-04-19 23:12:55.
1174 0