{"componentChunkName":"component---src-templates-post-template-js","path":"/posts/what-is-service-class","result":{"data":{"markdownRemark":{"id":"751c6751-561f-507f-a348-8d34ee2af489","html":"<p>アプリケーションの設計で「サービスクラス」というものがしばしば使われますが、その「サービスクラス」が何を指しているのか、状況によって違ったりしないでしょうか？</p>\n<p>この記事では、そんな「サービスクラス」についての私の理解を、3 種類に分けて整理していきます。</p>\n<p>その中で、「サービスクラス」がアンチパターンと言われる理由なども書いていきます。</p>\n<h2 id=\"結論---3-種類の「サービスクラス」\" style=\"position:relative;\"><a href=\"#%E7%B5%90%E8%AB%96---3-%E7%A8%AE%E9%A1%9E%E3%81%AE%E3%80%8C%E3%82%B5%E3%83%BC%E3%83%93%E3%82%B9%E3%82%AF%E3%83%A9%E3%82%B9%E3%80%8D\" aria-label=\"結論   3 種類の「サービスクラス」 permalink\" class=\"anchor before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>結論 - 3 種類の「サービスクラス」</h2>\n<p>最初に結論として、3 種類のサービスクラスについて書いておきます。</p>\n<ol>\n<li>「トランザクションスクリプトパターン」における「サービス」</li>\n<li>「ドメインモデルパターン」における「アプリケーションサービス (= ユースケース)」</li>\n<li>「ドメインモデルパターン」における「ドメインサービス」</li>\n</ol>\n<p>の 3 つです。</p>\n<p>ここから、この 3 パターンを整理するための前提からまとめていきます。</p>\n<h2 id=\"前提---「ビジネスロジック」について\" style=\"position:relative;\"><a href=\"#%E5%89%8D%E6%8F%90---%E3%80%8C%E3%83%93%E3%82%B8%E3%83%8D%E3%82%B9%E3%83%AD%E3%82%B8%E3%83%83%E3%82%AF%E3%80%8D%E3%81%AB%E3%81%A4%E3%81%84%E3%81%A6\" aria-label=\"前提   「ビジネスロジック」について permalink\" class=\"anchor before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>前提 - 「ビジネスロジック」について</h2>\n<h3 id=\"アプリケーションを-3-層に分けて考える\" style=\"position:relative;\"><a href=\"#%E3%82%A2%E3%83%97%E3%83%AA%E3%82%B1%E3%83%BC%E3%82%B7%E3%83%A7%E3%83%B3%E3%82%92-3-%E5%B1%A4%E3%81%AB%E5%88%86%E3%81%91%E3%81%A6%E8%80%83%E3%81%88%E3%82%8B\" aria-label=\"アプリケーションを 3 層に分けて考える permalink\" class=\"anchor before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>アプリケーションを 3 層に分けて考える</h3>\n<p>まず、アプリケーションの役割を 3 層に分けて考えてみます。</p>\n<p>「プレゼンテーション」・「ビジネスロジック」・「データアクセス」の 3 つです。</p>\n<p><img src=\"/media/service-3-tier.png\"></p>\n<p>典型的には、いわゆる「3 層アーキテクチャ」として、例えば以下のようなクラス構成をとったりします。</p>\n<p><img src=\"/media/service-3-tier-classes.png\"></p>\n<p>ただし、ここで言う 3 層に分けて考えるというのは、そうクラス分けするという意味ではないです。</p>\n<p>この 3 種類の役割をまたがったクラスが登場するケースもあります。</p>\n<p>例えば、Ruby on Rails などでよくあるコードでは、以下のような構成になっていたりします。</p>\n<p><img src=\"/media/service-3-tier-rails.png\"></p>\n<h3 id=\"ビジネスロジック層の役割\" style=\"position:relative;\"><a href=\"#%E3%83%93%E3%82%B8%E3%83%8D%E3%82%B9%E3%83%AD%E3%82%B8%E3%83%83%E3%82%AF%E5%B1%A4%E3%81%AE%E5%BD%B9%E5%89%B2\" aria-label=\"ビジネスロジック層の役割 permalink\" class=\"anchor before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>ビジネスロジック層の役割</h3>\n<p>「サービスクラス」に関する議論と関係するのは、上記の 3 層の中の「ビジネスロジック層」の部分です。</p>\n<p><strong>ビジネスロジック層の役割には、大きく以下の 2 つがあります</strong>。</p>\n<ul>\n<li><strong>ユースケースの実現</strong></li>\n<li><strong>コアなルール</strong></li>\n</ul>\n<p>「ユースケースの実現」というのは、例えば「じゃんけんして、その内容を保存して、結果を返す」といった処理の流れです。</p>\n<p>「コアなルール」というのは、じゃんけんで言えば「グーがチョキに勝ち、チョキがパーに勝ち、パーがグーに勝つ」といったルールのことです。</p>\n<p>「コアなルール」は「ドメインロジック」と言われたり、狭い意味でこれを「ビジネスロジック」と呼ぶ場合もあります。</p>\n<p>ビジネスロジックという単語については、<a href=\"https://qiita.com/os1ma/items/25725edfe3c2af93d735\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">こちら</a> の記事にもう少し書かせていただいています。</p>\n<h3 id=\"ビジネスロジックの実装パターン\" style=\"position:relative;\"><a href=\"#%E3%83%93%E3%82%B8%E3%83%8D%E3%82%B9%E3%83%AD%E3%82%B8%E3%83%83%E3%82%AF%E3%81%AE%E5%AE%9F%E8%A3%85%E3%83%91%E3%82%BF%E3%83%BC%E3%83%B3\" aria-label=\"ビジネスロジックの実装パターン permalink\" class=\"anchor before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>ビジネスロジックの実装パターン</h3>\n<p><strong>ビジネスロジックの実装方法には、大きく</strong></p>\n<ul>\n<li><strong>トランザクションスクリプトパターン</strong></li>\n<li><strong>ドメインモデルパターン</strong></li>\n</ul>\n<p><strong>の 2 パターンがあります</strong>。</p>\n<p>それぞれ以下の図のような役割分担になります。</p>\n<p><img src=\"/media/service-transaction-script-vs-domain-model.png\"></p>\n<p>※ ドメインモデルパターンでは、ビジネスロジック層を「アプリケーション層」と「ドメイン層」に分割したりするので、この図でもそのように表現しています。</p>\n<p><strong>このどちらのパターンを使っているかによって、「サービスクラス」の意味が変わります</strong>。</p>\n<h2 id=\"本題---3-種類の「サービスクラス」の整理\" style=\"position:relative;\"><a href=\"#%E6%9C%AC%E9%A1%8C---3-%E7%A8%AE%E9%A1%9E%E3%81%AE%E3%80%8C%E3%82%B5%E3%83%BC%E3%83%93%E3%82%B9%E3%82%AF%E3%83%A9%E3%82%B9%E3%80%8D%E3%81%AE%E6%95%B4%E7%90%86\" aria-label=\"本題   3 種類の「サービスクラス」の整理 permalink\" class=\"anchor before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>本題 - 3 種類の「サービスクラス」の整理</h2>\n<p>それでは、本題の、3 種類の「サービスクラス」について書いていきます。</p>\n<h3 id=\"1-「トランザクションスクリプトパターン」における「サービス」\" style=\"position:relative;\"><a href=\"#1-%E3%80%8C%E3%83%88%E3%83%A9%E3%83%B3%E3%82%B6%E3%82%AF%E3%82%B7%E3%83%A7%E3%83%B3%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%97%E3%83%88%E3%83%91%E3%82%BF%E3%83%BC%E3%83%B3%E3%80%8D%E3%81%AB%E3%81%8A%E3%81%91%E3%82%8B%E3%80%8C%E3%82%B5%E3%83%BC%E3%83%93%E3%82%B9%E3%80%8D\" aria-label=\"1 「トランザクションスクリプトパターン」における「サービス」 permalink\" class=\"anchor before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>1. 「トランザクションスクリプトパターン」における「サービス」</h3>\n<p><strong>トランザクションスクリプトパターンにおける「サービス」は、「ユースケースの実現」と「コアなルール」を両方担うクラス</strong>です。</p>\n<p><img src=\"/media/service-transaction-script.png\"></p>\n<p>よくある 3 層アーキテクチャで見られるもので、単純に「サービスクラス」と言った場合、このパターンを指していることが多いと思います。</p>\n<p>Spring Framework などではこの「サービス」を設けるのが一般的だと思います。\n一方で、Ruby on Rails などでは、典型構成としてはこの「サービス」は使わないことが多く、その役割も Controller に持たせてしまう実装をよく見ます。</p>\n<p>このパターンの欠点は、「サービス」が「ユースケースの実現」と「コアなルール」の両方を持ち、役割が多すぎることです。\nそのため、この「サービス」はアンチパターンと言われることがあります。\nただ、それは「サービス」が悪いというよりも、「トランザクションスクリプトパターン」に起因する問題です。</p>\n<p>「トランザクションスクリプトパターン」には、学習コストが低いというメリットがありますが、デメリットとして Service や Controller が “Fat” になりやすいです。</p>\n<p>Fat Controller の解消法については、<a href=\"https://qiita.com/os1ma/items/66fb47f229896b32b2e8\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">こちら</a> の記事に書かせていただいています。</p>\n<h3 id=\"2-「ドメインモデルパターン」における「アプリケーションサービス」\" style=\"position:relative;\"><a href=\"#2-%E3%80%8C%E3%83%89%E3%83%A1%E3%82%A4%E3%83%B3%E3%83%A2%E3%83%87%E3%83%AB%E3%83%91%E3%82%BF%E3%83%BC%E3%83%B3%E3%80%8D%E3%81%AB%E3%81%8A%E3%81%91%E3%82%8B%E3%80%8C%E3%82%A2%E3%83%97%E3%83%AA%E3%82%B1%E3%83%BC%E3%82%B7%E3%83%A7%E3%83%B3%E3%82%B5%E3%83%BC%E3%83%93%E3%82%B9%E3%80%8D\" aria-label=\"2 「ドメインモデルパターン」における「アプリケーションサービス」 permalink\" class=\"anchor before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>2. 「ドメインモデルパターン」における「アプリケーションサービス」</h3>\n<p>次に、「ドメインモデルパターン」の場合についてです。</p>\n<p>「ドメインモデルパターン」においては、「アプリケーションサービス」と「ドメインサービス」の 2 種類が登場します。</p>\n<p>「アプリケーションサービス」は、「ユースケースの実現」のみを担うクラスで、「コアなルール」は持ちません。</p>\n<p><img src=\"/media/service-domain-model-application-service.png\"></p>\n<p>「アプリケーションサービス」は、別名「ユースケース」と呼ばれます。</p>\n<p>XxxApplicationService といったクラス名よりも XxxUseCase といったクラス名の方が役割がわかりやすいので、UseCase という命名が望ましいかもしれません。</p>\n<p>この「アプリケーションサービス (= ユースケース)」については、特にアンチパターンとは言われていないと思います。</p>\n<p>ただ、Rails などを使う場合は、この「アプリケーションサービス」の役割は Controller に持たせてしまうのも一つの手だと思います。</p>\n<h3 id=\"3-「ドメインモデルパターン」における「ドメインサービス」\" style=\"position:relative;\"><a href=\"#3-%E3%80%8C%E3%83%89%E3%83%A1%E3%82%A4%E3%83%B3%E3%83%A2%E3%83%87%E3%83%AB%E3%83%91%E3%82%BF%E3%83%BC%E3%83%B3%E3%80%8D%E3%81%AB%E3%81%8A%E3%81%91%E3%82%8B%E3%80%8C%E3%83%89%E3%83%A1%E3%82%A4%E3%83%B3%E3%82%B5%E3%83%BC%E3%83%93%E3%82%B9%E3%80%8D\" aria-label=\"3 「ドメインモデルパターン」における「ドメインサービス」 permalink\" class=\"anchor before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>3. 「ドメインモデルパターン」における「ドメインサービス」</h3>\n<p>ドメインモデルパターンにおいては、「コアなルール」はできるだけデータを持つクラスのメソッドとして実装します。</p>\n<p>しかし、どうしてもどのクラスに持たせてもしっくりこない処理が発生するケースがあります。</p>\n<p>そういった状況で<strong>「コアなルール」の一部を実装するクラスが「ドメインサービス」</strong>です。</p>\n<p><img src=\"/media/service-domain-model-domain-service.png\"></p>\n<p>このクラスには「サービス」という名前がついておらず、そのクラスの役割に応じた適切な名前がつけられる場合もあります。</p>\n<p>この「ドメインサービス」については、使いすぎはアンチパターンであり、できるだけ、データを持つ「モデル」に処理も持たせてあげるべきと言われます。</p>\n<p>なお、トランザクションスクリプトパターンであっても、「サービス」や「コントローラ」間で共通の処理を切り出す先のクラスとして「ドメインサービス」のようなクラスが利用されるケースもあります。</p>\n<h2 id=\"おわりに\" style=\"position:relative;\"><a href=\"#%E3%81%8A%E3%82%8F%E3%82%8A%E3%81%AB\" aria-label=\"おわりに permalink\" class=\"anchor before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>おわりに</h2>\n<p>以上、「サービスクラス」について私の理解を整理してみました。</p>\n<p>この記事では色々な用語を使って整理してきましたが、用語の定義は人によって違うことが少なくありません。\nその点はご注意ください。</p>\n<p>認識合わせのために用語の定義を合わせるのも大事ですが、設計という観点で重要なのは「<strong>そのクラスの役割は何なのか</strong>」だと思います。</p>\n<p>また、個人的に、「サービスクラス」は特にアンチパターンとは考えていないです。\nポイントは<strong>役割の多すぎるクラスを作らない</strong>ことで、その解消のために「サービスクラス」が役立つのであれば、取り入れるべきだと思います。</p>\n<p>最後になりますが、こちらの記事の内容は、私が見たことのある範囲のまとめになります。\nご指摘などあれば、<a href=\"https://twitter.com/oshima_123\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">Twitter</a> などで教えていただけると嬉しいです。</p>\n<h2 id=\"参考書籍\" style=\"position:relative;\"><a href=\"#%E5%8F%82%E8%80%83%E6%9B%B8%E7%B1%8D\" aria-label=\"参考書籍 permalink\" class=\"anchor before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>参考書籍</h2>\n<ul>\n<li><a href=\"https://amzn.to/3FeJ4yy\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">エンタープライズアプリケーションアーキテクチャパターン</a></li>\n<li><a href=\"https://amzn.to/3eOykZa\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">エリック・エヴァンスのドメイン駆動設計</a></li>\n<li><a href=\"https://amzn.to/2ZNetFR\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">実践ドメイン駆動設計</a></li>\n<li><a href=\"https://amzn.to/3cmseB2\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">．ＮＥＴのエンタープライズアプリケーションアーキテクチャ　第２版</a></li>\n<li><a href=\"https://amzn.to/30DYXLI\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">Clean Architecture</a></li>\n<li><a href=\"https://amzn.to/3AeR0MK\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">ドメイン駆動設計入門 ボトムアップでわかる！ドメイン駆動設計の基本</a></li>\n<li><a href=\"https://amzn.to/32GGu3p\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">「実践ドメイン駆動設計」から学ぶDDDの実装入門</a></li>\n</ul>\n<p><a href=\"https://www.amazon.co.jp/dp/B01B5MX2O2?&linkCode=li1&tag=oshimayuki0d-22&linkId=7884eecb4f77a09490554e5e80b05ab9&language=ja_JP&ref_=as_li_ss_il\" target=\"_blank\"><img border=\"0\" src=\"//ws-fe.amazon-adsystem.com/widgets/q?_encoding=UTF8&ASIN=B01B5MX2O2&Format=_SL110_&ID=AsinImage&MarketPlace=JP&ServiceVersion=20070822&WS=1&tag=oshimayuki0d-22&language=ja_JP\" ></a><img src=\"https://ir-jp.amazon-adsystem.com/e/ir?t=oshimayuki0d-22&amp;language=ja_JP&amp;l=li1&amp;o=9&amp;a=B01B5MX2O2\" width=\"1\" height=\"1\" border=\"0\" alt=\"\" style=\"border:none !important; margin:0px !important;\"></p>\n<p><a href=\"https://www.amazon.co.jp/dp/B00GRKD6XU?&linkCode=li1&tag=oshimayuki0d-22&linkId=e5bebe195262dc16be2ef0186c837ceb&language=ja_JP&ref_=as_li_ss_il\" target=\"_blank\"><img border=\"0\" src=\"//ws-fe.amazon-adsystem.com/widgets/q?_encoding=UTF8&ASIN=B00GRKD6XU&Format=_SL110_&ID=AsinImage&MarketPlace=JP&ServiceVersion=20070822&WS=1&tag=oshimayuki0d-22&language=ja_JP\" ></a><img src=\"https://ir-jp.amazon-adsystem.com/e/ir?t=oshimayuki0d-22&amp;language=ja_JP&amp;l=li1&amp;o=9&amp;a=B00GRKD6XU\" width=\"1\" height=\"1\" border=\"0\" alt=\"\" style=\"border:none !important; margin:0px !important;\"></p>\n<p><a href=\"https://www.amazon.co.jp/dp/B00UX9VJGW?&linkCode=li1&tag=oshimayuki0d-22&linkId=fd4e4e0245294231d9b486e262c64c1d&language=ja_JP&ref_=as_li_ss_il\" target=\"_blank\"><img border=\"0\" src=\"//ws-fe.amazon-adsystem.com/widgets/q?_encoding=UTF8&ASIN=B00UX9VJGW&Format=_SL110_&ID=AsinImage&MarketPlace=JP&ServiceVersion=20070822&WS=1&tag=oshimayuki0d-22&language=ja_JP\" ></a><img src=\"https://ir-jp.amazon-adsystem.com/e/ir?t=oshimayuki0d-22&amp;language=ja_JP&amp;l=li1&amp;o=9&amp;a=B00UX9VJGW\" width=\"1\" height=\"1\" border=\"0\" alt=\"\" style=\"border:none !important; margin:0px !important;\"></p>\n<p><a href=\"https://www.amazon.co.jp/dp/4822298485?&linkCode=li1&tag=oshimayuki0d-22&linkId=1f5d033f39a39b8b5125d5e9a06df697&language=ja_JP&ref_=as_li_ss_il\" target=\"_blank\"><img border=\"0\" src=\"//ws-fe.amazon-adsystem.com/widgets/q?_encoding=UTF8&ASIN=4822298485&Format=_SL110_&ID=AsinImage&MarketPlace=JP&ServiceVersion=20070822&WS=1&tag=oshimayuki0d-22&language=ja_JP\" ></a><img src=\"https://ir-jp.amazon-adsystem.com/e/ir?t=oshimayuki0d-22&amp;language=ja_JP&amp;l=li1&amp;o=9&amp;a=4822298485\" width=\"1\" height=\"1\" border=\"0\" alt=\"\" style=\"border:none !important; margin:0px !important;\"></p>\n<p><a href=\"https://www.amazon.co.jp/dp/B07FSBHS2V?&linkCode=li1&tag=oshimayuki0d-22&linkId=d5fa680059a8d97efd390bb0072f4ad1&language=ja_JP&ref_=as_li_ss_il\" target=\"_blank\"><img border=\"0\" src=\"//ws-fe.amazon-adsystem.com/widgets/q?_encoding=UTF8&ASIN=B07FSBHS2V&Format=_SL110_&ID=AsinImage&MarketPlace=JP&ServiceVersion=20070822&WS=1&tag=oshimayuki0d-22&language=ja_JP\" ></a><img src=\"https://ir-jp.amazon-adsystem.com/e/ir?t=oshimayuki0d-22&amp;language=ja_JP&amp;l=li1&amp;o=9&amp;a=B07FSBHS2V\" width=\"1\" height=\"1\" border=\"0\" alt=\"\" style=\"border:none !important; margin:0px !important;\"></p>\n<p><a href=\"https://www.amazon.co.jp/dp/B082WXZVPC?&linkCode=li1&tag=oshimayuki0d-22&linkId=d41efaf2049af2e64b3cd75cd7802cb5&language=ja_JP&ref_=as_li_ss_il\" target=\"_blank\"><img border=\"0\" src=\"//ws-fe.amazon-adsystem.com/widgets/q?_encoding=UTF8&ASIN=B082WXZVPC&Format=_SL110_&ID=AsinImage&MarketPlace=JP&ServiceVersion=20070822&WS=1&tag=oshimayuki0d-22&language=ja_JP\" ></a><img src=\"https://ir-jp.amazon-adsystem.com/e/ir?t=oshimayuki0d-22&amp;language=ja_JP&amp;l=li1&amp;o=9&amp;a=B082WXZVPC\" width=\"1\" height=\"1\" border=\"0\" alt=\"\" style=\"border:none !important; margin:0px !important;\"></p>\n<p><a href=\"https://www.amazon.co.jp/dp/B07S675HVM?&linkCode=li1&tag=oshimayuki0d-22&linkId=2ea832e09e739b30f288416d5eb39d98&language=ja_JP&ref_=as_li_ss_il\" target=\"_blank\"><img border=\"0\" src=\"//ws-fe.amazon-adsystem.com/widgets/q?_encoding=UTF8&ASIN=B07S675HVM&Format=_SL110_&ID=AsinImage&MarketPlace=JP&ServiceVersion=20070822&WS=1&tag=oshimayuki0d-22&language=ja_JP\" ></a><img src=\"https://ir-jp.amazon-adsystem.com/e/ir?t=oshimayuki0d-22&amp;language=ja_JP&amp;l=li1&amp;o=9&amp;a=B07S675HVM\" width=\"1\" height=\"1\" border=\"0\" alt=\"\" style=\"border:none !important; margin:0px !important;\"></p>\n<h2 id=\"関連記事\" style=\"position:relative;\"><a href=\"#%E9%96%A2%E9%80%A3%E8%A8%98%E4%BA%8B\" aria-label=\"関連記事 permalink\" class=\"anchor before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>関連記事</h2>\n<p>以下、自分が過去に書いた関連記事です。</p>\n<ul>\n<li><a href=\"https://qiita.com/os1ma/items/7a229585ebdd8b7d86c2\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">MVC、3 層アーキテクチャから設計を学び始めるための基礎知識</a></li>\n<li><a href=\"https://qiita.com/os1ma/items/25725edfe3c2af93d735\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">「ビジネスロジック」とは何か、どう実装するのか</a></li>\n<li><a href=\"https://qiita.com/os1ma/items/66fb47f229896b32b2e8\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">「Controller にビジネスロジックを書くな」の対応パターン</a></li>\n</ul>","fields":{"slug":"/posts/what-is-service-class","tagSlugs":["/tag/architecture/","/tag/ddd/"],"autoRecommendPosts":["data-access-patterns","linux-learning-roadmap","ddd-books","cpu-books"]},"frontmatter":{"date":"2021-10-06T08:25:54.594Z","description":"アプリケーションの設計で「サービスクラス」というものがしばしば使われますが、その「サービスクラス」が何を指しているのか、状況によって違ったりしないでしょうか？\nこの記事では、そんな「サービスクラス」についての私の理解を、3 種類に分けて整理していきます。\nその中で、「サービスクラス」がアンチパターンと言われる理由なども書いていきます。","tags":["architecture","ddd"],"title":"「サービスクラス」は 3 種類ある","socialImage":null,"recommendPosts":null}}},"pageContext":{"slug":"/posts/what-is-service-class"}},"staticQueryHashes":["251939775","3942705351","401334301"]}