{"id":2657,"date":"2022-11-19T06:47:14","date_gmt":"2022-11-18T21:47:14","guid":{"rendered":"https:\/\/mattarishitemota.com\/?p=2657"},"modified":"2022-11-23T06:15:57","modified_gmt":"2022-11-22T21:15:57","slug":"next-js-mui-typescript-%e3%81%ae%e9%96%8b%e7%99%ba%e7%92%b0%e5%a2%83%e3%82%92-docker-%e3%81%a7%e4%bd%9c%e3%82%8b","status":"publish","type":"post","link":"https:\/\/mattarishitemota.com\/?p=2657","title":{"rendered":"Next.js + MUI + TypeScript \u306e\u958b\u767a\u74b0\u5883\u3092 Docker \u3067\u4f5c\u308b"},"content":{"rendered":"\n<p>\u3055\u3063\u3068 Web \u30a2\u30d7\u30ea\u3092\u4f5c\u3063\u3066\u8a66\u3057\u305f\u3044\u6642\u306b\u3001Node.js \u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u306a\u3069\u3067\u5f15\u3063\u304b\u304b\u308a\u51fa\u9f3b\u3092\u304f\u3058\u304b\u308c\u308b\u3053\u3068\u304c\u591a\u3044\u3002\u683c\u95d8\u3057\u3066\u3044\u308b\u5185\u306b\u30a2\u30d7\u30ea\u4f5c\u6210\u610f\u6b32\u304c\u5931\u308f\u308c\u3066&#8230; \u307f\u305f\u3044\u306a\u3053\u3068\u306b\u306a\u308a\u3084\u3059\u304f\u3001Docker \u3092\u4f7f\u3063\u3066\u6642\u9593\u3092\u304b\u3051\u305a\u306b\u958b\u767a\u3092\u59cb\u3081\u3089\u308c\u308b\u3088\u3046\u306b\u3057\u305f\u3044\u3068\u3053\u308d\u3002\u6700\u8fd1\u826f\u304f\u76ee\u306b\u3059\u308b Next.js \u3082\u6c17\u306b\u306a\u308b\u3057\u3001\u306f\u3058\u3081\u304b\u3089 TypeScript \u306b\u3057\u3066\u304a\u3044\u305f\u65b9\u304c\u3044\u3044\u306e\u304b\u3082\u3068\u601d\u3044\u59cb\u3081\u3066\u3044\u308b\u3002\u66f4\u306b\u3001\u4f55\u304b\u4f5c\u308b\u6642\u306b UI \u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306f\u5fc5\u9808\u3060\u306a\u30fc\u3068\u601d\u3046\u3002<\/p>\n\n\n\n<p>\u3068\u3044\u3046\u308f\u3051\u3067 Next.js + MUI + TypeScript \u306e\u958b\u767a\u74b0\u5883\u3092 Docker \u3067\u4f5c\u3063\u3066\u307f\u3088\u3046\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\" data-file=\"Dockerfile\"><code>FROM node\n\nWORKDIR \/app<\/code><\/pre><\/div>\n\n\n\n<p><\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\" data-file=\"docker-compose.yaml\"><code>version: &#39;3&#39;\nservices:\n  app:\n    build:\n      context: .\n    tty: true\n    ports:\n      - &quot;3000:3000&quot;\n    volumes:\n      - .\/src:\/app\n    command: sh -c &quot;npm run dev&quot;<\/code><\/pre><\/div>\n\n\n\n<p>\u3053\u306e2\u3064\u306e\u30d5\u30a1\u30a4\u30eb\u3092\u4f5c\u3063\u3066\u304b\u3089<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>docker-compose build\ndocker-compose run --rm app sh -c &#39;curl https:\/\/codeload.github.com\/mui\/material-ui\/tar.gz\/master | tar -xz --strip=3  material-ui-master\/examples\/nextjs-with-typescript&#39;\ndocker-compose run --rm app sh -c &#39;cd src | npm install&#39;\ndocker-compose up<\/code><\/pre><\/div>\n\n\n\n<p>http:\/\/localhost:3000\/ \u3078\u30a2\u30af\u30bb\u30b9\u3059\u308b\u3068\u4e0b\u8a18\u304c\u8868\u793a\u3055\u308c\u308b\u3002<\/p>\n\n\n\n<figure class=\"wp-block-image size-large\"><img loading=\"lazy\" decoding=\"async\" width=\"840\" height=\"283\" src=\"https:\/\/i0.wp.com\/mattarishitemota.com\/wp-content\/uploads\/2022\/11\/7689850b8b085eb84d177d7bcfaf7324.png?resize=840%2C283&#038;ssl=1\" alt=\"\" class=\"wp-image-2658\" srcset=\"https:\/\/i0.wp.com\/mattarishitemota.com\/wp-content\/uploads\/2022\/11\/7689850b8b085eb84d177d7bcfaf7324.png?resize=1024%2C345&amp;ssl=1 1024w, https:\/\/i0.wp.com\/mattarishitemota.com\/wp-content\/uploads\/2022\/11\/7689850b8b085eb84d177d7bcfaf7324.png?resize=300%2C101&amp;ssl=1 300w, https:\/\/i0.wp.com\/mattarishitemota.com\/wp-content\/uploads\/2022\/11\/7689850b8b085eb84d177d7bcfaf7324.png?resize=768%2C259&amp;ssl=1 768w, https:\/\/i0.wp.com\/mattarishitemota.com\/wp-content\/uploads\/2022\/11\/7689850b8b085eb84d177d7bcfaf7324.png?w=1482&amp;ssl=1 1482w\" sizes=\"(max-width: 840px) 100vw, 840px\" data-recalc-dims=\"1\" \/><\/figure>\n\n\n\n<p>\u4e0b\u8a18\u3092\u53c2\u8003\u306b\u3057\u305f\u3002<\/p>\n\n\n\n<p><a href=\"https:\/\/zenn.dev\/temple_c_tech\/articles\/setup-next-on-docker#create-next-app\">https:\/\/zenn.dev\/temple_c_tech\/articles\/setup-next-on-docker#create-next-app<\/a><\/p>\n\n\n\n<p><a href=\"https:\/\/github.com\/mui\/material-ui\/tree\/master\/examples\/nextjs-with-typescript\">https:\/\/github.com\/mui\/material-ui\/tree\/master\/examples\/nextjs-with-typescript<\/a><\/p>\n\n\n\n<p><a href=\"https:\/\/qiita.com\/yyos\/items\/409784a040d20a2c2d4a\">https:\/\/qiita.com\/yyos\/items\/409784a040d20a2c2d4a<\/a><\/p>\n\n\n\n<h5 class=\"wp-block-heading\">2022.11.23 \u8ffd\u8a18<\/h5>\n\n\n\n<p>Mac + Docker Desktop \u306a\u3089\u554f\u984c\u306a\u304b\u3063\u305f\u306e\u3060\u304c\u3001Windows + WSL2 \u306e\u74b0\u5883\u3067\u8a66\u3057\u305f\u3068\u3053\u308d\u3001\u30db\u30c3\u30c8\u30ea\u30ed\u30fc\u30c9\u304c\u3081\u3061\u3083\u304f\u3061\u3083\u9045\u3044\u73fe\u8c61\u304c\u767a\u751f&#8230;<\/p>\n\n\n\n<p>\u4e0b\u8a18\u306e\u5bfe\u5fdc\u3092\u3057\u305f\u3068\u3053\u308d\u3001\u5909\u66f4\u691c\u77e5\u304b\u3089\u30b3\u30f3\u30d1\u30a4\u30eb\u307e\u3067\u306f\u901f\u304f\u306a\u3063\u305f\u306e\u3060\u304c\u3001\u30d6\u30e9\u30a6\u30b6\u3067\u306e\u30a2\u30af\u30bb\u30b9\u304c\u3081\u3061\u3083\u304f\u3061\u3083\u9045\u3044\u72b6\u6cc1\u304c\u7d9a\u3044\u3066\u3044\u308b\u3002\u3042\u3068\u3001CPU\u8ca0\u8377\u304c\u304b\u306a\u308a\u9ad8\u3044\u72b6\u614b\u306b\u306a\u3063\u3066\u3057\u307e\u3046\u306e\u3067\u305d\u308c\u3082\u8003\u3048\u3082\u306e\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\" data-file=\"docker-compose.yml\" data-line=\"11,12\"><code>version: &#39;3&#39;\nservices:\n  app:\n    build:\n      context: .\n    tty: true\n    ports:\n      - &quot;3000:3000&quot;\n    volumes:\n      - .\/src:\/app\n    environment:\n      - WATCHPACK_POLLING=true\n    command: sh -c &quot;npm run dev&quot;<\/code><\/pre><\/div>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\" data-file=\"\/etc\/wsl.conf\"><code>[automount]\nroot=&quot;\/home\/mnt\/&quot;<\/code><\/pre><\/div>\n\n\n\n<p>\u306a\u304a\u3001\u4e0a\u8a18\u3067\u30de\u30a6\u30f3\u30c8\u5148\u3092\u5909\u66f4\u3057\u305f\u3089 VSCode \u306e\u30bf\u30fc\u30df\u30ca\u30eb\u3067 wsl \u30b3\u30de\u30f3\u30c9\u3067\u30a2\u30af\u30bb\u30b9\u3057\u305f\u6642\u306b\u3044\u3061\u3044\u3061\u79fb\u52d5\u3059\u308b\u5fc5\u8981\u304c\u3042\u308b\u304b\u3068\u601d\u3063\u305f\u304c\u3001\u30de\u30a6\u30f3\u30c8\u5148\u3092\u8a8d\u8b58\u3057\u3066\u3044\u308b\u3088\u3046\u3067\u3001\u65b0\u3057\u3044\u30de\u30a6\u30f3\u30c8\u5148\u306e\u30ab\u30ec\u30f3\u30c8\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u3092\u958b\u3044\u3066\u304f\u308c\u305f\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u3055\u3063\u3068 Web \u30a2\u30d7\u30ea\u3092\u4f5c\u3063\u3066\u8a66\u3057\u305f\u3044\u6642\u306b\u3001Node.js \u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u306a\u3069\u3067\u5f15\u3063\u304b\u304b\u308a\u51fa\u9f3b\u3092\u304f\u3058\u304b\u308c\u308b\u3053\u3068\u304c\u591a\u3044\u3002\u683c\u95d8\u3057\u3066\u3044\u308b\u5185\u306b\u30a2\u30d7\u30ea\u4f5c\u6210\u610f\u6b32\u304c\u5931\u308f\u308c\u3066&#8230; \u307f\u305f\u3044\u306a\u3053\u3068\u306b\u306a\u308a\u3084\u3059\u304f\u3001Docker \u3092\u4f7f\u3063\u3066 <span class=\"more-text\">&hellip;<\/span><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_monsterinsights_skip_tracking":false,"_monsterinsights_sitenote_active":false,"_monsterinsights_sitenote_note":"","_monsterinsights_sitenote_category":0,"footnotes":""},"categories":[9],"tags":[34,36,35],"jetpack_featured_media_url":"","jetpack_sharing_enabled":true,"jetpack-related-posts":[{"id":611,"url":"https:\/\/mattarishitemota.com\/?p=611","url_meta":{"origin":2657,"position":0},"title":"Angular\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u30a2\u30c3\u30d7\uff085.2.11\u21926.x\uff09","author":"Owner","date":"2020\u5e744\u67084\u65e5","format":false,"excerpt":"4\u21925\u306b\u5f15\u304d\u7d9a\u304d\u3001Angular Update Guide \u306b\u5f93\u3044\u5bfe\u5fdc\u3057\u3066\u307f\u308b\u3002 https:\/\/u\u2026","rel":"","context":"IT","block_context":{"text":"IT","link":"https:\/\/mattarishitemota.com\/?cat=9"},"img":{"alt_text":"","src":"","width":0,"height":0},"classes":[]},{"id":533,"url":"https:\/\/mattarishitemota.com\/?p=533","url_meta":{"origin":2657,"position":1},"title":"Angular\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u30a2\u30c3\u30d7\uff084.0.1\u21925.x\uff09","author":"Owner","date":"2020\u5e743\u670822\u65e5","format":false,"excerpt":"Angular Update Guide \u306b\u5f93\u3044\u5bfe\u5fdc\u3057\u3066\u307f\u308b\u3002 https:\/\/update.ang\u2026","rel":"","context":"IT","block_context":{"text":"IT","link":"https:\/\/mattarishitemota.com\/?cat=9"},"img":{"alt_text":"","src":"","width":0,"height":0},"classes":[]},{"id":2533,"url":"https:\/\/mattarishitemota.com\/?p=2533","url_meta":{"origin":2657,"position":2},"title":"\u4eca\u3055\u3089 Expo SDK36 \u3067 jest \u3092\u4f7f\u3063\u3066\u30e6\u30cb\u30c3\u30c8\u30c6\u30b9\u30c8\u3057\u305f\u3044","author":"Owner","date":"2022\u5e747\u670811\u65e5","format":false,"excerpt":"Expo \u306e\u30a2\u30d7\u30ea\u3067\u3001\u30ed\u30b8\u30c3\u30af\u304c\u8907\u96d1\u306a\u30e6\u30fc\u30c6\u30a3\u30ea\u30c6\u30a3\u95a2\u6570\u3092\u30d4\u30f3\u30dd\u30a4\u30f3\u30c8\u3067\u30c6\u30b9\u30c8\u3057\u305f\u3044\u3002\u3057\u304b\u3082\u30bd\u30fc\u30b9\u306f\u2026","rel":"","context":"IT","block_context":{"text":"IT","link":"https:\/\/mattarishitemota.com\/?cat=9"},"img":{"alt_text":"","src":"","width":0,"height":0},"classes":[]},{"id":1347,"url":"https:\/\/mattarishitemota.com\/?p=1347","url_meta":{"origin":2657,"position":3},"title":"now \u30b3\u30de\u30f3\u30c9\u3067\u306e\u30c7\u30d7\u30ed\u30a4\u3067 The specified token is not valid \u30a8\u30e9\u30fc","author":"Owner","date":"2020\u5e7412\u67082\u65e5","format":false,"excerpt":"\u4e45\u3057\u3076\u308a\u306b now \u3067\u30c7\u30d7\u30ed\u30a4\u3057\u3088\u3046\u3068\u3059\u308b\u3068\u3001\u4e0b\u8a18\u306e\u30a8\u30e9\u30fc\u3002 UPDATE AVAILABLE Ru\u2026","rel":"","context":"IT","block_context":{"text":"IT","link":"https:\/\/mattarishitemota.com\/?cat=9"},"img":{"alt_text":"","src":"","width":0,"height":0},"classes":[]},{"id":2518,"url":"https:\/\/mattarishitemota.com\/?p=2518","url_meta":{"origin":2657,"position":4},"title":"Expo\u3067firebase\u3092\u4f7f\u3044\u305f\u3044","author":"Owner","date":"2022\u5e747\u67088\u65e5","format":false,"excerpt":"\u4e0b\u8a18\u306e\u516c\u5f0f\u30ac\u30a4\u30c9\u306b\u6cbf\u3063\u3066\u5c0e\u5165\u3057\u305f\u3068\u3053\u308d\u3001\u30b3\u30f3\u30d1\u30a4\u30eb\u6642\u306b\u30a8\u30e9\u30fc\u3002 https:\/\/firebase.g\u2026","rel":"","context":"IT","block_context":{"text":"IT","link":"https:\/\/mattarishitemota.com\/?cat=9"},"img":{"alt_text":"","src":"","width":0,"height":0},"classes":[]},{"id":2365,"url":"https:\/\/mattarishitemota.com\/?p=2365","url_meta":{"origin":2657,"position":5},"title":"Electron Forge \u306e Webpack \u30c6\u30f3\u30d7\u30ec\u30fc\u30c8\u3067 Electron Preferences \u3092\u4f7f\u3046\u3068\u3001\u8a2d\u5b9a\u753b\u9762\u304c\u771f\u3063\u767d\u306b\u306a\u308b","author":"Owner","date":"2022\u5e742\u670811\u65e5","format":false,"excerpt":"\u72b6\u6cc1\u3092\u78ba\u8a8d\u3059\u308b\u305f\u3081\u3001debug: true \u306b\u3057\u3066 DevTools \u3092\u8868\u793a\u3057\u3066\u307f\u308b\u3002 const \u2026","rel":"","context":"IT","block_context":{"text":"IT","link":"https:\/\/mattarishitemota.com\/?cat=9"},"img":{"alt_text":"","src":"","width":0,"height":0},"classes":[]}],"_links":{"self":[{"href":"https:\/\/mattarishitemota.com\/index.php?rest_route=\/wp\/v2\/posts\/2657"}],"collection":[{"href":"https:\/\/mattarishitemota.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/mattarishitemota.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/mattarishitemota.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/mattarishitemota.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=2657"}],"version-history":[{"count":4,"href":"https:\/\/mattarishitemota.com\/index.php?rest_route=\/wp\/v2\/posts\/2657\/revisions"}],"predecessor-version":[{"id":2663,"href":"https:\/\/mattarishitemota.com\/index.php?rest_route=\/wp\/v2\/posts\/2657\/revisions\/2663"}],"wp:attachment":[{"href":"https:\/\/mattarishitemota.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=2657"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/mattarishitemota.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=2657"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/mattarishitemota.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=2657"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}