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

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

ただいまの
回答率

91.02%

  • Linux

    3190questions

    Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

  • CentOS

    2346questions

    CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

  • phpMyAdmin

    567questions

    phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

  • VPS

    297questions

    VPS(バーチャル・プライベート・サーバ)は、仮想化されたサーバをレンタルするサービスで、共有サーバでありながら専門サーバと同等の機能を果たします。物理的な専門サーバより安価で提供できるメリットがあります。

  • Apache Tomcat

    28questions

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

CentOS7でJava環境を構築する際にproxyの転送が上手くできない

解決済

回答 1

投稿

  • 評価
  • クリップ 1
  • VIEW 141

shaketonori

score 2

さくらインターネットのVPSでJavaの環境を構築しています。
これまでCentOS6.Xでは何回も行なっていますが、今回初めてCentOS7 で環境を作ろうとしたところ、TomcatとApacheの連携がうまくいかず、phpMyAdminの画面が開かない、という問題が出てしまいました。

インストールしているのは以下のソフトです。
1)CentOS 7
2)Apache2.4.6 標準repo
3)PHP 7.1 remi
4)MariaDB 5.5 標準repo
5)phpMyAdmin4.7.7 remi
6)OpenJDK1.8.0 標準repo
7)Tomcat8.5.24 バイナリ

上記ソフトをインストール/設定した後にSSLの設定をする予定ですので、今のところはSSLとは無関係です。

順番にインストールを行い、5)phpMyAdminをインストールを行ったところまでは特に問題はありませんでした。
5)が終わった時点でURLと検索結果は以下の関係でした。

http://example.com        → /var/www/htmlの下のindex.htmlが表示された。OK
http://example.com:8080     → ネコの画面が表示された。OK
http://example.com/phpMyAdmin  → phpMyAdminのログイン画面が表示された。OK
と特に問題はありませんでした。

その後6)OpenJDKと7)Tomcat8.5.24をインストールした後、以下の設定を行いました。

①「:8080」を使わないでTomcatに転送するために、/etc/httpd/conf/extraの下に「httpd-proxy.conf」を作成し以下のように記述しました。phpMyAdminへの例外処理を含める。

ProxyPass /phpMyAdmin !
<Location / >
    ProxyPass ajp://localhost:8009/
</Location>

②Apacheの設定ファイル「/etc/httpd/conf/httpd.conf」の末尾に

Include /etc/httpd/conf/extra/httpd-proxy.conf


を追加記述し、①のファイルを読み込むようにした。

以上の2点を行い、TomacatとApacheを再起動した結果、TomcatとApacheの連携はうまくいったようだが、phpMyAdminへの ProxyPassが上手くいかず画面にたどり着けません。

http://example.com         → ネコの画面が表示された。OK
http://example.com/phpMyAdmin   → 404 Not Found となる。NG

ひとつ考えられるのは「mod_proxy_ajp」が有効になっているかということですが、
Apache2.4ではLoadModuleの読み込みが「httpd-proxy.conf」には記載されておらず、
「/etc/httpd/conf.modules.d」の下にある複数のconfファイルで読み込んでいます。
当然のことながら、この中に「mod_proxy」や「mod_proxy_ajp」は有効に読み込まれていました。
もっとも、port8009への転送はうまくいっているので、ここは問題ないようです。

proxyの転送自体は機能しているようだが、例外処理が上手くいっていないということか。

httpd-proxy.conf の記述を

<Location /phpMyAdmin>
    ProxyPass !
</Location>
<Location />
    ProxyPass ajp://localhost:8009/
</Location>

と、記述を変えてみましたが、結果は変わりませんでした。
例外の記述方法がApache2.4で変更になったのかと考えたが、マニュアルを見ても
それらしい記述はありませんでした。

また、バカバカしい失敗としてはキャッシュがクリアされていない場合ですが、
今回は慎重に毎回毎回キャッシュをクリアして確認しました。

