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

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

ただいまの
回答率

88.92%

VPSサーバ上のTomcatにwarファイルをデプロイできない

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 2
  • VIEW 3,226

taku_oshiba

score 4

Spring Boot で "Hello world" を表示するごく簡単なWebアプリ作成を行っております。完成品から war ファイルを作成し、ローカルの tomcat/webapps 下にコピー。すると問題なく展開・ブラウザでの表示が確認出来たのですが、公開用のさくらVPSサーバ上に同じ様に配置しても表示まで行き着けません。

[状況]

  • VPS 上でも war ファイルの自動展開は行われている
  • VPS 上の Tomcat に元から入っている /docs や、/examples 以下サンプル は正しく動作しますが、manager/html も開けない
  • war ファイルを使わずに個別に必要な箇所に必要なファイルを配置していったアプリに関しては正しく動いている
  • {IPアドレス}/{appName}/ にローカルでは :8080 でアクセス。VPS ではポート80でアクセス出来るよう処理済で :80 でアクセス
  • VPS の Tomcat フォルダ以下はすべて所有者 tomcat:{userName} で、パーミッションは 770
  • tomcat/conf/server.xml のオートデプロイ記述に関してはデフォルト(=true)であることを確認。
  • 表示できない = 全てブラウザ上で 404 が返ってきている
  • Tomcat ログファイル各種はエラーの様子は無さそうですが、アクセスに対する GET の通知は届いていない様
  • ローカルの Tomcat は Spring Boot 組み込みのものでは無く、単独起動したもので動作

[環境]

  • Spring Tool Suite の Legacy Project (Maven) で製作
  • Spring Tool Suite ver.3.9.6
  • Java(VPS) ver.open-jdk-1.8.0_181
  • Java(local) ver.open-jdk-1.8.0_181-1-redhat
  • Spring Boot ver.2.0.5
  • Tomcat(VPS・local共) ver.9.0.11
  • さくらVPS CentOS7
  • ブラウザ Google Chrome ver.69.0.3497.100
  • ローカル自機 Win7 64bit Professional

完全に行き詰まってしまい、ご助言いただければ幸いです。必要な情報あれば追記いたします、何卒よろしくお願いいたします。
※頂いたコメントの検証を元に加筆修正しました。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

質問への追記・修正、ベストアンサー選択の依頼

  • asahina1979

    2018/09/28 19:53

    webapps じゃないからじゃ?

    キャンセル

  • taku_oshiba

    2018/09/28 20:17

    ご指摘ありがとうございます。webapp は全て私の誤植で、実際は webapps フォルダでした。現状を追記しましたので、もしお時間ありましたらご覧いただければ幸いです。

    キャンセル

  • asahina1979

    2018/09/28 20:24

    logs 以下のログになにかでてないん?

    キャンセル

  • taku_oshiba

    2018/09/28 21:18

    ありがとうございます、logs 以下中身 一式見てみました。表示に成功しているローカルのログと見比べてもエラーの類の記述はなさそうでしたが、アクセス時の GET の通知は届いていないようです。

    キャンセル

回答 2

+2

さくらVPSサーバについては見識がありませんので、一般的にtomcatにアプリケーションを配備する際の観点でお話しします。
webapp配下にモジュール(warファイル)を配置するとtomcatがモジュールを展開、配備されますが、モジュールを配置する前にモジュールの所有者を変更してみては如何でしょうか?
webapp以外の適当なフォルダに一旦モジュールを配置、chownコマンドにて所有者の変更を行えばよいと思います。
所有者変更に特別な権限が必要であれば、権限を有するユーザにsuコマンドでユーザ変更する必要があるかもです。(root権限があるユーザであれば問題ないと思いますが)

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/09/28 20:31

    ありがとうございます。まだ色々探っている最中ではありますが、

    manager/html にもアクセスできない ことが判明いたしました…しかしフォルダ・ファイルは正しく存在しているようです。host-manager というのもデフォルトで入っていますがこちらも開かないようです。docsと、examples 以下全てのサンプルにはアクセス出来ています。

    tomcat/conf/server.xml のオートデプロイに関する設定はネットの情報とも照らし合わせましたが、デフォルト=true で間違い無いようです。

    配備ディレクトリの設定も合ってる筈です。webapps/{appName} 以下には正しく展開されているのです…works/Catalina/localhost/{appName} 以下にだけ展開される様子がありません。

    随分以前に ポート80でアクセスできるように迂回するような修正記述を行ったので、tomcatのトップページ と サイトのトップページと同じURLになり、これにアクセスすると後者の html ページが表示されます。8080ポートも開いてあるのですがアクセスは拒否されます。
    この設定に関する何かか、またはtomcatのインストール自体が怪しい可能性もあるのでしょうか…?度々恐縮ですが何卒よろしくお願いいたします。

    キャンセル

  • 2018/09/28 20:33

    アクセスできない、は何れも 404 です。

    キャンセル

  • 2018/09/28 21:26

    度々すみません。
    works/Catalina/localhost/{appName} 以下のファイルは、最初のアクセスがあったときに生成されるものの様でした。なので、自動展開自体は正しくされているのではと思います。そのかわりアクセスは tomcat に届いていない(?)ということにもなります、ログにも GET の記録が残っていません。

    キャンセル

check解決した方法

0

解決しました…お騒がせいたしました。

VPS 上のポートリダイレクト :8080 → :80 の内部処理、httpd から tomcat に渡す対象のパスをその都度書かないとならないのでした…。/etc/httpd/conf.d/httpd-proxy.conf ファイルの記述です。

<Location /hoge>
    ProxyPass ajp://localhost:8009/hoge
</Location>


ご回答頂いた皆様ありがとうございました。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

関連した質問

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