質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

89.98%

mavenで作成した webアプリが WTP で動かなくなる。

解決済

回答 3

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 3,161

tknakamuri

score 34

やっていること

Eclipse(Neon Pleiades All-in-one)を使用し
 Maven プロジェクトで Web(war)アプリを
作成しています。

問題点

簡単なサーブレット1個のプロジェクトを作成し packageフェーズまで
ビルドし、Eclipse の Servers に追加した Tomcat8 に
プロジェクトを追加して「開始」すると、何の問題もなく動きます。 

ところが、
・プロジェクトを serversのtomcat8 から除去
・プロジェクトをF2(リファクタリングの名称変更)でリネーム
・プロジェクトの war を clean/package で再ビルド
・プロジェクトを serversのtomcat8に再追加
・serversのTomcat8を開始

とすると、Tomcat8は問題なく、エラーメッセージもなく起動しますが
サーブレットの URL を叩いても

The requested resource is not available.

と画面に出るだけです。

プロジェクト名を元に戻しても治りません。

但し、生成される war を直接 Tomcat8 の webapps に置き、
startup.bat で tomcat8 を起動すれば、サーブレットは問題なく
動きます。

また maven の jettyプラグインや tomcatプラグインでも
正常に動きます。動かないのは WTP を使って起動した場合だけです。

該当のソースコード

サーブレット

package info.nakamuri.app.spikes.mavenbasics.hellotest;

import java.io.IOException;

import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@WebServlet("/Hello")
public class HelloWorld extends HttpServlet {
    private static final long serialVersionUID = 1L;

    public HelloWorld() {
        super();
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        RequestDispatcher rd = request.getRequestDispatcher("WEB-INF/jsp/hello.jsp");
        rd.forward(request, response);
    }
}

JSP(WEB-INF/jsp/hello.jsp)

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Hello World</title>
</head>
<body>
    <h1>こんにちは</h1>
</body>
</html>

試したこと

同様な試験を struts2 等の各種プロジェクトでも行い、
warのmavenアプリなら再現することを確認しましたが
いろいろなアプリのエラーメッセージから
どうやら、クラスパスが正しくないことがわかってきました。

おそらく WTP で起動する場合に使うクラスパス関連の設定が壊れて
いると思うのですが、そんな設定がどこにあるのか、未だ見当が
付きません。

ご存知の方が居られましたらよろしくお願いいたします。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 3

check解決した方法

+1

ほぼ自己解決したので報告いたします。意外な結末でびっくりしてます。

日頃 maven + WTP で作業されている方に見てもらうと「m2e-WTP が動いていないっぽい」
とのこと。m2e-WTP が表示するはずの項目がプロジェクトエクスプローラーにないらしいのです。

「メモリとCPUが足りないと、この状態になることがある・・・・・」

とのことで、マシンを Celeron 4GB から i5 8GB に変更
Eclipse と workspace をコピーして起動すると、
驚いたことに、確かに Mavenのwarのプロジェクトの表示項目が増えてます。

この状態で、Mavenプロジェクト更新、clean/package, serversのTomcat8 に
プロジェクト追加&実行すると、何の問題もなくすんなり動きます。

というわけで、メモリ/CPU不足という結末になりそうです。

ただ、i5はともかく、8GB積んだマシンがあまりないので、対策を
検討中です。

教訓: CPU/メモリ不足で eclipse の動作が、エラーではなく、「不調」になることがある。

追記(2016/12/8)

i5 8GB のマシンでも、頻度は少ないものの、たまに再現することがあるので、調べてみたところ

C:\pleiades\workspace\.metadata\.plugins\org.eclipse.wst.server.core\tmp0\wtpwebapps

にできる WTP用のWebプロジェクトのコピーにクラスファイルがコピーされるのにひどく時間がかかったり、
WEB-INFの下に classes 以外のフォルダができなかったりすることがあることを確認しました。
TOMCATにプロジェクトを再ビルド/再追加するとほとんど治りますが、100%の信頼性はありません。

不安な動きをすることから、当面 m2e-WTP の使用は諦め、maven-tomcat-plugin でデバッグを
行うことに決めました。こちらでは mavenのwarプロジェクトでもホットリロードが可能なため
(m2e-WTP では reloadable="true" に設定しても不可) 効率がよさそうです。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

解決方法にならない可能性はありますが、下記を確認してください。

プロジェクト名をリネームした際には、Webアプリケーションのコンテキストルートも同時に変更するかを確認ダイアログが出たかと思います。

もし変更しなかった場合は、WTPでは名前変更前のコンテキストパスのままなので、対象のアプリケーションが正しく起動できない場合があるでしょう。

Neonに対応しているWTPのバージョンであれば、サーバタブ(つまりWTP管理下のサーバ)のTomcatを選択し、「モジュール」タブから、Webモジュールのパスと合致しているかどうかを確認してください。

なお、サーバにデプロイしているアプリケーションの名前と実際のコンテキストパスを確認する方法は、Serversプロジェクト>コンテナ名(Tomcat8) にある server.xmlの最下部です。こちらも正しい名前で作られているかを確認すると良いでしょう。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/12/06 18:47

    ご回答ありがとうございます。残念ながら解決に至っていないのですが、経過を報告いたします。

    おっしゃる通り、コンテキストパス名とプロジェクト名は一致しておりませんでした。

    元のプロジェクト名=HelloTest 改名後 = HelloTest2

    <Context docBase="HelloTest2" path="/HelloTest" reloadable="false" source="org.eclipse.jst.jee.server:HelloTest2"/></Host>

    コンテキストパス名とプロジェクト名は独立でよいという認識だったのと

    http://localhost:8080/HelloTest/Hello
    http://localhost:8080/HelloTest2/Hello

    も駄目だったものですから、あまり気に留めなかったのですは、取り合えず一致させるため
    プロジェクトのプロパティの[Webプロジェクトの設定]でコンテキストルートを「HelloTest2]
    に設定。ところが Maven のプロジェクト更新で元に戻ってしまうため、よく調べると
    warのmavenプロジェクトでは pom.xml の ArtifactId がコンテキストルートになるようです。

    pom.xml の ArtifactId を HelloTest2 に変更して Mavenプロジェクト更新すると
    [Webプロジェクトの設定]のコンテキストルートも HelloTest2 になったので、
    clean/package で再構築。Tomcat8 に改めて加えると

    <Context docBase="HelloTest2" path="/HelloTest2" reloadable="false" source="org.eclipse.jst.jee.server:HelloTest2"/></Host>

    と名前が揃いました。
    しかし、http://localhost:8080/HelloTest2/Hello

    The requested resource is not available.

    のまま。http://localhost:8080/HelloTest/Hello も同様です。

    どうもコンテキストパスは関係なかったようです。

    現在正常に動く HelloTest をもう一つ作って、違いを虱潰しに探していますが
    今のところ全然わかっていません。

    キャンセル

0

たぶん。.m2リポジトリ内のjarファイルが壊れているので .m2リポジトリ内のjarファイルを削除してみてください。
(クリーンで処理できない子がいる。)

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/12/06 19:52

    どのjar でしょう? 

    プロジェクトを install でビルドしていないので、ローカルリポジトリには
    何も登録していないはずですが、実際 .m2の info.nakamuri.app.spikes.mavenbasics.hellotestというフォルダは存在しませんでした。

    キャンセル

  • 2016/12/07 08:01

    Org apace Maven pluguin 等関連付けされているjarのいずれか

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 89.98%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る