この辺の処理は、前述したようにCentOS 6.8でも行っており、現状も問題なく使えています。
なぜCentOS7/Apache2.4でうまくいかないのか、
どなたかお分かりの方がいらしたら、ご指導ください。
よろしくお願い致します。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • CHERRY

    2018/01/18 10:57

    どちらかといえば、apache の設定の質問なので、タグに Apache も入れたほうがいいですね。

    キャンセル

回答 1

checkベストアンサー

+1

おそらくディレクティブ解釈の優先順位の問題だと思いますが、loglevel をあげてログを取ってみたら何か分かるかもしれないですね。


内容的には同じですが、以下のようにしてみたら、どうなるでしょうか?

ProxyPass /phpMyAdmin !
ProxyPass /           ajp://localhost:8009/

ProxyPass - Apache モジュール mod_proxy に記載されている「サブディレクトリをリバースプロキシしたくないとき」の設定例ですが...

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/01/18 12:41

    CHERRYさん、回答ありがとうございました。

    私もApache モジュール mod_proxy【2.4】(https://httpd.apache.org/docs/current/ja/mod/mod_proxy.html#proxypass)とApache モジュール mod_proxy【2.2】(http://httpd.apache.org/docs/2.2/mod/mod_proxy.html)
    を見比べて、いくつかのパターンでやってみましたがうまくいきませんでした。

    ところが、CHERRYさんのアイデアどおり

    ProxyPass /phpMyAdmin !
    ProxyPass / ajp://localhost:8009/

    Locationタグを外したところ、phpMyAdmin のログイン画面に遷移することができました。

    ウレシイですねぇ。
    うまくいきました!
    何かしらやってみるものですね。
    本当にありがとうございました。

    キャンセル

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

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

関連した質問

  • 受付中

    ApacheのリバースプロキシとSSL

    こんにちは。 Apache2.4 + Tomcat7 で プロジェクトメンバー間の情報共有サーバーを構築しています。 いま、タスク管理にredmineを導入することになり、 イ

  • 受付中

    eclipseでのtomcat7の起動について(apatch連携)

    解決したいこと javaの勉強をし始めた初心者です javaのupdateを行って以降、以下の現象が起きて困っています。 eclipse4.5のローカルサーバーとしてmo

  • 解決済

    tomcatとapacheの連携

    tomcat7とapacheのhttpd-2.4.20-win64-VC14を連携させたいのですがうまくいきません Webサイトで調べてhttpd.confのLoadModule

  • 解決済

    TomcatをSystemdで起動すると、接続できない

    発生している事象 CentOS7環境のサーバ上で、Tomcat8を使用しています。 サーバ起動時の自動起動を、Systemdのserviceで行いたいと思っています。 コマン

  • 解決済

    GitBucketをVPSでhttpsで使う方法

    今、GitBucketをさくらVPS上で使いたいと思い試行錯誤しております。 それで、↓こちらのサイトを参考にさせていただきながら、なんとか動くようになりました。 http:/

  • 解決済

    ApacheとTomcatの連携について(Windows2012 R2)

    前提・実現したいこと Windows Server 2012 R2 にてApache2.4.25とTomcat8.5.11を連携させてWebアプリケーションを動作させたい

  • 受付中

    Tomcatが上手く起動しない

    前提・実現したいこと アプリケーションの開発初心者です。 これから勉強しようとしています。 こちらでの質問も初めてですが、 皆様のお力をどうかお貸しください。 発生し

  • 受付中

    TomcatとApache間連携のmod_proxyの利用について

    OS:winにてTomcatとApache間連携でmod_proxyを利用する設定について質問です。 ◆httpd.confファイルの中身にについて LoadModule ro

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

  • Linux

    3190questions

    Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

  • CentOS

    2346questions

    CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

  • phpMyAdmin

    567questions

    phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

  • VPS

    297questions

    VPS(バーチャル・プライベート・サーバ)は、仮想化されたサーバをレンタルするサービスで、共有サーバでありながら専門サーバと同等の機能を果たします。物理的な専門サーバより安価で提供できるメリットがあります。

  • Apache Tomcat

    28questions

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