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

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

新規登録して質問してみよう
ただいま回答率
85.51%
Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

Tomcat

TomcatはApache Software Foundation (ASF)で開発されたオープンソースのWebコンテナです。

Q&A

解決済

3回答

7605閲覧

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

tknakamuri

総合スコア56

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

Tomcat

TomcatはApache Software Foundation (ASF)で開発されたオープンソースのWebコンテナです。

0グッド

0クリップ

投稿2016/12/06 01:42

編集2016/12/06 06:58

###やっていること

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 で起動する場合に使うクラスパス関連の設定が壊れて
いると思うのですが、そんな設定がどこにあるのか、未だ見当が
付きません。

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

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

自己解決

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

日頃 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" に設定しても不可) 効率がよさそうです。

投稿2016/12/07 03:06

編集2016/12/08 02:13
tknakamuri

総合スコア56

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

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

投稿2016/12/06 10:42

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

tknakamuri

2016/12/06 10:52

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

退会済みユーザー

2016/12/06 23:01

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

0

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

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

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

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

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

投稿2016/12/06 08:19

A-pZ

総合スコア12011

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

tknakamuri

2016/12/06 09:47

ご回答ありがとうございます。残念ながら解決に至っていないのですが、経過を報告いたします。 おっしゃる通り、コンテキストパス名とプロジェクト名は一致しておりませんでした。 元のプロジェクト名=HelloTest 改名後 = HelloTest2 <Context docBase="HelloTest2" path="/HelloTest" reloadable="false" source="org.eclipse.jst.jee.server:HelloTest2"/></Host> コンテキストパス名とプロジェクト名は独立でよいという認識だったのと http://localhost:8080/HelloTest/Hellohttp://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 をもう一つ作って、違いを虱潰しに探していますが 今のところ全然わかっていません。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.51%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問