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

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

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

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Webサーバー

Webサーバーとは、HTTPリクエストに応じて、クライアントに情報を提供するシステムです。

Q&A

解決済

7回答

5830閲覧

Webシステムにおける写真の取り扱い

退会済みユーザー

退会済みユーザー

総合スコア0

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Webサーバー

Webサーバーとは、HTTPリクエストに応じて、クライアントに情報を提供するシステムです。

1グッド

7クリップ

投稿2017/02/15 07:32

すごくベーシックな質問だとは思うのですが、Webシステムにおいて、写真(jpegやpngファイル)というのはどのように取り扱うのでしょうか?
例えば、アカウントに写真を設定するとなったときに、Javaであれば、そのクラスのフィールドとしてPictureクラスの変数に値を設定すると言った感じになるのではないかと思ったのですが、jpegファイルやpngファイルをそのままデータベースに設定したり、できるのでしょうか?
そのほかのもの(名前やパスワードなど)の取り扱いであればわかりますが、写真の場合どうなるのでしょうか?
回答お願いします。

yohhoy👍を押しています

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

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

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

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

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

guest

回答7

0

ベストアンサー

個人的な経験を元に私の感想を書きますが、規模が小さければDBに画像データを格納する方が管理しやすいですが、ある程度の規模(ファイル数や容量)になると、DBとは別のファイルサーバーに画像を保存して、DBにはファイルパスで管理するのが融通が効いて良いですね。

メリット

  • DB、ファイルサーバそれぞれのバックアップを別々に取ることが出来る→DBは高頻度でとりたい。ファイルサーバーはデイリーで良い。など
  • 画像の差し替えや、変換を後からできる→サイズ縮小、高圧縮化、など
  • CDNを使える余地がある→Webサーバーの負荷分散
  • DBの負荷を軽減できる→結合や集約した結果、内部的に一時テーブルを作る場合、BLOB型のデータは性能悪化につながることがあるのと、単純に処理するデータ量が減るので負荷軽減が見込める。

デメリット

  • 別々にリストアしなければいけない
  • 別途ファイルサーバーが必用
  • ネットワーク的に複雑化する
  • 画像の排他制御をプログラムで行う必要がある(必用ならばですが…)
  • ファイル名をユニークに保つ必要が出て来る

なお、Webサーバーのローカルに画像を置く方式もアリですが、Webサーバー自体をスケールアウトした場合や、冗長化した場合に面倒になるので、ファイルサーバーを別に立てるのが良いかなという感じです。

投稿2017/02/21 13:05

編集2017/02/27 08:55
take88

総合スコア1351

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

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

zico_teratail

2017/02/22 01:10

teratail回答者の皆さんはシンプルな回答ができずに、すぐに複雑で難しい回答や、質問者が求めている以上の詳細すぎる回答に走りがちです。 もちろん親切心から良かれと思ってそうしているのだろうと思いますが、でも需要(質問者)と供給(回答者)の次元が違いすぎます。 質問者のレベルに合わせて答えるならば、一番シンプルに「Webサーバのローカルに画像を置いてパスだけDBに入れろ」がベストだと私は思います。 スケールアウトだの冗長化だのが必要になったらそのときにまた考えてもいいし、そもそもそんな大規模のサービスを運営するような人がこんなレベルの質問をするでしょうか? 「近所のコンビニに行くためのオススメ自転車を教えてください」という質問に対して、「自転車ではなく、応用範囲の広い自動車を買ってください。最も性能がいいのはF1マシンです。でもかなりセッティングが難しいのでとりあえず市販車のGT-Rにしておけば云々・・・」などと答えだすのがteratail質問者の悪い意味でのあるあるパターンです。
take88

2017/02/22 02:25

ご意見理解しました。私の考え方はとあなたの考えは違うようですが、あなたの言ってることはよくわかります。シンプルな回答は私の目指すところですが、何故そうなのかという事とともに示さないと価値が半減するというのが私の考えでしてつい長くなってしまいました。ただ、質問者のレベルが書かれていない以上、そのレベルに合わせるということは出来ませんので難しい問題ですね。規模についても書かれていませんでしたので、「規模が小さければ…」「ある程度の規模になると…」と条件つきで2つの方式どちらも良いと思う。ということを書いた次第です。メリットやデメリットを書いたのは他の回答への質問者の方のコメントを読んでのことです。
zico_teratail

2017/02/22 08:21

take88さんの回答内容そのものを否定しているわけではありません。 相対的なレベル合わせはどうしたら良いかな、という話です。念のため。 また、take88さんに向かって書いたというよりも、どちらかというとteratail回答者全体の傾向について書いたものですので悪しからず。ご気分を害されましたら申し訳ありません。
take88

2017/02/22 09:32

いえいえ、ご意見はよく分かってますので気分を害すと言ったこともありませんので大丈夫です。
guest

0

