質問 > 管理機能 > 携帯ですごく遅いのですが。動的のせい? |
管理機能
スレッド表示 | 古いものから | 前のトピック | 次のトピック | 下へ |
投稿者 | スレッド |
---|---|
gallu |
投稿日時: 2008/6/23 16:08
対応状況: −−−
|
半人前 登録日: 2007/9/13 居住地: 東京 投稿: 28 |
Re: 携帯ですごく遅いのですが。動的のせい? がるです。
なんか久しぶりに書き込み応酬しておりますw まず、SQLの特定ですが。 「EC-CUBE使ってた現場から離れてしまった & その現場でも使わなくなってしまった」ので、ちとわざわざ環境作り直してまで、という元気はないので資料がない、という状況なので、「これ」とは申し上げられないのですが。 ただ、印象値としては「一つ二つではなくて色々と困ったクエリが多発していた」ように記憶しています。 コネクション関連なのですが。 どうやら「あるconnectionから発行されたSQLが完了するまでは解放しない」ような挙動をしているように感じられました(まぁ結果かえさにゃいかんのでそうだろうとは思うのですが)。 やはり「重いクエリがいかん」とか、どうしても思ってしまうんですがどんなもんなんですかねぇ。 で。 > 複雑なクエリほど I/O を使うので > 負荷を掛けるならDBだと。 についてはまぁ色々な見地があろうかと思うのですが。 個人的には「DBには負荷をかけちゃいけない 負荷かけるのはWebサーバ側」というスタンスを取る事が多いです。 端的に書くと。Webサーバをクラスタリング化しても、プログラムさえちゃんと考慮されていれば、3台にしたら1台の3倍程度のお値段で片付くのですが。 DBサーバをクラスタリング化し始めると、桁が2つ3つずれこんでくるので orz # OracleとDB2でクラスタリングしたくて見積もり依頼出したときの、あまりの指数っぷりに本気でどん引きした記憶があります。 # 1台横にのばすと、本気で0が一つ追加くらいの勢いでした orz 多分この辺って > しかし、その辺って、商用DBとオープンソースのDBで、差がつくんですよね… が非常に大きな部分だとは思うのですが…ただ、裏側の機構(データの整合性の取り方)を考えると、どうしてもそこのコストの高さが気になってしまって(苦笑 あと。OSSのDBMSでも「ミドルウェアとして有料のソフトを使う」なんて事も少なからず出てくる事を考えると…「Webサーバに負荷かけて横にのばしたほうが安いよねぇ」と考えてしまいます(笑 まぁぶっちゃけあっしは現在使ってないのでいいっちゃぁいいのですが。 願わくば、もう少しスケーラビリティのある設計とかプログラミングとかなされてればなぁ、とか思ってみなくもありません。 |
seasoft |
投稿日時: 2008/6/23 11:28
対応状況: −−−
|
神 登録日: 2008/6/4 居住地: 投稿: 7367 |
Re: 携帯ですごく遅いのですが。動的のせい? がる様
コネクション数の件、理解できました。 しかし、それって PHP は手を離しているはずなので、(MySQL内のセッションが残るのは仕方が無いとして)MySQLもコネクションを開放してほしい気がしますが、そういうものではないのかなぁ… その状況下では、コネクションを張れたところで、処理で詰まるので、根本的な解決にはなら無そうですが。 > テーブル設計もそうなのですが、それ以上に、投げるクエリがちょっとどんなもんかなぁ、と感じております。 大いに賛同します。 > 大規模系開発の方とお話するときくらいしか頷いていただけないのですが。個人的には「原則としてjoin及び副次問い合わせ禁止」というスタンスなので。 ここは逆ですね。 以前は私も結合・副問い合わせはほとんど使っていませんでした。それが、1000行を超えるSQL文をWEBからリアルタイムで投げる銀行の情報系システムを扱ってから考えが変わりました。負荷を掛けるならDBだと。 しかし、その辺って、商用DBとオープンソースのDBで、差がつくんですよね…
|
kvex2004 |
投稿日時: 2008/6/23 10:11
対応状況: −−−
|
長老 登録日: 2007/10/31 居住地: 埼玉 投稿: 218 |
Re: 携帯ですごく遅いのですが。動的のせい? どの部分と言われると、もしかすると回答は「全体的に」となってしまいそうな気がします。
たとえば、カテゴリ一覧を拾う、などといったSQLはあたりまえですがそんなに複雑なわけはありませんので、そこは突っ込まれても困るのですが。 すくなくとお、SQL投げる直前でvar_dumpなどとやって見ていますが「すげぇな・・・これ」と感じるところが多々ございます。 すみません「ここです」と明確に言えません、あまいに多岐にわたっているので。 ただ、何度もいいますが小規模なら十分使えると認識しております。 できれば、MySQLは特例としての動作環境にとどめたほうがいいかもしれませんね。 |
nanasess |
投稿日時: 2008/6/23 6:46
対応状況: −−−
|
神 登録日: 2006/9/9 居住地: 投稿: 2314 |
Re: 携帯ですごく遅いのですが。動的のせい? 引用:
具体的に SQL を特定できれば, 多くの人が幸せになれるかもしれませんね. EC-CUBE で構築した大規模事例をいくつか見ていますが, PV が多くなると, 商品一覧などの重い SQL よりもセッション処理が追いつかなくなる傾向が多いようでした. dtb_session を UPDATE するだけの簡単な SQL ですが, ロードバランサで冗長化された WEB サーバーからの PV を捌き切るのは簡単ではないようです. # dtb_session のみを別の DB で処理することで対応していました 引用:
複雑なクエリほど I/O を使うので, ATA な低速ディスクと SAS や Fibre Channel 接続用のディスクなどで, それぞれベンチマークをとってみてはいかがでしょう? # 正直ではなくてすみません... |
gallu |
投稿日時: 2008/6/23 2:15
対応状況: −−−
|
半人前 登録日: 2007/9/13 居住地: 東京 投稿: 28 |
Re: 携帯ですごく遅いのですが。動的のせい? がるです。
コネクション数に関してですが。私が見ていた限りでは ・ものすごく重いSQLを投げていたために、あるDB接続ハンドルにおいて「処理が終わらない」事象が発生 ・上述が多数重なって(大抵この手のは、一度溜まり始めると一気に溜まります)、結果的にコネクション数を食いつぶした 感じでした。 個人的には。 テーブル設計もそうなのですが、それ以上に、投げるクエリがちょっとどんなもんかなぁ、と感じております。 大規模系開発の方とお話するときくらいしか頷いていただけないのですが。個人的には「原則としてjoin及び副次問い合わせ禁止」というスタンスなので。 …EC-CUBEが投げているSQLを見ている限りでは、ちょっとびっくりするくらいにネストしたクエリがあったりします。 正直、DBって、マシンスペックどんだけ上げてもクエリが重ければあんまり効果がでず、また、横に広げ出すともの凄いコストがかかりまくるので。個人的には「DBには出来るだけ仕事をさせない」設計が好みだったりはします。 まぁ開発スタンスは色々あってよいとは思うのですが。 個人的には「小規模を超えるものには向かないんじゃないかなぁ」と感じる次第です。 |
x41 |
投稿日時: 2008/6/22 23:43
対応状況: −−−
|
仙人 登録日: 2007/11/23 居住地: 投稿: 308 |
Re: 携帯ですごく遅いのですが。動的のせい? そうですね。DB設計の改善には時間がかかると思いますので現段階のバージョンでパフォーマンスを上げたい場合(商品数1500以上)はnanasessさんの仰るとおり高速なハード等のインフラとpostgresqlは一つの選択肢でしょうね。
私もインフラの改善を行いたいと思っているのですが、費用面でなかなか先に進まず・・ |
seasoft |
投稿日時: 2008/6/22 23:22
対応状況: −−−
|
神 登録日: 2008/6/4 居住地: 投稿: 7367 |
Re: 携帯ですごく遅いのですが。動的のせい? 私の場合も、私の利用する予定のボリュームでは問題なさそうなんですよね。
特に PostgreSQL の方は、問題の度合いが軽そうだし。 なので、パフォーマンスチューニングからは一旦手を引きました。 ちなみに、DB設計で気になる点は、どのようなあたりでしょうか? 私はまだ、DBはあまり把握できていないのですが、気になるといえばPKが張られていないとかは嫌ですね。
|
kvex2004 |
投稿日時: 2008/6/22 23:08
対応状況: −−−
|
長老 登録日: 2007/10/31 居住地: 埼玉 投稿: 218 |
Re: 携帯ですごく遅いのですが。動的のせい? 確かにそれは的を得ていると思います。
ただ、まぁ、数百とか1000件以内の商品数なら、それでもそこそこには動いていますね。 できれば、DB設計から見直してもらえるとありがたいかなぁ、という気がしました。 前々から言ってるように、MySQLのほうは、かなりボーダーラインで動いてる気がします。 |
seasoft |
投稿日時: 2008/6/22 22:56
対応状況: −−−
|
神 登録日: 2008/6/4 居住地: 投稿: 7367 |
Re: 携帯ですごく遅いのですが。動的のせい? コネクション数は、通常同時接続ユーザ数と連動するので、サイト規模との兼ね合いもあるので難しいところですが…
1.x系は細切れSQLを投げていたのですかね? 最新版は、比較的コストの高い大物を投げているようです。 その大物が無駄に大きくて… 特に MySQL のは酷いですね。 コネクション数の問題は、同時接続の試験はやっていなかったので、気づかなかったです。 しかし、再起動云々という対処が可能となると、何か別の階層の予感もしますね。 コネクションを明示的に閉じなくて良いことになっているのに、実際には明示的に閉じないと駄目とかはありがちですから。
|
gallu |
投稿日時: 2008/6/22 22:22
対応状況: −−−
|
半人前 登録日: 2007/9/13 居住地: 東京 投稿: 28 |
Re: 携帯ですごく遅いのですが。動的のせい? がると申します。
以前伺ってたところでEC-CUBEを使っていたのですが(バージョンは1.4.…確か3かそこらだったと記憶しております)。 DBはMySQLを、Webサーバとは別立てで、それなりのパワーのモノを占有で使っていたのですが。 端的に言ってしまうと「何度かDBサーバが落ちました」。より正確には「コネクション数が設定の100を超えてしまい固まった」というのが正しいのですが。 結果的に、Webサーバ側からのDB connectが一切合切拒否られて、何度か、DBサーバのrestartの必要に駆られる事がありました。 数値は覚えてませんが…ユーザ数で万の一桁前半、アイテム数は万行かない程度だったように記憶してます…曖昧ですが。 そのあたりもあって私も色々見たのですが…正直、ちょっと如何なモノかと思われるようなSQLをものすごい量投げてました。 とりあえず直近には ・DBサーバのコネクション数の監視 ・発行されているSQL文(特に時間がかかっているクエリ)のチェック などが重要だと思うのですが…正直、もうちょっと基本設計を…と思わなくもありません。 とりあえず「そんな事もあったんだ」程度のニュアンスで書き込んでみます。 |
(1) 2 3 » |
スレッド表示 | 古いものから | 前のトピック | 次のトピック | トップ |