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

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

新規登録して質問してみよう
ただいま回答率
86.12%
Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

CodeIgniter

CodeIgniterは、PHP向けオープンソースのWebアプリケーションフレームワークです。CodeIgniterは覚える構文が少なく、自由度も高いため、PHPを理解していれば構築が簡単です。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

解決済

CodeigniterとAJAXで作ったサイトが、表示されなくなる

qwe001
qwe001

総合スコア129

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

CodeIgniter

CodeIgniterは、PHP向けオープンソースのWebアプリケーションフレームワークです。CodeIgniterは覚える構文が少なく、自由度も高いため、PHPを理解していれば構築が簡単です。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

2回答

0リアクション

0クリップ

1227閲覧

投稿2020/07/30 09:00

原因がわからず、解決の糸口が全く見つかりません。
ダメ元で質問します。

背景として、それまで他社サーバ上で、静的HTMLのみで構成していた自社サイトに、
自社開発…というか私がCodeIgniter3を使って開発したCMSを導入することになりました。

ユーザ向け画面のViewをCodeIgniterで管理するといったことはせず、
既存の静的HTMLファイルのままで、動的コンテンツの読み込みが必要な箇所のみ、
jQueryのAJAXでデータを読み込むことにしました。
ただし、一部の下層コンテンツは事情があり、Vue.jsのaxiosを用いてデータを読み込みます。

開発が完成し、テスト環境での動作確認も終えて、いざ本番環境にリリース。
…を、した時に、表題の事象が発生しました。

事象が発生するまでの流れは次の通りです。

  1. 任意のブラウザ(Google Chromeなど)でサイトトップを表示する
  2. AJAX通信で、APIにコンテンツデータをリクエストする
  3. PHPが動き、MySQL DBからコンテンツデータを取得
  4. PHPが動き、JSON形式でレスポンスを返す
  5. レスポンスデータを元に、HTML要素が形成され、画面が表示される

どこのサイトでもやってそうな、いたって普通の処理です。

要するに、普通にサイトトップページにアクセスするだけです。

たったこれだけのことですが、よりによって本番環境でのみ、
何回かページをリロードすると、サイトの全コンテンツが表示されなくなります。

ページの読み込みが非常に遅くなり、しまいにはページが表示されず、
Error empty response とブラウザに表示されます。

しかも具合が悪いのは、一度発生すると同じサーバー内の
別サイト(他社管理)まで5~15分程度、表示されなくなります。
サーバーは当社の管理外のため、Apacheを再起動することもできません。

他社サイトにまで悪影響を及ぼすプログラムをリリースできるわけもなく、
原因不明のまま、元の静的HTMLページにロールバックしました。
(当然、元に戻したら事象は発生しなくなりました。)

開発環境でもテスト環境でも再現せず、
Apacheログやアプリケーションログを見ても何のエラーも表示されないので、
完全にお手上げ状態です。

リリースしてすぐに問題が発生したので、
私が開発したCMSか、AJAX処理記述になんらかの問題があると思いますが、
いかんせん何から手を付けたらいいのか、さっっっぱりわかりません。

ちなみに、以前、別のサイトでリリースした時も同じ現象が発生して、
その時は、CodeIgniterのアプリケーションログ書き込みをやめることで現象が発生しなくなりました。

今回も同じパターンと思い、ログ書き込みをやめたのですが、現象は解決せず。
(その時は、複数人が同時にアクセスすることで、ロック中のログファイルに書き込みリクエストが殺到して表示されなくなったのかなと推測しました。当然ながら、こちらも原因不明です)

似たような事象に遭遇した方はいますか?
事象の解決ができれば方法は何でもいいです。
(原因不明でも解決できそうな方法は一つだけ考えついていますが、大掛かりな改修が必要になるので、躊躇しています)

自分はこうしたら治った、こんなところを調べたなど、
体験談があれば是非教えてください。
よろしくお願いいたします。

以下のような質問にはリアクションをつけましょう

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

リアクションが多い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

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

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

適切な質問に修正を依頼しましょう。

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
86.12%

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

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

質問する

関連した質問

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

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

CodeIgniter

CodeIgniterは、PHP向けオープンソースのWebアプリケーションフレームワークです。CodeIgniterは覚える構文が少なく、自由度も高いため、PHPを理解していれば構築が簡単です。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。