jpegファイルやpngファイルをそのままデータベースに設定したり、できるのでしょうか?

できます。BLOB型などのキーワードで検索可能だと思います。

ファイル自体をデータベースへ保存せずとも、ファイル自体はサーバーのどこかのディレクトリへ保存しておき、データベースへはそのファイルのパスを保存する方が多いかもしれません。

投稿2017/02/15 07:37

編集2017/02/15 07:38
Y.H.

総合スコア7914

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

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

退会済みユーザー

退会済みユーザー

2017/02/15 07:47

サーバのどこかのディレクトリに保存するというのは普通のことなのでしょうか? 例えば、登録しているユーザー数が多くなってしまったときに、大量のデータがサーバのストレージにあるというふうになってしまうわけですが、それはあまり望ましくないように感じるのです。と言いいますのは大量のデータがある場合に、その取り扱いというのはDBMSを使った場合が一番良いと思うからです。
Y.H.

2017/02/15 07:57

「DBMSを使った場合が一番良いと思うからです。」これはサーバーを管理する方(組織/企業)のポリシーによると思うのでどれを選択するかはご自由にとしか言えないです。 Webサーバーのローカル機材(HDD)に保存しなくてもWebサーバーからアクセス可能な別の機材(SANデバイスなど)へ保存してもいいですし(というよりWebサーバーのスケールアウトを考慮するとローカルのHDDへの保存は選択肢から外れますし。)。 「大量のデータがサーバのストレージにある」「大量のデータがDBサーバにある」「大量のデータを保存しておく機材を別に用意する」のうち要件にあるものを選択すればいいと思います。 (バックアップ・リストアやサーバーのスケールアップ/スケールアウトなど考える必要もあるので)
maisumakun

2017/02/15 08:59

いまどきだと、AWS S3のような「ファイルを置くのに特化したサービス」も多数あるので、そういうのに任せてしまう、というのも選択肢の1つかなと思います。
退会済みユーザー

退会済みユーザー

2017/02/16 04:13

データベースシステムに格納することもできるし、データベースにはファイルへのパスを入れておき、別にストレージを用意することもできるとのことですが、それぞれのメリット・デメリットはどのようになるのでしょうか? 私個人的にはデータベースに格納できるのであれば、別にストレージサーバなどを用意しない方がよりシンプルな構成になって、いいのではないかと考えているのですが、パフォーマンス等を考慮した場合、どうなのでしょうか?
maisumakun

2017/02/16 04:24

普通のデータはともかく、Webサイトに画像を表示するような場合は画像を別リクエストで配信することになるので、画像を表示するためのエントリポイントも必要になって、プログラムとしては煩雑になりますし、DBサーバ・アプリサーバの両方で処理が必要になるので、性能的にもあまり有利ではありません(Data URIを使うとキャッシュできないので、よほど小さな画像以外ではおすすめできません)。 ただし、「ファイルが散らからない」という点はメリットなので、「キャッシュサーバが入っていて直接のレスポンスタイムがあまり影響しない」、あるいは「頻繁に画像の更新や削除を行うため、ファイルで管理するのが煩雑になる」というような場合はDB保存も有用です。
Y.H.

2017/02/16 04:38

あとはDBに保存した場合、データベースのバックアップ時間・容量(およびリストア時間)にも多大な影響が出ます。これとDBサーバーの負荷など考慮し許容できるならDBへ格納でもいいんじゃないでしょうか? 画像ファイルのサイズが1枚あたり数十MB以上のものを保存する場合はDBへの保存はお勧めしません。
Y.H.

2017/02/16 04:59

インラインでHTMLに埋め込んで重くならない程度の画像であればDBに保存することはありますね。 viewにそのまま渡せて楽なので:-P <img src="....">
と言うような形でHTML上に表示も出来ます。

2.画像ファイルはファイルとしてサーバに置いておき、ファイルのパスだけDB管理する

ID名前画像ファイルパス
8012寺 ている/images/profile/8012.png
↑のようなテーブルデータで、表示するときはこのパスをimgのsrcに入れればOKです

3.画像ファイルはWEBサーバ以外の倉庫サーバに置いておき、画像のIDだけDB管理する。(倉庫サーバは画像を返答する機能を実装する。)
ブラウザ → WEBサーバ → 倉庫サーバ
<img src="http://倉庫/8012"> ←image/jpeg

投稿2017/02/15 07:43

kunai

総合スコア5405

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

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

退会済みユーザー

退会済みユーザー

2017/02/16 04:13

データベースシステムに格納することもできるし、データベースにはファイルへのパスを入れておき、別にストレージを用意することもできるとのことですが、それぞれのメリット・デメリットはどのようになるのでしょうか? 私個人的にはデータベースに格納できるのであれば、別にストレージサーバなどを用意しない方がよりシンプルな構成になって、いいのではないかと考えているのですが、パフォーマンス等を考慮した場合、どうなのでしょうか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問