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

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

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

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

ImageMagick

ImageMagickとは、画像の表示や操作を行うオープンソースのソフトウェアです。プログラムはCで書かれており、GIFやJPEG、PDFなど画像ファイルフォーマット100種類以上に対応しています。

Q&A

2回答

2269閲覧

画像のリサイズについて(ビューで処理するのと、アプリケーション側?で処理するのとではどちらが速度が早いのでしょうか?)

kento2543

総合スコア163

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

ImageMagick

ImageMagickとは、画像の表示や操作を行うオープンソースのソフトウェアです。プログラムはCで書かれており、GIFやJPEG、PDFなど画像ファイルフォーマット100種類以上に対応しています。

0グッド

1クリップ

投稿2015/07/07 16:22

編集2015/07/07 16:27

現在、画像を多く使用するwebサービスを作ろうと思っております。
そこで画像のリサイズについて疑問が生じたため、質問に至りました。

※railsでの開発を想定しておりますが、今回の検証にあたっては言語は特に問いません。

画像をたくさん使う大手のweb会社ではアプリケーション側(ImageMagick等を用いて)で加工しているというイメージがあります。(処理1)

その一方で、ビュー側でサイズを指定し、リクエスト毎にリサイズしてしまうという方法の方がとても簡単にできるのではないかと思います。(処理2)

今回の要件としては
・PC以外にもスマホ等も想定しているため、端末毎にリサイズの大きさを変えたい
・そのため、リサイズした画像をサーバーにおいてしまっては端末毎に結局リサイズしなくてはいけないため、端末毎からのアクセスが来る度にリサイズをする

このような条件の元、処理1と処理2ではどれくらいのレスポンスの差があるのか知りたいです。
実装の簡易さでは圧倒的に処理2かと思われます。

但し、扱う画像数の総数が数百万枚とかになったときには処理1の方が早いのでしょうか?

結局、端末毎でのリクエストの度に、リサイズをするので、処理1と処理2では個人的には差がないようにも見えます。

ただ、画像数の総数が数百万枚以上扱っているweb会社では処理1を採用している印象があります・・・。(違ってるかもしれません。)

宜しくお願いします。

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

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

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

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

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

guest

回答2

0

ちょっと処理2のイメージがわかなかったのですが、Javascriptか何かでクライアントに仕事をさせるということでしょうか?
だとしたら、データ転送量の問題を解決できないのでは?
縮小表示させるにしても、縮小処理させるにしても元データはクライアントに送らなくてはなりませんよね?

それとも、リクエスト毎に元データから縮小データを生成して送るんでしょうか?
だとしたら、リクエスト毎にリサイズ処理がかかるのでリクエストが多ければそれだけサーバーのリソースを食うことになります。

後、考えられるのは最初の表示があったときにリサイズ処理して、それ以降はリサイズされたものを送る、という方法でしょうか?
遅延処理の考えですが、コードの見通しが悪くなりそうです。

処理1だと、アップロードされたときの処理が多くなりますが、フロントエンドのHTTPDがキャッシュしてくれたりとか、色々うれしいことが多いように思えます。
また、アップロードの時のレスポンスが多少遅くなっても、ユーザーの体感的にはあまり問題がなさそうですし。

投稿2015/07/07 16:48

rifuch

総合スコア1901

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

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

0

サーバのスペックにもよりますが、一般的にいえば、処理2の方が速いと思います。

処理2の場合、view側ということなので、javascriptか
cssのメディアクエリを使って動的にサイズ変更することになると思います。

ただし、javascriptやcssを用いた場合、解像度を変更したりといった高度な画像編集はできません。
質問にあったリサイズ程度であれば、javascriptかcssでまかなえると思います。

投稿2015/07/09 16:43

ylang365

総合スコア175

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

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

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

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問