{"id":11313,"date":"2025-07-08T09:52:34","date_gmt":"2025-07-08T00:52:34","guid":{"rendered":"https:\/\/www.moonmile.net\/blog\/?p=11313"},"modified":"2025-07-09T09:56:49","modified_gmt":"2025-07-09T00:56:49","slug":"asp-net-minimail-%e3%82%92-docker-%e5%af%be%e5%bf%9c%e3%81%97%e3%81%a6%e3%80%81azure-%e3%81%ab-up-%e3%81%99%e3%82%8b%e3%81%be%e3%81%a7-%e3%81%84%e3%81%8b%e3%81%9a","status":"publish","type":"post","link":"http:\/\/www.moonmile.net\/blog\/archives\/11313","title":{"rendered":"asp.net minimal \u3092 Docker \u5bfe\u5fdc\u3057\u3066\u3001azure \u306b up \u3059\u308b\u307e\u3067&#8230;\u3044\u304b\u305a"},"content":{"rendered":"\n<p>asp.net minimal \u3092\u30ed\u30fc\u30ab\u30eb\u74b0\u5883\u3067\u306a\u304f Azure \u3067\u52d5\u4f5c\u3067\u304d\u308b\u3088\u3046\u306b\u3057\u307e\u3059\u3002\u3072\u3068\u307e\u305a\u3001Docker \u5316\u3057\u3066\u304a\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Dockerfile \u3092\u4f5c\u308b<\/h2>\n\n\n\n<pre class=\"wp-block-preformatted\">aspnet-minimal-sample \u306e Dockerfile \u3092\u66f8\u3044\u3066\u3002<\/pre>\n\n\n\n<figure class=\"wp-block-image size-large\"><a href=\"https:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-86.png\"><img loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"591\" src=\"https:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-86-1024x591.png\" alt=\"\" class=\"wp-image-11314\" srcset=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-86-1024x591.png 1024w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-86-300x173.png 300w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-86-768x443.png 768w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-86.png 1188w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/a><\/figure>\n\n\n\n<p>\u6bce\u5ea6\u3001Docker \u30d5\u30a1\u30a4\u30eb\u3092\u4f5c\u308b\u306e\u304c\u9762\u5012\u306a\u306e\u3067\u3001\u4f5c\u3063\u3066\u304f\u308c\u308b\u306e\u306f\u3042\u308a\u304c\u305f\u3044\u3002<\/p>\n\n\n\n<p>mysql \u3082\u4f7f\u3046\u306e\u3067 docker-compose.yml \u3082\u6b21\u3044\u3067\u306b\u4f5c\u3063\u3066\u304f\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<p>Dockerfile<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code># ASP.NET Minimal API Dockerfile\n\n# Build stage\nFROM mcr.microsoft.com\/dotnet\/sdk:9.0 AS build\nWORKDIR \/src\n\n# Copy csproj and restore dependencies\nCOPY *.csproj .\/\nRUN dotnet restore\n\n# Copy everything else and build\nCOPY . .\/\nRUN dotnet publish -c Release -o \/app\/publish\n\n# Runtime stage\nFROM mcr.microsoft.com\/dotnet\/aspnet:9.0 AS runtime\nWORKDIR \/app\n\n# Copy published files\nCOPY --from=build \/app\/publish .\n\n# Copy static files (wwwroot)\nCOPY --from=build \/src\/wwwroot .\/wwwroot\n\n# Create a non-root user\nRUN adduser --disabled-password --gecos &#39;&#39; appuser && chown -R appuser \/app\nUSER appuser\n\n# Expose port\nEXPOSE 8000\n\n# Set environment variables\nENV ASPNETCORE_URLS=http:\/\/+:8000\nENV ASPNETCORE_ENVIRONMENT=Production\n\n# Entry point\nENTRYPOINT [&quot;dotnet&quot;, &quot;aspnet-minimal-sample.dll&quot;]\n<\/code><\/pre><\/div>\n\n\n\n<p>docker-compose.yml<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>version: &#39;3.8&#39;\n\nservices:\n  # MySQL Database\n  mysql:\n    image: mysql:8.0\n    container_name: mos-mysql\n    environment:\n      MYSQL_ROOT_PASSWORD: root\n      MYSQL_DATABASE: mos\n      MYSQL_USER: mos\n      MYSQL_PASSWORD: mos\n    ports:\n      - &quot;3306:3306&quot;\n    volumes:\n      - mysql_data:\/var\/lib\/mysql\n      - .\/database\/init:\/docker-entrypoint-initdb.d\n    networks:\n      - mos-network\n    healthcheck:\n      test: [&quot;CMD&quot;, &quot;mysqladmin&quot;, &quot;ping&quot;, &quot;-h&quot;, &quot;localhost&quot;]\n      timeout: 20s\n      retries: 10\n\n  # ASP.NET Web API\n  webapi:\n    build:\n      context: .\n      dockerfile: Dockerfile\n    container_name: mos-webapi\n    ports:\n      - &quot;8000:8000&quot;\n    environment:\n      - ASPNETCORE_ENVIRONMENT=Production\n      - ConnectionStrings__DefaultConnection=Server=mysql;Database=mos;User=mos;Password=mos;\n    depends_on:\n      mysql:\n        condition: service_healthy\n    networks:\n      - mos-network\n    volumes:\n      - .\/wwwroot\/images:\/app\/wwwroot\/images\n\nvolumes:\n  mysql_data:\n\nnetworks:\n  mos-network:\n    driver: bridge\n<\/code><\/pre><\/div>\n\n\n\n<p><\/p>\n\n\n\n<p>\u3044\u307e\u3069\u304d\u3001Dockerfile \u3084 docker-compose.yml \u3092\u4e00\u304b\u3089\u4f5c\u308b\u3053\u3068\u306f\u306a\u304f\u3066\u3001\u5927\u4f53\u304c\u4f3c\u305f\u3088\u3046\u306a\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u304b\u3089\u30b3\u30d4\u30fc\u3057\u3066\u5c11\u3057\u4fee\u6b63\u3059\u308b\u3050\u3089\u3044\u306a\u306e\u3067\u3001\u305d\u306e\u5143\u30cd\u30bf\u304c Claude \u7531\u6765\u3063\u3066\u3068\u3053\u308d\u3067\u3057\u3087\u3046\u304b\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u30d5\u30a1\u30a4\u30eb\u3092\u4f5c\u308b<\/h2>\n\n\n\n<pre class=\"wp-block-preformatted\">mysql \u306b categories \u30c6\u30fc\u30d6\u30eb\u7b49\u3092\u4f5c\u6210\u3059\u308b\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u7528\u306e\u30b3\u30fc\u30c9\u3092\u4f5c\u6210\u3057\u3066\u3002<\/pre>\n\n\n\n<p>\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u3092 Docker \u5185\u306b\u69cb\u7bc9\u3059\u308b\u306e\u3067\u3001\u30c6\u30fc\u30d6\u30eb\u5b9a\u7fa9\u304b\u3089\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u7528\u306e\u30b3\u30fc\u30c9\u3092\u751f\u6210\u3057\u307e\u3059\u3002\u4ee5\u524d\u306a\u3089\u3070\u3001\u4f55\u3089\u304b\u306e\u30c4\u30fc\u30eb\u304b\u624b\u4f5c\u696d\u3067\u4f5c\u6210\u3059\u308b\u3068\u3053\u308d\u3067\u3059\u304c\u3001\u3053\u308c\u3082\u4e00\u6c17\u306b\u4f5c\u3063\u3066\u304f\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<figure class=\"wp-block-image size-large\"><a href=\"https:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-87.png\"><img loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"729\" src=\"https:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-87-1024x729.png\" alt=\"\" class=\"wp-image-11315\" srcset=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-87-1024x729.png 1024w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-87-300x214.png 300w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-87-768x547.png 768w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-87.png 1191w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/a><\/figure>\n\n\n\n<p>Seeder \u306e\u30b5\u30f3\u30d7\u30eb\u3082\u4f5c\u3063\u3066\u304f\u308c\u3066\u3001\u4e01\u5be7\u306b\u3082 readme.md \u306b\u30c4\u30fc\u30eb\u306e\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u304c\u751f\u6210\u3055\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<p>README.md<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code># ASP.NET Core Minimal API with MySQL - \u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u7ba1\u7406\n\n\u3053\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306f\u3001Entity Framework Core\u3092\u4f7f\u7528\u3057\u3066MySQL\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u3068\u306e\u9023\u643a\u3092\u884c\u3044\u307e\u3059\u3002\n\n## \u524d\u63d0\u6761\u4ef6\n\n- .NET 9.0\n- MySQL 8.0\u4ee5\u964d\n- Entity Framework Core Tools\n\n## \u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u8a2d\u5b9a\n\n### 1. \u63a5\u7d9a\u6587\u5b57\u5217\u306e\u8a2d\u5b9a\n\n`appsettings.json`\u307e\u305f\u306f`appsettings.Development.json`\u3067\u63a5\u7d9a\u6587\u5b57\u5217\u3092\u8a2d\u5b9a\u3057\u3066\u304f\u3060\u3055\u3044\uff1a\n\n```json\n{\n  &quot;ConnectionStrings&quot;: {\n    &quot;DefaultConnection&quot;: &quot;Server=localhost;Database=mos;User=root;Password=your_password;Port=3306;&quot;\n  }\n}\n```\n\n### 2. \u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u306e\u7ba1\u7406\n\n#### PowerShell\uff08Windows\uff09\n\n```powershell\n# \u521d\u671f\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u3092\u4f5c\u6210\n.\\migrate.ps1 init\n\n# \u65b0\u3057\u3044\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u3092\u4f5c\u6210\n.\\migrate.ps1 add &quot;AddNewTable&quot;\n\n# \u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u3092\u6700\u65b0\u306e\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u306b\u66f4\u65b0\n.\\migrate.ps1 update\n\n# \u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u306e\u72b6\u614b\u3092\u78ba\u8a8d\n.\\migrate.ps1 status\n\n# \u521d\u671f\u30c7\u30fc\u30bf\u3092\u6295\u5165\n.\\migrate.ps1 seed\n\n# \u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u3092\u30ea\u30bb\u30c3\u30c8\uff08\u5371\u967a\uff09\n.\\migrate.ps1 reset\n```\n\n#### Bash\uff08Linux\/Mac\uff09\n\n```bash\n# \u521d\u671f\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u3092\u4f5c\u6210\n.\/migrate.sh init\n\n# \u65b0\u3057\u3044\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u3092\u4f5c\u6210\n.\/migrate.sh add &quot;AddNewTable&quot;\n\n# \u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u3092\u6700\u65b0\u306e\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u306b\u66f4\u65b0\n.\/migrate.sh update\n\n# \u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u306e\u72b6\u614b\u3092\u78ba\u8a8d\n.\/migrate.sh status\n\n# \u521d\u671f\u30c7\u30fc\u30bf\u3092\u6295\u5165\n.\/migrate.sh seed\n\n# \u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u3092\u30ea\u30bb\u30c3\u30c8\uff08\u5371\u967a\uff09\n.\/migrate.sh reset\n```\n\n#### \u624b\u52d5\u3067\u306eEntity Framework Core\u30b3\u30de\u30f3\u30c9\n\n```bash\n# \u521d\u671f\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u3092\u4f5c\u6210\ndotnet ef migrations add InitialCreate\n\n# \u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u3092\u66f4\u65b0\ndotnet ef database update\n\n# \u521d\u671f\u30c7\u30fc\u30bf\u3092\u6295\u5165\ndotnet run -- --seed\n\n# \u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u306e\u72b6\u614b\u3092\u78ba\u8a8d\ndotnet ef migrations list\n\n# \u7279\u5b9a\u306e\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u306b\u79fb\u884c\ndotnet ef database update TargetMigration\n\n# \u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u3092\u524a\u9664\ndotnet ef database drop\n```\n\n## \u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u30d5\u30a1\u30a4\u30eb\u306e\u69cb\u6210\n\n### \u81ea\u52d5\u751f\u6210\u3055\u308c\u308b\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\n\nEntity Framework Core\u306f\u3001\u30e2\u30c7\u30eb\u306e\u5909\u66f4\u3092\u691c\u51fa\u3057\u3066\u81ea\u52d5\u7684\u306b\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u3092\u4f5c\u6210\u3057\u307e\u3059\uff1a\n\n- `Migrations\/[timestamp]_InitialCreate.cs`: \u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u306e\u5b9f\u884c\u5185\u5bb9\n- `Migrations\/[timestamp]_InitialCreate.Designer.cs`: EF Core\u306e\u30e1\u30bf\u30c7\u30fc\u30bf\n- `Migrations\/AppDbContextModelSnapshot.cs`: \u73fe\u5728\u306e\u30e2\u30c7\u30eb\u306e\u30b9\u30ca\u30c3\u30d7\u30b7\u30e7\u30c3\u30c8\n\n### \u624b\u52d5\u3067\u306eSQL\u5b9f\u884c\n\n\u624b\u52d5\u3067SQL\u3092\u5b9f\u884c\u3059\u308b\u5834\u5408\u306f\u3001`database\/init\/01_create_tables.sql`\u3092\u4f7f\u7528\u3067\u304d\u307e\u3059\uff1a\n\n```sql\n-- MySQL\u306b\u76f4\u63a5\u63a5\u7d9a\u3057\u3066\u5b9f\u884c\nmysql -u root -p mos &lt; database\/init\/01_create_tables.sql\n```\n\n## \u521d\u671f\u30c7\u30fc\u30bf\u306b\u3064\u3044\u3066\n\n### \u81ea\u52d5\u6295\u5165\u3055\u308c\u308b\u521d\u671f\u30c7\u30fc\u30bf\n\n`Services\/DatabaseSeeder.cs`\u3067\u4ee5\u4e0b\u306e\u30c7\u30fc\u30bf\u304c\u81ea\u52d5\u6295\u5165\u3055\u308c\u307e\u3059\uff1a\n\n- **\u30ab\u30c6\u30b4\u30ea**: 4\u4ef6\uff08\u30b3\u30fc\u30d2\u30fc\u3001\u7d05\u8336\u30fb\u30c6\u30a3\u30fc\u3001\u30d5\u30fc\u30c9\u3001\u5b63\u7bc0\u9650\u5b9a\uff09\n- **\u5546\u54c1**: 12\u4ef6\uff08\u5404\u30ab\u30c6\u30b4\u30ea\u306e\u4ee3\u8868\u7684\u306a\u5546\u54c1\uff09\n- **\u6ce8\u6587**: 2\u4ef6\uff08\u30b5\u30f3\u30d7\u30eb\u6ce8\u6587\u30c7\u30fc\u30bf\uff09\n- **\u6ce8\u6587\u5546\u54c1**: \u95a2\u9023\u3059\u308b\u6ce8\u6587\u5546\u54c1\u30c7\u30fc\u30bf\n\n### \u521d\u671f\u30c7\u30fc\u30bf\u306e\u6295\u5165\n\n```bash\n# \u521d\u671f\u30c7\u30fc\u30bf\u3092\u6295\u5165\ndotnet run -- --seed\n\n# \u307e\u305f\u306f PowerShell\n.\\migrate.ps1 seed\n\n# \u307e\u305f\u306f Bash\n.\/migrate.sh seed\n```\n\n## Docker\u74b0\u5883\u3067\u306e\u4f7f\u7528\n\nDocker\u74b0\u5883\u3067\u306f\u3001\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306e\u521d\u671f\u5316\u304c\u81ea\u52d5\u3067\u884c\u308f\u308c\u307e\u3059\uff1a\n\n```bash\n# \u958b\u767a\u74b0\u5883\u306e\u8d77\u52d5\ndocker-compose -f docker-compose.dev.yml up\n\n# \u672c\u756a\u74b0\u5883\u306e\u8d77\u52d5\ndocker-compose up\n```\n\n## \u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\n\n### \u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u30a8\u30e9\u30fc\n\n```bash\n# \u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u3092\u30ea\u30bb\u30c3\u30c8\ndotnet ef migrations remove\n\n# \u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u3092\u524a\u9664\u3057\u3066\u518d\u4f5c\u6210\ndotnet ef database drop\ndotnet ef database update\n```\n\n### \u63a5\u7d9a\u30a8\u30e9\u30fc\n\n1. MySQL \u30b5\u30fc\u30d0\u30fc\u304c\u8d77\u52d5\u3057\u3066\u3044\u308b\u3053\u3068\u3092\u78ba\u8a8d\n2. \u63a5\u7d9a\u6587\u5b57\u5217\u304c\u6b63\u3057\u3044\u3053\u3068\u3092\u78ba\u8a8d\n3. \u30c7\u30fc\u30bf\u30d9\u30fc\u30b9 `mos` \u304c\u5b58\u5728\u3059\u308b\u3053\u3068\u3092\u78ba\u8a8d\n\n### \u30d1\u30c3\u30b1\u30fc\u30b8\u30a8\u30e9\u30fc\n\n```bash\n# \u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u5fa9\u5143\ndotnet restore\n\n# \u30ad\u30e3\u30c3\u30b7\u30e5\u3092\u30af\u30ea\u30a2\ndotnet nuget locals all --clear\n```\n\n## API \u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\n\n\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u5f8c\u3001\u4ee5\u4e0b\u306eAPI\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u304c\u5229\u7528\u53ef\u80fd\u306b\u306a\u308a\u307e\u3059\uff1a\n\n- `GET \/mos\/api\/categories` - \u30ab\u30c6\u30b4\u30ea\u4e00\u89a7\n- `GET \/mos\/api\/products` - \u5546\u54c1\u4e00\u89a7\n- `GET \/mos\/api\/orders` - \u6ce8\u6587\u4e00\u89a7\n- `POST \/mos\/api\/orders` - \u6ce8\u6587\u4f5c\u6210\n\n\u8a73\u7d30\u306a\u4ed5\u69d8\u306b\u3064\u3044\u3066\u306f\u3001`webapi\/mos-api.yaml`\u3092\u53c2\u7167\u3057\u3066\u304f\u3060\u3055\u3044\u3002\n<\/code><\/pre><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">DatabaseSeeder.cs \u3092\u66f8\u304d\u5909\u3048\u308b<\/h2>\n\n\n\n<p>\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306b\u6295\u5165\u3059\u308b\u521d\u671f\u5024\u306f DatabaseSeeder.cs \u306b\u66f8\u304b\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-csharp\" data-lang=\"C#\"><code>using aspnet_minimal_sample.Data;\nusing aspnet_minimal_sample.Models;\nusing Microsoft.EntityFrameworkCore;\n\nnamespace aspnet_minimal_sample.Services;\n\npublic class DatabaseSeeder\n{\n    private readonly AppDbContext _context;\n\n    public DatabaseSeeder(AppDbContext context)\n    {\n        _context = context;\n    }\n\n    public async Task SeedAsync()\n    {\n        \/\/ \u65e2\u5b58\u306e\u30c7\u30fc\u30bf\u304c\u3042\u308b\u5834\u5408\u306f\u30b9\u30ad\u30c3\u30d7\n        if (await _context.Categories.AnyAsync())\n        {\n            Console.WriteLine(&quot;\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306b\u306f\u65e2\u306b\u30c7\u30fc\u30bf\u304c\u5b58\u5728\u3057\u307e\u3059\u3002\u521d\u671f\u30c7\u30fc\u30bf\u306e\u6295\u5165\u3092\u30b9\u30ad\u30c3\u30d7\u3057\u307e\u3059\u3002&quot;);\n            return;\n        }\n\n        Console.WriteLine(&quot;\u521d\u671f\u30c7\u30fc\u30bf\u3092\u6295\u5165\u4e2d...&quot;);\n\n        \/\/ \u30ab\u30c6\u30b4\u30ea\u306e\u521d\u671f\u30c7\u30fc\u30bf\n        var categories = new List&lt;Category&gt;\n        {\n            new Category\n            {\n                Slug = &quot;coffee&quot;,\n                Title = &quot;\u30b3\u30fc\u30d2\u30fc&quot;,\n                Description = &quot;\u53b3\u9078\u3055\u308c\u305f\u30b3\u30fc\u30d2\u30fc\u8c46\u3092\u4f7f\u7528\u3057\u305f\u30c9\u30ea\u30f3\u30af&quot;,\n                Image = &quot;\/images\/categories\/coffee.jpg&quot;,\n                SortId = 1,\n                Display = 1\n            },\n            new Category\n            {\n                Slug = &quot;tea&quot;,\n                Title = &quot;\u7d05\u8336\u30fb\u30c6\u30a3\u30fc&quot;,\n                Description = &quot;\u4e16\u754c\u5404\u5730\u304b\u3089\u53b3\u9078\u3055\u308c\u305f\u7d05\u8336\u3068\u30cf\u30fc\u30d6\u30c6\u30a3\u30fc&quot;,\n                Image = &quot;\/images\/categories\/tea.jpg&quot;,\n                SortId = 2,\n                Display = 1\n            },\n            new Category\n            {\n                Slug = &quot;food&quot;,\n                Title = &quot;\u30d5\u30fc\u30c9&quot;,\n                Description = &quot;\u8efd\u98df\u3084\u30c7\u30b6\u30fc\u30c8\u306a\u3069\u3001\u304a\u98f2\u307f\u7269\u3068\u4e00\u7dd2\u306b\u304a\u697d\u3057\u307f\u304f\u3060\u3055\u3044&quot;,\n                Image = &quot;\/images\/categories\/food.jpg&quot;,\n                SortId = 3,\n                Display = 1\n            },<\/code><\/pre><\/div>\n\n\n\n<p>\u3061\u307e\u3061\u307e\u66f8\u304d\u5909\u3048\u3066\u3082\u3044\u3044\u306e\u3067\u3059\u304c\u3001\u65e2\u306b laravel-webapi-sample \u3067 CategorySeeder.php \u3068 ProductSeeder.php \u304c\u66f8\u304b\u308c\u3066\u3044\u308b\u306e\u3067\u3001\u3053\u308c\u3092\u6d41\u7528\u3057\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<pre class=\"wp-block-preformatted\">laravel-webapi-sample \u306e ProductSeeder \u3068 CategorySeeder \u304c\u3042\u308b\u306e\u3067\u3001<br>\u3053\u308c\u3092\u4f7f\u3063\u3066 aspnet-minimal-sample \u306e DatabaseSeeder \u306e\u30c7\u30fc\u30bf\u3092\u66f8\u304d\u5909\u3048\u3066\u3002<\/pre>\n\n\n\n<p>PHP \u306e\u30b3\u30fc\u30c9\u304b\u3089 C# \u306e\u30b3\u30fc\u30c9\u306b\u66f8\u304d\u5909\u3048\u308b\u3060\u3051\u306a\u306e\u3067\u3001Copilot + Claude Sonnet \u306e\u5f97\u610f\u3068\u3059\u308b\u3068\u3053\u308d\u3067\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<p>\u30b3\u30f3\u30d0\u30fc\u30c8\u304c\u51fa\u6765\u3066\u4e00\u898b\u3067\u304d\u3066\u3044\u308b\u3088\u3046\u306b\u898b\u3048\u307e\u3059\u304c\u3001CategoryId\u306e\u5024\u304c\u56fa\u5b9a\u306b\u306a\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-csharp\" data-lang=\"C#\"><code>        \/\/ \u5546\u54c1\u306e\u521d\u671f\u30c7\u30fc\u30bf\n        var products = new List&lt;Product&gt;\n        {\n            \/\/ \u30cf\u30f3\u30d0\u30fc\u30ac\u30fc\n            new Product\n            {\n                CategoryId = categories[4].Id, \/\/ \u30cf\u30f3\u30d0\u30fc\u30ac\u30fc\n                Slug = &quot;burger1&quot;,\n                Name = &quot;\u30e2\u30b9\u30d0\u30fc\u30ac\u30fc&quot;,\n                Description = &quot;&quot;,\n                Image = &quot;burger1.jpg&quot;,\n                Price = 440,\n                SortId = 1,\n                Display = 1\n            },\n            new Product\n            {\n                CategoryId = categories[4].Id, \/\/ \u30cf\u30f3\u30d0\u30fc\u30ac\u30fc\n                Slug = &quot;burger2&quot;,\n                Name = &quot;\u30e2\u30b9\u30c1\u30fc\u30ba\u30d0\u30fc\u30ac\u30fc&quot;,\n                Description = &quot;&quot;,\n                Image = &quot;burger2.jpg&quot;,\n                Price = 480,\n                SortId = 2,\n                Display = 1\n            },\n<\/code><\/pre><\/div>\n\n\n\n<p>\u5b9f\u306f\u3001\u30ab\u30c6\u30b4\u30ea\u306f\u3042\u3061\u3053\u3061\u306b\u5272\u308a\u632f\u3089\u308c\u308b\u3088\u3046\u306b\u30e9\u30f3\u30c0\u30e0\u5024\u306b\u3057\u3066\u3044\u307e\u3059\u3002\u3053\u308c\u3092 C# \u306e\u30b3\u30fc\u30c9\u306b\u3082\u3044\u308c\u3066\u304a\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-php\" data-lang=\"PHP\"><code>        \/\/ \u30ab\u30c6\u30b4\u30ea\u306e\u6700\u5927\u5024\u304b\u3089\u30e9\u30f3\u30c0\u30e0id\u3092\u53d6\u5f97\n        function fake_category_id() {\n            $maxId = Category::max(&#39;id&#39;);\n            return rand(1, $maxId);\n        }\n<\/code><\/pre><\/div>\n\n\n\n<p>\u3053\u306e\u90e8\u5206\u306f\u624b\u4f5c\u696d\u3068 Copiot \u3067\u5909\u66f4<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-csharp\" data-lang=\"C#\"><code>        \/\/ \u30ab\u30c6\u30b4\u30ea\u306e\u6700\u5927\u5024\u304b\u3089\u30e9\u30f3\u30c0\u30e0id\u3092\u53d6\u5f97\n        int fake_category_id()\n        {\n            var maxId = _context.Categories.Max(c =&gt; c.Id);\n            return Random.Shared.Next(maxId) + 1; \/\/ 1\u304b\u3089maxId\u307e\u3067\u306e\u30e9\u30f3\u30c0\u30e0\u306a\u5024\u3092\u751f\u6210\n        }\n\n\n        \/\/ \u5546\u54c1\u306e\u521d\u671f\u30c7\u30fc\u30bf\n        var products = new List&lt;Product&gt;\n        {\n            \/\/ \u30cf\u30f3\u30d0\u30fc\u30ac\u30fc\n            new Product\n            {\n                CategoryId = fake_category_id(),\n                Slug = &quot;burger1&quot;,\n                Name = &quot;\u30e2\u30b9\u30d0\u30fc\u30ac\u30fc&quot;,\n                Description = &quot;&quot;,\n                Image = &quot;burger1.jpg&quot;,\n                Price = 440,\n                SortId = 1,\n                Display = 1\n            },\n<\/code><\/pre><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">.devcontainer \u30b3\u30f3\u30c6\u30ca\u3092\u4f5c\u6210\u3059\u308b<\/h2>\n\n\n\n<p>vscode \u3067\u306f\u958b\u767a\u74b0\u5883\u3092\u30b3\u30f3\u30c6\u30ca\u5316\u3067\u304d\u308b\u306e\u3067\u3053\u308c\u3092\u4f5c\u6210\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"wp-block-preformatted\">.devcontainer \u3092\u4f5c\u6210\u3057\u3066\u3002<\/pre>\n\n\n\n<figure class=\"wp-block-image size-large\"><a href=\"https:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-88.png\"><img loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"871\" src=\"https:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-88-1024x871.png\" alt=\"\" class=\"wp-image-11316\" srcset=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-88-1024x871.png 1024w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-88-300x255.png 300w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-88-768x654.png 768w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-88.png 1194w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/a><\/figure>\n\n\n\n<p>\u3067\u304d\u3042\u304c\u3063\u305f\u3063\u307d\u3044\u306e\u3067\u3001\u3044\u3063\u305f\u3093 vscode \u3092\u9589\u3058\u3066\u958b\u304d\u76f4\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><a href=\"https:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-89.png\"><img loading=\"lazy\" decoding=\"async\" width=\"922\" height=\"348\" src=\"https:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-89.png\" alt=\"\" class=\"wp-image-11317\" srcset=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-89.png 922w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-89-300x113.png 300w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-89-768x290.png 768w\" sizes=\"auto, (max-width: 922px) 100vw, 922px\" \/><\/a><\/figure>\n\n\n\n<p>\u53f3\u4e0b\u306b\u300c\u30b3\u30f3\u30c6\u30ca\u2015\u3067\u518d\u5ea6\u958b\u304f\u300d\u30dc\u30bf\u30f3\u304c\u51fa\u3066\u304d\u305f\u3089 ok \u3067\u3059\u3002\u3053\u308c\u3092\u30af\u30ea\u30c3\u30af\u3059\u308b\u3068 Docker \u30b3\u30f3\u30c6\u30ca\u3092\u4f5c\u308a\u59cb\u3081\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u30b3\u30de\u30f3\u30c9\u30d1\u30ec\u30c3\u30c8\u3067\u300c\u958b\u767a\u30b3\u30f3\u30c6\u30ca\uff1a\u30b3\u30f3\u30c6\u30ca\u2015\u3067\u518d\u5ea6\u958b\u304f\u300d\u3092\u9078\u629e\u3057\u3066\u3082 ok \u3067\u3059\u3002<\/p>\n\n\n\n<p>\u3067\u3001\u4e00\u767a\u3067\u3046\u307e\u304f\u3044\u3051\u3070\u3044\u3044\u306e\u3067\u3059\u304c\u3001\u5927\u62b5\u306f\u3046\u307e\u304f\u3044\u304d\u307e\u305b\u3093\u3002\u7d20\u76f4\u306b AI \u306b\u805e\u3044\u3066\u307f\u307e\u3057\u3087\u3046\u3002AI \u304c\u66f8\u3044\u305f\u3093\u3060\u3057\u3002<\/p>\n\n\n\n<pre class=\"wp-block-preformatted\">\u30ea\u30e2\u30fc\u30c8\u30b3\u30f3\u30c6\u30ca\u3092\u958b\u3044\u305f\u3068\u304d\u306b\u30a8\u30e9\u30fc\u304c\u3067\u307e\u3059\u3002<\/pre>\n\n\n\n<figure class=\"wp-block-image size-full\"><a href=\"https:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-90.png\"><img loading=\"lazy\" decoding=\"async\" width=\"894\" height=\"537\" src=\"https:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-90.png\" alt=\"\" class=\"wp-image-11318\" srcset=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-90.png 894w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-90-300x180.png 300w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-90-768x461.png 768w\" sizes=\"auto, (max-width: 894px) 100vw, 894px\" \/><\/a><\/figure>\n\n\n\n<p>ubuntu \u306e dotnet 9.0 \u306e\u30a4\u30e1\u30fc\u30b8\u304c\u7121\u3044\u3088\u3046\u3067\u3059\u3002<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><a href=\"https:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-91.png\"><img loading=\"lazy\" decoding=\"async\" width=\"895\" height=\"462\" src=\"https:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-91.png\" alt=\"\" class=\"wp-image-11319\" srcset=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-91.png 895w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-91-300x155.png 300w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-91-768x396.png 768w\" sizes=\"auto, (max-width: 895px) 100vw, 895px\" \/><\/a><\/figure>\n\n\n\n<p>\u8c6a\u5feb\u306b 8.0 \u306b\u4ee5\u964d\u3057\u3088\u3046\u3068\u3057\u3066\u3044\u307e\u3059\u304c\u30019.0 \u3067\u4f7f\u3044\u305f\u3044\u3093\u3067\u3059\u3088\u306d\u3002\u3002\u3002<\/p>\n\n\n\n<p>.NET(Core)\u3067\u5229\u7528\u53ef\u80fd\u306aDocker\u30a4\u30e1\u30fc\u30b8\u3068\u30bf\u30b0 #Docker &#8211; Qiita <a href=\"https:\/\/qiita.com\/karuakun\/items\/8d98f0430bf2dbc6af59\">https:\/\/qiita.com\/karuakun\/items\/8d98f0430bf2dbc6af59<\/a><\/p>\n\n\n\n<p>\u3053\u308c\u3092\u898b\u308b\u9650\u308a\u3001Ubuntu 22.04 \u306a\u3089\u3070 9.0-jammy\u3001Ubuntu 24.04 \u306a\u3089\u3070 9.0-noble \u3068\u306a\u308b\u306f\u305a\u3067\u3059\u3002<\/p>\n\n\n\n<pre class=\"wp-block-preformatted\">FROM mcr.microsoft.com\/dotnet\/sdk:8.0<br>\u306e\u4ee3\u308f\u308a\u306b<br>FROM mcr.microsoft.com\/dotnet\/sdk:9.0-noble<br>\u3092\u4f7f\u3063\u3066\u307f\u3066\u3002<\/pre>\n\n\n\n<p>\u57f7\u62d7\u306b Pomelo.EntityFrameworkCore.MySql \u3092\u85a6\u3081\u3066\u304f\u308b\u306e\u3067\u3059\u304c\u3001\u73fe\u6642\u70b9\u3067\u306f Oracle \u63d0\u4f9b\u306e MySql.EntityFrameworkCore \u3092\u4f7f\u3063\u305f\u65b9\u304c\u3044\u3044\u3067\u3059\u3002<\/p>\n\n\n\n<pre class=\"wp-block-preformatted\">MySql.EntityFrameworkCore \u3092\u4f7f\u3063\u3066\u3002<\/pre>\n\n\n\n<p>\u3053\u306e\u624b\u306e\u8a71\u306f\u3001\u5b9f\u969b\u306b\u958b\u767a\u7d4c\u9a13\u304c\u306a\u3044\u3068\u308f\u304b\u3089\u306a\u3044\u3068\u3053\u308d\u3067\u3082\u3042\u308b\u3057\u3001Claude Sonnet \u306b\u3057\u3066\u3082\u5185\u90e8\u3067\u306e\u5b66\u7fd2\u6e08\u307f\u30e2\u30c7\u30eb\u3092\u4f5c\u6210\u3057\u305f\u3068\u304d\u306e\u53ce\u96c6\u30c7\u30fc\u30bf\u6642\u671f\u306e\u554f\u984c\u3082\u3042\u308a\u3001\u305d\u3082\u305d\u3082\u3001MySql.EntityFrameworkCore \u3092\u4f7f\u3063\u305f\u4f8b\u304c\u3042\u307e\u308a\u30d6\u30ed\u30b0\u306a\u3069\u3067\u306a\u3044\u3068\u3044\u3046\u73fe\u72b6\u3082\u3042\u308a\u3002\u3053\u306e\u3042\u305f\u308a\u3001\u300c\u6b63\u89e3\u300d\u306a\u306e\u304b\u300c\u591a\u6570\u6c7a\u300d\u306a\u306e\u304b\u304c\u554f\u308f\u308c\u308b\u3068\u3053\u308d\u3067\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Docker \u30b3\u30f3\u30c6\u30ca\u3092\u4f5c\u308b<\/h2>\n\n\n\n<p>\u3055\u3066\u3001\u30d3\u30eb\u30c9\u304c\u901a\u3063\u305f\u3068\u3053\u308d\u3067 Docker \u306e\u958b\u767a\u30b3\u30f3\u30c6\u30ca\u3092\u4f5c\u308a\u307e\u3059\u3002\u4eca\u5ea6\u306f\u3046\u307e\u304f\u30a4\u30e1\u30fc\u30b8\u30d5\u30a1\u30a4\u30eb\u3092\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9\u3067\u304d\u305d\u3046\u3067\u3059\u3002<\/p>\n\n\n\n<p>\u3061\u306a\u307f\u306b\u3001\u5148\u306e 9.0 \u304b\u3089 8.0 \u306e\u30c0\u30a6\u30f3\u30b0\u30ec\u30fc\u30c9\u9a12\u304e\u306e\u3068\u304d\u306b\u3001Claude Sonnet \u304c\u65e2\u5b58\u306e\u30b3\u30f3\u30c6\u30ca\u3092\u5168\u524a\u9664\u3057\u3066\u3057\u307e\u3044\u307e\u3057\u305f\u3002\u3053\u306e\u624b\u306e\u3084\u3089\u304b\u3057\u306f\u7d50\u69cb\u3042\u308b\u304b\u3082\u3057\u308c\u307e\u305b\u3093\u3002<\/p>\n\n\n\n<p><\/p>\n\n\n\n<p>\u4e00\u898b\u3046\u307e\u304f\u3044\u304d\u305d\u3046\u3060\u3063\u305f\u306e\u3067\u3059\u304c\u3001\u4f55\u6545\u304b https:\/\/download.docker.com\/linux\/debian \u306e\u3068\u3053\u308d\u3067\u5931\u6557\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"wp-block-preformatted\">------<br> &gt; [dev_container_auto_added_stage_label 4\/9] RUN curl -fsSL https:\/\/download.do<br>cker.com\/linux\/debian\/gpg | gpg --dearmor -o \/usr\/share\/keyrings\/docker-archive-<br>keyring.gpg     &amp;&amp; echo \"deb [arch=$(dpkg --print-architecture) signed-by=\/usr\/s<br>hare\/keyrings\/docker-archive-keyring.gpg] https:\/\/download.docker.com\/linux\/debi<br>an $(lsb_release -cs) stable\" | tee \/etc\/apt\/sources.list.d\/docker.list &gt; \/dev\/n<br>ull     &amp;&amp; apt-get update     &amp;&amp; apt-get install -y docker-ce-cli     &amp;&amp; apt-get<br> clean     &amp;&amp; rm -rf \/var\/lib\/apt\/lists\/*:<br>0.917 Hit:1 https:\/\/deb.nodesource.com\/node_20.x nodistro InRelease<br>1.171 Hit:2 http:\/\/archive.ubuntu.com\/ubuntu noble InRelease<br>1.221 Hit:3 http:\/\/security.ubuntu.com\/ubuntu noble-security InRelease<br>1.324 Ign:4 https:\/\/download.docker.com\/linux\/debian noble InRelease<br>1.391 Hit:5 http:\/\/archive.ubuntu.com\/ubuntu noble-updates InRelease<br>1.614 Hit:6 http:\/\/archive.ubuntu.com\/ubuntu noble-backports InRelease<br>1.656 Err:7 https:\/\/download.docker.com\/linux\/debian noble Release<br>1.656   404  Not Found [IP: 18.172.31.22 443]<br>1.728 Reading package lists...<br>3.740 E: The repository 'https:\/\/download.docker.com\/linux\/debian noble Release'<br> does not have a Release file.<br>------<br>failed to solve: process \"\/bin\/sh -c curl -fsSL https:\/\/download.docker.com\/linu<br>x\/debian\/gpg | gpg --dearmor -o \/usr\/share\/keyrings\/docker-archive-keyring.gpg<br>   &amp;&amp; echo \\\"deb [arch=$(dpkg --print-architecture) signed-by=\/usr\/share\/keyring<br>s\/docker-archive-keyring.gpg] https:\/\/download.docker.com\/linux\/debian $(lsb_rel<br>ease -cs) stable\\\" | tee \/etc\/apt\/sources.list.d\/docker.list &gt; \/dev\/null     &amp;&amp;<br>apt-get update     &amp;&amp; apt-get install -y docker-ce-cli     &amp;&amp; apt-get clean<br>&amp;&amp; rm -rf \/var\/lib\/apt\/lists\/*\" did not complete successfully: exit code: 100<br><br>View build details: docker-desktop:\/\/dashboard\/build\/desktop-linux\/desktop-linux<br>\/jadc0jrt185aqxmaw15etxq1i<br>[2025-07-06T12:53:13.110Z] Stop (136147 ms): Run: docker compose --project-name aspnet-minimal-sample_devcontainer -f h:\\ai-sample\\src\\webapi\\aspnet-minimal-sample\\.devcontainer\\docker-compose.yml -f c:\\Users\\masuda\\AppData\\Roaming\\Code\\User\\globalStorage\\ms-vscode-remote.remote-containers\\data\\docker-compose\\docker-compose.devcontainer.build-1751806256960.yml build<br>[2025-07-06T12:53:13.129Z] Error: Command failed: docker compose --project-name aspnet-minimal-sample_devcontainer -f h:\\ai-sample\\src\\webapi\\aspnet-minimal-sample\\.devcontainer\\docker-compose.yml -f c:\\Users\\masuda\\AppData\\Roaming\\Code\\User\\globalStorage\\ms-vscode-remote.remote-containers\\data\\docker-compose\\docker-compose.devcontainer.build-1751806256960.yml build<br>[2025-07-06T12:53:13.129Z]     at lw (c:\\Users\\masuda\\.vscode\\extensions\\ms-vscode-remote.remote-containers-0.417.0\\dist\\spec-node\\devContainersSpecCLI.js:432:525)<br>[2025-07-06T12:53:13.130Z]     at async c6 (c:\\Users\\masuda\\.vscode\\extensions\\ms-vscode-remote.remote-containers-0.417.0\\dist\\spec-node\\devContainersSpecCLI.js:432:2475)<br>[2025-07-06T12:53:13.130Z]     at async u6 (c:\\Users\\masuda\\.vscode\\extensions\\ms-vscode-remote.remote-containers-0.417.0\\dist\\spec-node\\devContainersSpecCLI.js:412:3489)<br>[2025-07-06T12:53:13.130Z]     at async H6 (c:\\Users\\masuda\\.vscode\\extensions\\ms-vscode-remote.remote-containers-0.417.0\\dist\\spec-node\\devContainersSpecCLI.js:484:4015)<br>[2025-07-06T12:53:13.130Z]     at async BC (c:\\Users\\masuda\\.vscode\\extensions\\ms-vscode-remote.remote-containers-0.417.0\\dist\\spec-node\\devContainersSpecCLI.js:484:4957)<br>[2025-07-06T12:53:13.131Z]     at async d7 (c:\\Users\\masuda\\.vscode\\extensions\\ms-vscode-remote.remote-containers-0.417.0\\dist\\spec-node\\devContainersSpecCLI.js:665:202)<br>[2025-07-06T12:53:13.131Z]     at async f7 (c:\\Users\\masuda\\.vscode\\extensions\\ms-vscode-remote.remote-containers-0.417.0\\dist\\spec-node\\devContainersSpecCLI.js:664:14804)<br>[2025-07-06T12:53:13.131Z]     at async c:\\Users\\masuda\\.vscode\\extensions\\ms-vscode-remote.remote-containers-0.417.0\\dist\\spec-node\\devContainersSpecCLI.js:484:1188<br>[2025-07-06T12:53:13.219Z] Stop (143625 ms): Run: d:\\tools\\Microsoft VS Code\\Code.exe c:\\Users\\masuda\\.vscode\\extensions\\ms-vscode-remote.remote-containers-0.417.0\\dist\\spec-node\\devContainersSpecCLI.js up --user-data-folder c:\\Users\\masuda\\AppData\\Roaming\\Code\\User\\globalStorage\\ms-vscode-remote.remote-containers\\data --container-session-data-folder \/tmp\/devcontainers-434ce8f4-209d-49f9-b58e-f43a1a52828f1751806242331 --workspace-folder h:\\ai-sample\\src\\webapi\\aspnet-minimal-sample --workspace-mount-consistency cached --gpu-availability detect --id-label devcontainer.local_folder=h:\\ai-sample\\src\\webapi\\aspnet-minimal-sample --id-label devcontainer.config_file=h:\\ai-sample\\src\\webapi\\aspnet-minimal-sample\\.devcontainer\\devcontainer.json --log-level debug --log-format json --config h:\\ai-sample\\src\\webapi\\aspnet-minimal-sample\\.devcontainer\\devcontainer.json --default-user-env-probe loginInteractiveShell --mount type=volume,source=vscode,target=\/vscode,external=true --mount type=bind,source=\\\\wsl.localhost\\Ubuntu\\mnt\\wslg\\runtime-dir\\wayland-0,target=\/tmp\/vscode-wayland-97456619-a854-41e6-aa3d-2cca4ba71657.sock --skip-post-create --update-remote-user-uid-default on --mount-workspace-git-root --include-configuration --include-merged-configuration<br>[2025-07-06T12:53:13.220Z] Exit code 1<br>[2025-07-06T12:53:13.238Z] Command failed: d:\\tools\\Microsoft VS Code\\Code.exe c:\\Users\\masuda\\.vscode\\extensions\\ms-vscode-remote.remote-containers-0.417.0\\dist\\spec-node\\devContainersSpecCLI.js up --user-data-folder c:\\Users\\masuda\\AppData\\Roaming\\Code\\User\\globalStorage\\ms-vscode-remote.remote-containers\\data --container-session-data-folder \/tmp\/devcontainers-434ce8f4-209d-49f9-b58e-f43a1a52828f1751806242331 --workspace-folder h:\\ai-sample\\src\\webapi\\aspnet-minimal-sample --workspace-mount-consistency cached --gpu-availability detect --id-label devcontainer.local_folder=h:\\ai-sample\\src\\webapi\\aspnet-minimal-sample --id-label devcontainer.config_file=h:\\ai-sample\\src\\webapi\\aspnet-minimal-sample\\.devcontainer\\devcontainer.json --log-level debug --log-format json --config h:\\ai-sample\\src\\webapi\\aspnet-minimal-sample\\.devcontainer\\devcontainer.json --default-user-env-probe loginInteractiveShell --mount type=volume,source=vscode,target=\/vscode,external=true --mount type=bind,source=\\\\wsl.localhost\\Ubuntu\\mnt\\wslg\\runtime-dir\\wayland-0,target=\/tmp\/vscode-wayland-97456619-a854-41e6-aa3d-2cca4ba71657.sock --skip-post-create --update-remote-user-uid-default on --mount-workspace-git-root --include-configuration --include-merged-configuration<br>[2025-07-06T12:53:13.238Z] Exit code 1<br><\/pre>\n\n\n\n<p>\u3067\u3001<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><a href=\"https:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-92.png\"><img loading=\"lazy\" decoding=\"async\" width=\"876\" height=\"532\" src=\"https:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-92.png\" alt=\"\" class=\"wp-image-11321\" srcset=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-92.png 876w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-92-300x182.png 300w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-92-768x466.png 768w\" sizes=\"auto, (max-width: 876px) 100vw, 876px\" \/><\/a><\/figure>\n\n\n\n<p>\u672c\u5f53\u304b\u3069\u3046\u304b\u308f\u304b\u3089\u306a\u3044\u306e\u3067\u3059\u304c\u3001Docker \u306f 24.04 \u306f\u30b5\u30dd\u30fc\u30c8\u3057\u3066\u3044\u306a\u3044\u3089\u3057\u304f\u300122.04 \u3092\u4f7f\u3046\u305d\u3046\u3067\u3059\u3002\u307b\u3093\u3068\u304b\u306a\uff1f<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u3067\u3001\u3046\u307e\u304f\u3044\u304b\u306a\u3044\u306e\u3067\u3084\u308a\u76f4\u3057<\/h2>\n\n\n\n<p>2\u65e5\u9593\u82e6\u6226\u3057\u305f\u306e\u3067\u3059\u304c\u3001\u4f55\u3092\u3084\u3063\u3066\u3082\u30dd\u30fc\u30c8\u30a8\u30e9\u30fc\u7b49\u304c\u53d6\u308c\u306a\u304f\u306a\u3063\u3066\u3057\u307e\u3063\u305f\u306e\u3067\u3001\u5225\u9014 minimal \u306e\u307f\u306a asp.net web api \u3092\u4f5c\u3063\u3066\u3001Dockerfile \u3092\u6574\u7406\u3057\u307e\u3057\u305f\u3002<\/p>\n\n\n\n<p>Dockerfile.dev<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code># Development Dockerfile for devcontainer\nFROM mcr.microsoft.com\/dotnet\/sdk:9.0\n\n# Set environment variables\nENV DEBIAN_FRONTEND=noninteractive\nENV TZ=Asia\/Tokyo\n\n# Install additional tools\nRUN apt-get update && apt-get install -y \\\n    git \\\n    curl \\\n    wget \\\n    unzip \\\n    vim \\\n    nano \\\n    zsh \\\n    sudo \\\n    ca-certificates \\\n    && rm -rf \/var\/lib\/apt\/lists\/* \\\n    && apt-get clean\n\n# Create vscode user with sudo access\nRUN groupadd --gid 1000 vscode \\\n    && useradd --uid 1000 --gid vscode --shell \/bin\/bash --create-home vscode \\\n    && echo vscode ALL=\\(root\\) NOPASSWD:ALL &gt; \/etc\/sudoers.d\/vscode \\\n    && chmod 0440 \/etc\/sudoers.d\/vscode\n\n# Set up workspace directory with proper permissions\nWORKDIR \/workspace\nRUN chown vscode:vscode \/workspace\n\n# Switch to vscode user for the rest of the setup\nUSER vscode\n\n# Set umask to ensure proper permissions for created files\nRUN echo &quot;umask 022&quot; &gt;&gt; \/home\/vscode\/.bashrc \\\n    && echo &quot;umask 022&quot; &gt;&gt; \/home\/vscode\/.zshrc || true\n\n# Install Oh My Zsh with retry logic and error handling\nRUN curl -fsSL https:\/\/raw.githubusercontent.com\/ohmyzsh\/ohmyzsh\/master\/tools\/install.sh -o install-ohmyzsh.sh \\\n    && chmod +x install-ohmyzsh.sh \\\n    && bash install-ohmyzsh.sh --unattended \\\n    && rm -f install-ohmyzsh.sh \\\n    || echo &quot;Oh My Zsh installation failed, continuing...&quot;\n\n# Set the default shell to zsh (switch back to root temporarily)\nUSER root\nRUN chsh -s \/bin\/zsh vscode || echo &quot;Failed to change shell, continuing...&quot;\n\n# Switch back to vscode user\nUSER vscode\n\n# Install dotnet tools with error handling\nRUN dotnet tool install --global dotnet-ef || echo &quot;dotnet-ef installation failed&quot; \\\n    && dotnet tool install --global dotnet-aspnet-codegenerator || echo &quot;dotnet-aspnet-codegenerator installation failed&quot; \\\n    && dotnet tool install --global dotnet-watch || echo &quot;dotnet-watch installation failed&quot;\n\n# Add dotnet tools to PATH\nENV PATH=&quot;${PATH}:\/home\/vscode\/.dotnet\/tools&quot;\n\n# Set up git configuration\nRUN git config --global --add safe.directory \/workspace \\\n    && git config --global init.defaultBranch main\n\n# Create necessary directories\nRUN mkdir -p \/home\/vscode\/.vscode-server\/extensions \\\n    && mkdir -p \/home\/vscode\/.nuget\/packages\n\n# Default command\nCMD [&quot;sleep&quot;, &quot;infinity&quot;]\n<\/code><\/pre><\/div>\n\n\n\n<p>docker-compose.yml<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>services:\n  aspnet-sample:\n    build:\n      context: .\n      dockerfile: Dockerfile.dev\n    ports:\n      - &quot;8000:8000&quot;\n      - &quot;8001:8001&quot;\n    environment:\n      - ASPNETCORE_ENVIRONMENT=Development\n      - ASPNETCORE_URLS=http:\/\/+:8000\n    networks:\n      - aspnet-network\n  mysql:\n    image: mysql:8.0\n    restart: unless-stopped\n    environment:\n      MYSQL_ROOT_PASSWORD: root\n      MYSQL_DATABASE: mos\n      MYSQL_USER: mos\n      MYSQL_PASSWORD: mos\n    ports:\n      - &quot;3306:3306&quot;\n    volumes:\n      - mysql-data:\/var\/lib\/mysql\n      - .\/database\/init:\/docker-entrypoint-initdb.d\n    networks:\n      - aspnet-network\n    healthcheck:\n      test: [&quot;CMD&quot;, &quot;mysqladmin&quot;, &quot;ping&quot;, &quot;-h&quot;, &quot;localhost&quot;]\n      timeout: 20s\n      retries: 10\n      interval: 10s\n\nnetworks:\n  aspnet-network:\n    driver: bridge\n\nvolumes:\n    mysql-data:\n        driver: local\n<\/code><\/pre><\/div>\n\n\n\n<p>.devcontainer\/devcontainer.json<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-json\" data-lang=\"JSON\"><code>{\n  &quot;name&quot;: &quot;ASP.NET Core 9.0 Development Container&quot;,\n  &quot;dockerFile&quot;: &quot;..\/Dockerfile.dev&quot;,\n  &quot;context&quot;: &quot;..&quot;,\n  &quot;workspaceFolder&quot;: &quot;\/workspace&quot;,\n  &quot;shutdownAction&quot;: &quot;stopContainer&quot;,\n  \n  \/\/ Mount the workspace folder\n  &quot;mounts&quot;: [\n    &quot;source=${localWorkspaceFolder},target=\/workspace,type=bind,consistency=cached&quot;\n  ],\n  \n  \/\/ Use vscode user for development\n  &quot;remoteUser&quot;: &quot;vscode&quot;,\n  \n  \/\/ Configure tool-specific properties.\n  &quot;customizations&quot;: {\n    &quot;vscode&quot;: {\n      &quot;extensions&quot;: [\n        &quot;ms-dotnettools.csharp&quot;,\n        &quot;ms-dotnettools.csdevkit&quot;,\n        &quot;ms-vscode.vscode-json&quot;,\n        &quot;ms-azuretools.vscode-docker&quot;\n      ],\n      &quot;settings&quot;: {\n        &quot;dotnet.defaultSolution&quot;: &quot;aspnet-minimal-sample.sln&quot;,\n        &quot;files.exclude&quot;: {\n          &quot;**\/bin&quot;: true,\n          &quot;**\/obj&quot;: true\n        },\n        &quot;terminal.integrated.defaultProfile.linux&quot;: &quot;bash&quot;\n      }\n    }\n  },\n\n  \/\/ Use &#39;forwardPorts&#39; to make a list of ports inside the container available locally.\n  &quot;forwardPorts&quot;: [\n    8000,\n    8081\n  ],\n\n  \/\/ Use &#39;postCreateCommand&#39; to run commands after the container is created.\n  &quot;postCreateCommand&quot;: &quot;chmod +x .devcontainer\/init.sh && .devcontainer\/init.sh&quot;,\n\n  \/\/ Configure container features (simplified)\n  &quot;features&quot;: {\n    &quot;ghcr.io\/devcontainers\/features\/common-utils:2&quot;: {\n      &quot;installZsh&quot;: false,\n      &quot;username&quot;: &quot;vscode&quot;,\n      &quot;userUid&quot;: &quot;1000&quot;,\n      &quot;userGid&quot;: &quot;1000&quot;\n    }\n  }\n}\n<\/code><\/pre><\/div>\n\n\n\n<p>init.sh<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>#!\/bin\/bash\n\n# Fix permissions for .NET build artifacts\necho &quot;\ud83d\udd27 Fixing permissions for .NET development...&quot;\n\n# Remove existing build artifacts that might have incorrect permissions\necho &quot;\ud83e\uddf9 Cleaning build artifacts...&quot;\nrm -rf obj bin || true\n\n# Ensure vscode user owns the workspace\necho &quot;\ud83d\udc64 Setting ownership...&quot;\nsudo chown -R vscode:vscode \/workspace\n\n# Set appropriate permissions\necho &quot;\ud83d\udd10 Setting permissions...&quot;\nsudo chmod -R 755 \/workspace\n\n# Create directories with correct permissions\necho &quot;\ud83d\udcc1 Creating build directories...&quot;\nmkdir -p obj bin\n\n# Clean and restore\necho &quot;\ud83c\udfd7\ufe0f  Cleaning and restoring project...&quot;\ndotnet clean\ndotnet restore aspnet-minimal-sample.csproj\n\n# Test build\necho &quot;\ud83e\uddea Testing build...&quot;\ndotnet build aspnet-minimal-sample.csproj\n\necho &quot;\u2705 Setup complete! You can now run &#39;dotnet run&#39;&quot;\n<\/code><\/pre><\/div>\n\n\n\n<p>setup.sh<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>#!\/bin\/bash\n\n# DevContainer initialization script\necho &quot;\ud83d\ude80 Starting DevContainer setup...&quot;\n\n# Check if we&#39;re in the correct directory\necho &quot;\ud83d\udcc1 Current directory: $(pwd)&quot;\necho &quot;\ud83d\udcc4 Files in current directory:&quot;\nls -la\n\n# Check if project file exists\nif [ -f &quot;aspnet-minimal-sample.csproj&quot; ]; then\n    echo &quot;\u2705 Found aspnet-minimal-sample.csproj&quot;\n    echo &quot;\ud83d\udce6 Restoring NuGet packages...&quot;\n    dotnet restore aspnet-minimal-sample.csproj\n    if [ $? -eq 0 ]; then\n        echo &quot;\u2705 NuGet packages restored successfully&quot;\n    else\n        echo &quot;\u274c Failed to restore NuGet packages&quot;\n        exit 1\n    fi\nelse\n    echo &quot;\u274c aspnet-minimal-sample.csproj not found in current directory&quot;\n    exit 1\nfi\n\n# Check if solution file exists\nif [ -f &quot;aspnet-minimal-sample.sln&quot; ]; then\n    echo &quot;\u2705 Found aspnet-minimal-sample.sln&quot;\nelse\n    echo &quot;\u26a0\ufe0f  aspnet-minimal-sample.sln not found&quot;\nfi\n\necho &quot;\ud83c\udf89 DevContainer setup completed successfully!&quot;\n<\/code><\/pre><\/div>\n\n\n\n<p>Dockerfile \u3068 docker-compose.yml \u306a\u3093\u3066\u751f\u6210AI\u306e\u30e2\u30c7\u30eb\u306e\u4e2d\u3067\u306f\u5341\u5206\u306b\u77e5\u898b\u304c\u3042\u308a\u305d\u3046\u306a\u3082\u306e\u3067\u3059\u304c\u3001\u4f55\u5ea6\u3084\u3063\u3066\u3082\u5931\u6557\u3057\u307e\u3059\u3002\u4ed5\u65b9\u304c\u306a\u3044\u306e\u3067\u624b\u4f5c\u696d\u3067\u4fee\u6b63\u3092\u3057\u305f\u5f8c\u306b Claude Sonnet \u306b\u30ec\u30d3\u30e5\u30fc\u3057\u3066\u8cb0\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u304a\u305d\u3089\u304f<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30db\u30b9\u30c8\u306e\u30dd\u30fc\u30c8\u756a\u53f7\u3068\u30c0\u30d6\u308b\u3053\u3068\u3092\u60f3\u5b9a\u3057\u3066\u3044\u306a\u3044\u3002<\/li>\n\n\n\n<li>dotnet build \u3067\u66f8\u304d\u8fbc\u307f\u3055\u308c\u308b\u30d5\u30a9\u30eb\u30c0\u30fc\u306e\u30d1\u30fc\u30df\u30c3\u30b7\u30e7\u30f3\u5909\u66f4\u304c\u5fc5\u9808<\/li>\n\n\n\n<li>\u30db\u30b9\u30c8\u304c windows \u307e\u308f\u308a\u306a\u306e\u3067\u304c\u554f\u984c\u304b\uff1f<\/li>\n<\/ul>\n\n\n\n<p>\u306a\u3068\u3053\u308d\u3067\u5f15\u3063\u639b\u304b\u308a\u307e\u3059\u3002laravel \u3084 next.js \u306e\u307b\u3046\u306f\u30d3\u30eb\u30c9\u3059\u308b\u5fc5\u8981\u304c\u306a\u3044\u306e\u3067\u30b3\u30fc\u30c9\u5909\u66f4\u3092\u3057\u305f\u5f8c\u306b\u30d6\u30e9\u30a6\u30b6\u7b49\u3067\u30ea\u30ed\u30fc\u30c9\u3059\u308c\u3070\u3044\u3044\u306e\u3067\u3059\u304c\u3001dotnet \u306e\u5834\u5408\u306f\u3044\u3061\u3044\u3061\u30d3\u30eb\u30c9\u3057\u306a\u3044\u3068\u3044\u3051\u306a\u3044\u306e\u304c\u9762\u5012\u306a\u3068\u3053\u308d\u3067\u3059\u3002hot reload \u3082\u3067\u304d\u305f\u3088\u3046\u306a\u6c17\u304c\u3059\u308b\u306e\u3067\u3059\u304c\u3001\u3053\u308c\u306f\u5f8c\u3067\u8abf\u3079\u308b\u3068\u3057\u3066\u3002<\/p>\n\n\n\n<p>\u305d\u3093\u306a\u8a33\u3067\u3001\u7121\u4e8b\u300c\u958b\u767a\u30b3\u30f3\u30c6\u30ca\u300d\u306e\u4e2d\u3067\u306e\u5b9f\u884c\u307e\u3067\u5b8c\u4e86<\/p>\n\n\n\n<figure class=\"wp-block-image size-large\"><a href=\"https:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-93.png\"><img loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"516\" src=\"https:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-93-1024x516.png\" alt=\"\" class=\"wp-image-11324\" srcset=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-93-1024x516.png 1024w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-93-300x151.png 300w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-93-768x387.png 768w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-93-1536x775.png 1536w, http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2025\/07\/image-93-2048x1033.png 2048w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/a><\/figure>\n\n\n\n<p>\u79c1\u306e\u5834\u5408\u3001xamp \u3067\u306e mysql \u3082\u52d5\u3044\u3066\u3044\u308b\u306e\u3067 mysql-1 \u306e 3306:3306 \u3082\u5909\u3048\u306a\u3044\u3068\u99c4\u76ee\u306a\u3093\u3067\u3059\u304c\u3001\u3072\u3068\u307e\u305a\u3001\u3053\u308c\u306f\u7d42\u4e86\u3002\u3042\u3068\u3067\u3001azure \u306b\u30c7\u30d7\u30ed\u30a4\u3092\u8a66\u3057\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u53c2\u7167<\/h2>\n\n\n\n<p>webapi\/aspnet-minimal-sample : ASP.NET Core Minimal \u306b\u3088\u308b web api \u30b5\u30f3\u30d7\u30eb &amp; Docker \u52d5\u4f5c<\/p>\n\n\n\n<p><a href=\"https:\/\/github.com\/moonmile\/mos-ai-sample\/tree\/master\/src\/webapi\/aspnet-minimal-sample\">https:\/\/github.com\/moonmile\/mos-ai-sample\/tree\/master\/src\/webapi\/aspnet-minimal-sample<\/a><\/p>\n\n\n\n<p><\/p>\n","protected":false},"excerpt":{"rendered":"<p>asp.net minimal \u3092\u30ed\u30fc\u30ab\u30eb\u74b0\u5883\u3067\u306a\u304f Azure \u3067\u52d5\u4f5c\u3067\u304d\u308b\u3088\u3046\u306b\u3057\u307e\u3059\u3002\u3072\u3068\u307e\u305a\u3001Docker \u5316\u3057\u3066\u304a\u304d\u307e\u3057\u3087\u3046\u3002 Dockerfile \u3092\u4f5c\u308b aspnet-minimal-sample \u306e Do &hellip; <a href=\"http:\/\/www.moonmile.net\/blog\/archives\/11313\">\u7d9a\u304d\u3092\u8aad\u3080 <span class=\"meta-nav\">&rarr;<\/span><\/a><\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[3],"tags":[],"class_list":["post-11313","post","type-post","status-publish","format-standard","hentry","category-dev"],"jetpack_featured_media_url":"","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts\/11313","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/comments?post=11313"}],"version-history":[{"count":7,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts\/11313\/revisions"}],"predecessor-version":[{"id":11339,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts\/11313\/revisions\/11339"}],"wp:attachment":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/media?parent=11313"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/categories?post=11313"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/tags?post=11313"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}