{"id":1509,"date":"2022-04-28T09:00:00","date_gmt":"2022-04-28T00:00:00","guid":{"rendered":"https:\/\/www.miracleave.co.jp\/contents\/?p=1509"},"modified":"2023-05-23T09:55:26","modified_gmt":"2023-05-23T00:55:26","slug":"vscode-golang-next","status":"publish","type":"post","link":"https:\/\/www.miracleave.co.jp\/contents\/1509\/vscode-golang-next\/","title":{"rendered":"VSCode\u3067Golang\u2716\ufe0eNext.js\u306e\u958b\u767a\u74b0\u5883\u3092\u69cb\u7bc9\u3057\u3066\u307f\u305f"},"content":{"rendered":"\n<h2 class=\"wp-block-heading\">\u306f\u3058\u3081\u306b<\/h2>\n\n\n\n<p>\u4e0a\u91ce\u3067\u3059\uff01<br>\u6700\u8fd1\u3001GraphQL(Golang)\u3068Next.js\u3092\u4f7f\u7528\u3057\u3066\u7c21\u5358\u306aWeb\u30a2\u30d7\u30ea\u3092\u4f5c\u3063\u305f\u308a\u3057\u3066\u3044\u307e\u3059\u3002\u4eca\u56de\u306f\u3053\u306eGraphQL\u3068Next.js\u306e\u7c21\u5358 Web\u30a2\u30d7\u30ea\u3092\u4f5c\u308b\u4e2d\u3067\u69cb\u7bc9\u3057\u305f\u958b\u767a\u74b0\u5883\u3092\u3054\u7d39\u4ecb\u3057\u3066\u3044\u304d\u305f\u3044\u3068\u601d\u3044\u307e\u3059\u3002<br><br>\u4eca\u56de\u306fVSCode\u306eRemote Containers\u3092\u4f7f\u7528\u3057\u3066\u69cb\u7bc9\u3057\u3066\u3044\u304d\u307e\u3059\u3002<br>Golang\u5074\u306b\u95a2\u3057\u3066\u306f\u3001\u30db\u30c3\u30c8\u30ea\u30ed\u30fc\u30c9\u3001\u30c7\u30d0\u30c3\u30af\u304c\u3067\u304d\u308b\u3088\u3046\u306b\u3057\u3001Next.js\u5074\u306b\u95a2\u3057\u3066\u306fPrettier\u306a\u3069\u3092\u5165\u308c\u3066\u3088\u308a\u958b\u767a\u304c\u3057\u3084\u3059\u3044\u3088\u3046\u306b\u3057\u3066\u3044\u304d\u307e\u3059\u3002<br><br>\u3067\u306f\u3001\u65e9\u901f\u69cb\u7bc9\u3057\u3066\u3044\u304d\u307e\u3059\uff01<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u30d5\u30a9\u30eb\u30c0\u69cb\u6210<\/h2>\n\n\n\n<p>\u30d5\u30a9\u30eb\u30c0\u69cb\u6210\u306f\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u4f5c\u6210\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>go-next\n|_server\n|       |_.devcontainer\n|       |           |_devcontainer.json\n|       |_.vscode\n|       |           |_launch.json\n|       |_Dockerfile  \n|       |_.air.toml\n|       |_main.go\n|\n|_client\n|       |_.devcontainer\n|       |           |_devcontainer.json\n|       |_Dockerfile  \n|\n|_docker-compose.yml<\/code><\/pre><\/div>\n\n\n\n<p>docker-compose.yml\u306b\u306f\u4ee5\u4e0b\u306e\u30b3\u30fc\u30c9\u3092\u66f8\u3044\u3066\u304f\u3060\u3055\u3044\u3002<\/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  server:\n    build:\n      context: .\/server\/\n      dockerfile: Dockerfile\n      target: dev\n    ports:\n      - 8888:8080\n      - 2345:2345\n    volumes:\n      - .\/server\/:\/app\n  client:\n    build:\n      context: .\/client\/\n      dockerfile: Dockerfile\n      target: dev\n    volumes:\n      - .\/client:\/app\n    ports:\n      - 3434:3000\n<\/code><\/pre><\/div>\n\n\n\n<p>go-next\/server\/main.go\u306b\u306f\u4ee5\u4e0b\u306e\u30b3\u30fc\u30c9\u3092\u66f8\u3044\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap go\"><pre class=\"prism line-numbers lang-go\" data-lang=\"Go\"><code>package main\n\nimport (\n\t&quot;github.com\/gin-gonic\/gin&quot;\n)\n\nfunc main() {\n\tr := gin.Default()\n\tr.GET(&quot;\/greeting&quot;, func(c *gin.Context) {\n\t\tgreeting := &quot;hello world&quot;\n\t\tc.JSON(200, gin.H{\n\t\t\t&quot;message&quot;: greeting,\n\t\t})\n\t})\n\tr.Run()\n}<\/code><\/pre><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">VSCode\u306e\u8a2d\u5b9a<\/h2>\n\n\n\n<p>\u307e\u305a\u306fVSCode\u3067go-next\u30d5\u30a9\u30eb\u30c0\u3092\u958b\u304d\u3001Extensions\u3067\u300cRemote &#8211; Containers\u300d\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u307e\u3059\u3002<br><img decoding=\"async\" src=\"https:\/\/storage.googleapis.com\/zenn-user-upload\/5f10efb523bf-20220411.png\" alt=\"\"><\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Golang\u5074\u306eVSCode\u306e\u8a2d\u5b9a<\/h2>\n\n\n\n<p>go-next\/server\/.devcontainer\/devcontainer.json\u306b\u306f\u4ee5\u4e0b\u306e\u30b3\u30fc\u30c9\u3092\u66f8\u3044\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap json\"><pre class=\"prism line-numbers lang-json\" data-lang=\"JSON\"><code>{\n  &quot;name&quot;: &quot;Go devcontainer&quot;,\n  &quot;dockerComposeFile&quot;: [\n    &quot;..\/..\/docker-compose.yml&quot;\n  ],\n  &quot;service&quot;: &quot;server&quot;,\n  &quot;workspaceFolder&quot;: &quot;\/app&quot;,\n  &quot;settings&quot;: {\n    &quot;go.toolsManagement.checkForUpdates&quot;: &quot;off&quot;,\n    &quot;go.gopath&quot;: &quot;\/go&quot;,\n    &quot;go.gocodeAutoBuild&quot;: true,\n    &quot;go.formatTool&quot;: &quot;gofmt&quot;,\n    &quot;go.useLanguageServer&quot;: true,\n    &quot;editor.tabSize&quot;: 2,\n    &quot;editor.formatOnPaste&quot;: true,\n    &quot;editor.formatOnSave&quot;: true,\n    &quot;editor.formatOnType&quot;: true,\n    &quot;editor.renderWhitespace&quot;: &quot;all&quot;,\n    &quot;editor.bracketPairColorization.enabled&quot;: true,\n    &quot;editor.guides.bracketPairs&quot;:&quot;active&quot;,\n    &quot;files.trimTrailingWhitespace&quot;: true,\n    &quot;files.trimFinalNewlines&quot;: true,\n    &quot;emeraldwalk.runonsave&quot;: {\n    \/\/ \u30c7\u30d0\u30c3\u30af\u6642\u3001air\u306b\u3088\u3063\u3066.tmp\/main\u306e\u30d7\u30ed\u30bb\u30b9\u304c\u8d77\u52d5\u3055\u308c\u308b\u306e\u3067\u3001\u30d5\u30a1\u30a4\u30eb\u4fdd\u5b58\u6642\u306b\u5f37\u5236\u7684\u306b.tmp\/main\u306e\u30d7\u30ed\u30bb\u30b9\u3092\u524a\u9664\u3059\u308b\n      &quot;commands&quot;: [\n        {\n          &quot;match&quot;: &quot;.*&quot;,\n          &quot;isAsync&quot;: false,\n          &quot;cmd&quot;: &quot;ps aux | grep &#39;.\/tmp\/main&#39; | grep -v grep | awk &#39;{ print $1 }&#39; | xargs kill&quot;\n        },\n      ]\n    }\n  },\n  &quot;extensions&quot;: [\n    &quot;golang.go&quot;,\n    &quot;editorconfig.editorconfig&quot;,\n    &quot;emeraldwalk.runonsave&quot;,\n    \/\/ \u30b3\u30fc\u30c9\u306e\u30b9\u30da\u30eb\u30c1\u30a7\u30c3\u30ab\u30fc\n    &quot;streetsidesoftware.code-spell-checker&quot;,\n  ],\n  &quot;onCreateCommand&quot;: &quot;&quot;,\n  &quot;updateContentCommand&quot;: &quot;&quot;,\n  &quot;postCreateCommand&quot;: &quot;&quot;,\n  &quot;shutdownAction&quot;: &quot;none&quot;\n}<\/code><\/pre><\/div>\n\n\n\n<p>go-next\/server\/Dockerfile\u306b\u306f\u4ee5\u4e0b\u306e\u30b3\u30fc\u30c9\u3092\u66f8\u3044\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>FROM golang:1.17-alpine as dev\n\nWORKDIR \/app\nRUN apk update &amp;&amp; apk add git\n\nRUN go install golang.org\/x\/tools\/cmd\/goimports@latest \\\n    &amp;&amp; go install golang.org\/x\/tools\/gopls@latest \\\n    &amp;&amp; go install golang.org\/x\/tools\/cmd\/godoc@latest \\\n    &amp;&amp; go install golang.org\/x\/lint\/golint@latest \\\n    &amp;&amp; go install github.com\/rogpeppe\/godef@latest \\\n    &amp;&amp; go install github.com\/nsf\/gocode@latest \\\n    # hot relord\n    &amp;&amp; go install github.com\/cosmtrek\/air@latest \\\n    # debug\n    &amp;&amp; go install github.com\/go-delve\/delve\/cmd\/dlv@latest\n\nCMD [&quot;air&quot;, &quot;-c&quot;, &quot;.air.toml&quot;]<\/code><\/pre><\/div>\n\n\n\n<p>go-next\/server\/.vscode\/launch.json\u306b\u306f\u4ee5\u4e0b\u306e\u30b3\u30fc\u30c9\u3092\u66f8\u3044\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap json\"><pre class=\"prism line-numbers lang-json\" data-lang=\"JSON\"><code>{\n  &quot;version&quot;: &quot;0.2.0&quot;,\n  &quot;configurations&quot;: [\n    {\n      &quot;name&quot;: &quot;Go&quot;,\n      &quot;type&quot;: &quot;go&quot;,\n      &quot;request&quot;: &quot;attach&quot;,\n      &quot;mode&quot;: &quot;remote&quot;,\n      &quot;cwd&quot;: &quot;${workspaceFolder}&quot;,\n      &quot;port&quot;: 2345,\n      &quot;host&quot;: &quot;0.0.0.0&quot;,\n      &quot;showLog&quot;: true,\n    }\n  ]\n}<\/code><\/pre><\/div>\n\n\n\n<p>go-next\/server\/.air.toml\u306b\u306f\u4ee5\u4e0b\u306e\u30b3\u30fc\u30c9\u3092\u66f8\u3044\u3066\u304f\u3060\u3055\u3044\u3002<br>\u73fe\u5728\u306e.ari.toml\u306f\u30c7\u30d0\u30c3\u30af\u7528\u306b\u306a\u3063\u3066\u3044\u307e\u3059\u3002\u30c7\u30d0\u30c3\u30af\u7528\u3067\u306f\u306a\u304f\u3001\u666e\u901a\u306e\u30db\u30c3\u30c8\u30ea\u30ed\u30fc\u30c9\u306e\u72b6\u614b\u306b\u3057\u305f\u3044\u5834\u5408\u306fDebug\u3068\u30b3\u30e1\u30f3\u30c8\u304c\u3042\u308b\u4e0b\u306e\u90e8\u5206\u306efull_bin\u3092\u30b3\u30e1\u30f3\u30c8\u30a2\u30a6\u30c8\u3057\u3001Customize binary\u3068\u30b3\u30e1\u30f3\u30c8\u304c\u3042\u308b\u4e0b\u306e\u90e8\u5206\u306e\u30b3\u30e1\u30f3\u30c8\u30a2\u30a6\u30c8\u3092\u89e3\u9664\u3059\u308b\u3068\u666e\u901a\u306e\u30db\u30c3\u30c8\u30ea\u30ed\u30fc\u30c9\u306e\u72b6\u614b\u306b\u623b\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>root = &quot;.&quot;\ntmp_dir = &quot;tmp&quot;\n\n[build]\n  bin = &quot;.\/tmp\/main -e=develop&quot;\n  cmd = &quot;go build -o .\/tmp\/main .&quot;\n  # It&#39;s not necessary to trigger build each time file changes if it&#39;s too frequent.\n  delay = 1000 # ms\n  # Ignore these filename extensions or directories.\n  exclude_dir = [&quot;assets&quot;, &quot;tmp&quot;, &quot;vendor&quot;]\n  # Exclude files.\n  exclude_file = []\n  exclude_regex = []\n  exclude_unchanged = false\n  follow_symlink = false\n  # Customize binary.\n  # full_bin = &quot;APP_ENV=dev APP_USER=air .\/tmp\/main&quot;\n  # Debug\n  full_bin = &quot;APP_ENV=dev APP_USER=air \/go\/bin\/dlv exec .\/tmp\/main --headless=true --listen=:2345 --api-version=2 --accept-multiclient&quot;\n  # Watch these directories if you specified.\n  include_dir = []\n  # Watch these filename extensions.\n  include_ext = [&quot;go&quot;, &quot;tpl&quot;, &quot;tmpl&quot;, &quot;html&quot;]\n  # Delay after sending Interrupt signal\n  kill_delay = 500 # ms\n  # This log file places in your tmp_dir.\n  log = &quot;air.log&quot;\n  # Send Interrupt signal before killing process (windows does not support this feature)\n  send_interrupt = false\n  # Stop running old binary when build errors occur.\n  stop_on_error = true\n\n[color]\n  main = &quot;magenta&quot;\n  watcher = &quot;cyan&quot;\n  build = &quot;yellow&quot;\n  runner = &quot;green&quot;\n\n[log]\n  time = false\n\n[misc]\n# Delete tmp directory on exit\nclean_on_exit = true<\/code><\/pre><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">Next.js\u5074\u306eVSCode\u306e\u8a2d\u5b9a<\/h2>\n\n\n\n<p>client\/.devcontainer\/devcontainer.json\u306b\u306f\u4ee5\u4e0b\u306e\u30b3\u30fc\u30c9\u3092\u66f8\u3044\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap json\"><pre class=\"prism line-numbers lang-json\" data-lang=\"JSON\"><code>{\n  &quot;name&quot;: &quot;Next devcontainer&quot;,\n  &quot;dockerComposeFile&quot;: [\n    &quot;..\/..\/docker-compose.yml&quot;\n  ],\n  &quot;service&quot;: &quot;client&quot;,\n  &quot;workspaceFolder&quot;: &quot;\/app&quot;,\n  &quot;settings&quot;: {\n    &quot;editor.tabSize&quot;: 2,\n    &quot;editor.formatOnPaste&quot;: true,\n    &quot;editor.formatOnSave&quot;: true,\n    &quot;editor.formatOnType&quot;: true,\n    &quot;editor.renderWhitespace&quot;: &quot;all&quot;,\n    &quot;editor.bracketPairColorization.enabled&quot;: true,\n    &quot;editor.guides.bracketPairs&quot;:&quot;active&quot;,\n    &quot;files.trimTrailingWhitespace&quot;: true,\n    &quot;files.trimFinalNewlines&quot;: true,\n  },\n  &quot;extensions&quot;: [\n    &quot;xabikos.javascriptsnippets&quot;,\n    &quot;formulahendry.auto-rename-tag&quot;,\n    &quot;formulahendry.auto-close-tag&quot;,\n    &quot;coenraads.bracket-pair-colorizer-2&quot;,\n    &quot;shardulm94.trailing-spaces&quot;,\n    &quot;esbenp.prettier-vscode&quot;,\n    &quot;dbaeumer.vscode-eslint&quot;,\n    &quot;visualstudioexptteam.vscodeintellicode&quot;,\n    &quot;foxundermoon.next-js&quot;,\n    \/\/ \u30b3\u30fc\u30c9\u306e\u30b9\u30da\u30eb\u30c1\u30a7\u30c3\u30ab\u30fc\n    &quot;streetsidesoftware.code-spell-checker&quot;,\n  ],\n  &quot;shutdownAction&quot;: &quot;none&quot;\n}<\/code><\/pre><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">Next.js\u306e\u30a2\u30d7\u30ea\u3092\u4f5c\u6210<\/h2>\n\n\n\n<p>docker-compose.yml\u30d5\u30a1\u30a4\u30eb\u304c\u5b58\u5728\u3059\u308b\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u4e0a\u3067\u4ee5\u4e0b\u30b3\u30de\u30f3\u30c9\u3092\u5b9f\u884c\u3057Next.js\u306e\u30a2\u30d7\u30ea\u3092\u4f5c\u6210\u3057\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-c\" data-lang=\"C\"><code>docker-compose run --rm client yarn create next-app --typescript<\/code><\/pre><\/div>\n\n\n\n<p>\u9014\u4e2d\u3067\u300c? What is your project named?\u300d\u3068\u805e\u304b\u308c\u308b\u306e\u3067\u300capp\u300d\u3068\u5165\u529b\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<p>go-next\/client\u30d5\u30a9\u30eb\u30c0\u76f4\u4e0b\u306b\u300cyarn create next-app\u300d\u3067\u4f5c\u6210\u3057\u305fapp\u30d5\u30a9\u30eb\u30c0\u304c\u4f5c\u6210\u3055\u308c\u308b\u306e\u3067\u3001\u3053\u306eapp\u30d5\u30a9\u30eb\u30c0\u306e\u4e2d\u8eab\u3092.\/client\u30d5\u30a9\u30eb\u30c0\u306b\u79fb\u52d5\u3057\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-c\" data-lang=\"C\"><code>mv .\/client\/app\/* .\/client\/app\/.* .\/client\nrm -r .\/client\/app<\/code><\/pre><\/div>\n\n\n\n<p>\u4ee5\u4e0a\u3067Next.js\u306e\u7528\u610f\u304c\u5b8c\u4e86\u3057\u307e\u3057\u305f\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Golang\u3001Next.js\u306e\u30b3\u30f3\u30c6\u30ca\u306b\u30a2\u30af\u30bb\u30b9\u3057\u3066\u307f\u308b<\/h2>\n\n\n\n<p>docker-compose.yml\u30d5\u30a1\u30a4\u30eb\u304c\u5b58\u5728\u3059\u308b\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u4e0a\u3067\u4ee5\u4e0b\u30b3\u30de\u30f3\u30c9\u3092\u5b9f\u884c\u3057\u30b3\u30f3\u30c6\u30ca\u3092\u7acb\u3061\u4e0a\u3052\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-c\" data-lang=\"C\"><code>docker-compose up -d<\/code><\/pre><\/div>\n\n\n\n<p>\u3067\u306f\u3001Golang\u306e\u30b3\u30f3\u30c6\u30ca\u306b\u30a2\u30af\u30bb\u30b9\u3057\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>Golang\u306eRemote Container\u306b\u63a5\u7d9a\u3059\u308b\u306b\u306fVSCode\u306e\u5de6\u4e0b\u306e\u30dc\u30bf\u30f3\u3092\u30af\u30ea\u30c3\u30af\u3057\u300cOpen Folder in Container\u300d\u3092\u30af\u30ea\u30c3\u30af\u3057go-next\/server\u30d5\u30a9\u30eb\u30c0\u3092\u9078\u629e\u3057\u307e\u3059\u3002<br>server\u30d5\u30a9\u30eb\u30c0\u3092\u9078\u629e\u3059\u308b\u3068\u81ea\u52d5\u3067server\u306eRemote Container\u306b\u63a5\u7d9a\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u30b3\u30f3\u30c6\u30ca\u5185\u306b\u5165\u3063\u3066go\u30d5\u30a1\u30a4\u30eb\u3092\u4f5c\u6210\u3057\u3001\u5b9f\u969b\u306b\u30b3\u30fc\u30c7\u30a3\u30f3\u30b0\u3092\u3057\u3066\u307f\u3066\u304f\u3060\u3055\u3044\u3002\u958b\u767a\u304c\u3057\u3084\u3059\u304f\u306a\u3063\u3066\u3044\u308b\u306f\u305a\u3067\u3059\u3002<\/p>\n\n\n\n<p>Next.js\u7528\u306e\u30b3\u30f3\u30c6\u30ca\u3078\u306e\u30a2\u30af\u30bb\u30b9\u3082\u5148\u7a0b\u3068\u540c\u69d8(Golang\u5074)\u3067VSCode\u306e\u5de6\u4e0b\u306e\u30dc\u30bf\u30f3\u3092\u30af\u30ea\u30c3\u30af\u3057\u300cOpen Folder in Container\u300d\u3092\u30af\u30ea\u30c3\u30af\u3057go-next\/client\u30d5\u30a9\u30eb\u30c0\u3092\u9078\u629e\u3059\u308b\u3053\u3068\u3067Next.js\u306e\u30b3\u30f3\u30c6\u30ca\u306b\u30a2\u30af\u30bb\u30b9\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>Next.js\u5074\u306e\u30b3\u30f3\u30c6\u30ca\u3082\u540c\u69d8\u306b\u30d5\u30a1\u30a4\u30eb\u4fdd\u5b58\u6642\u306b\u81ea\u52d5\u3067\u30d5\u30a9\u30fc\u30de\u30c3\u30c8\u3055\u308c\u305f\u308a\u306a\u3069\u958b\u767a\u304c\u3057\u3084\u3059\u304f\u306a\u3063\u3066\u3044\u308b\u306e\u304c\u5206\u304b\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<p>Golang\u5074\u306eDebug\u306b\u95a2\u3057\u3066\u306f\u3001Golang\u5074\u306eRemote Container\u306b\u63a5\u7d9a\u3057VSCode\u306e\u30b5\u30a4\u30c9\u30e1\u30cb\u30e5\u30fc\u304b\u3089\u300cRun on Debug\u300d\u3092\u30af\u30ea\u30c3\u30af\u3057\u300cGo\u300d\u3068\u8a18\u8f09\u3057\u3066\u3042\u308b\u96a3\u306e\u518d\u751f\u30dc\u30bf\u30f3\u3092\u30af\u30ea\u30c3\u30af\u3059\u308b\u3068\u30c7\u30d0\u30c3\u30af\u304c\u958b\u59cb\u3057\u307e\u3059\u3002<br>\u30c7\u30d0\u30c3\u30af\u3092\u958b\u59cb\u3059\u308b\u969b\u306f\u3001.air.toml\u30d5\u30a1\u30a4\u30eb\u5185\u306eDebug\u3068\u30b3\u30e1\u30f3\u30c8\u30a2\u30a6\u30c8\u304c\u3055\u308c\u3066\u3044\u308b\u4e0b\u306efull_bin\u3068\u3044\u3046\u7b87\u6240\u306e\u30b3\u30e1\u30f3\u30c8\u30a2\u30a6\u30c8\u3092\u89e3\u9664\u3057\u3001Customize binary\u3068\u30b3\u30e1\u30f3\u30c8\u30a2\u30a6\u30c8\u3055\u308c\u3066\u3044\u308b\u4e0b\u306efull_bin\u3092\u30b3\u30e1\u30f3\u30c8\u30a2\u30a6\u30c8\u3059\u308b\u3088\u3046\u306b\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n<p>\u4ee5\u4e0a\u3067Next.js\u3068Golang\u306e\u958b\u767a\u74b0\u5883\u306e\u69cb\u7bc9\u306f\u5b8c\u4e86\u3067\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u307e\u3068\u3081<\/h2>\n\n\n\n<p>\u4eca\u56de\u306fGolang\u2716\ufe0eNext.js\u306e\u958b\u767a\u74b0\u5883\u3092\u3054\u7d39\u4ecb\u3057\u307e\u3057\u305f\u3002\u4eca\u56de\u7d39\u4ecb\u3057\u305fRemote Containers\u3092\u4f7f\u7528\u3057\u3066\u306e\u958b\u767a\u74b0\u5883\u3067\u3059\u304c\u3001\u500b\u4eba\u3054\u3068\u306bVSCode\u306e\u8a2d\u5b9a\u3092\u305b\u305a\u306b\u6e08\u307f\u3001\u307e\u305f\u30ed\u30fc\u30ab\u30eb\u74b0\u5883\u3082\u6c5a\u3055\u305a\u306b\u6e08\u3080\u306e\u3067\u304b\u306a\u308a\u304a\u52e7\u3081\u3067\u3059\u3002\u4ed6\u306b\u3082\u304a\u52e7\u3081\u306e\u8a2d\u5b9a\u65b9\u6cd5\u306a\u3069\u304c\u3042\u308c\u3070\u7d39\u4ecb\u3057\u3066\u3044\u304d\u307e\u3059\uff01<br><br>\u4eca\u56de\u306f\u4ee5\u4e0a\u3068\u306a\u308a\u307e\u3059\u3002\u3042\u308a\u304c\u3068\u3046\u3054\u3056\u3044\u307e\u3057\u305f\uff01<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u306f\u3058\u3081\u306b \u4e0a\u91ce\u3067\u3059\uff01\u6700\u8fd1\u3001GraphQL(Golang)\u3068Next.js\u3092\u4f7f\u7528\u3057\u3066\u7c21\u5358\u306aWeb\u30a2\u30d7\u30ea\u3092\u4f5c\u3063\u305f\u308a\u3057\u3066\u3044\u307e\u3059\u3002\u4eca\u56de\u306f\u3053\u306eGraphQL\u3068Next.js\u306e\u7c21\u5358 Web\u30a2\u30d7\u30ea\u3092\u4f5c\u308b\u4e2d\u3067\u69cb\u7bc9\u3057\u305f\u958b\u767a\u74b0\u5883\u3092\u3054\u7d39\u4ecb\u3057\u3066 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":1516,"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,"swell_btn_cv_data":"","_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[1],"tags":[17,104,112,111],"class_list":["post-1509","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-tech","tag-golang","tag-next-js","tag-remote-containers","tag-vs-code"],"jetpack_featured_media_url":"https:\/\/www.miracleave.co.jp\/contents\/wp-content\/uploads\/2022\/04\/Visual_Studio_Code_1.35_icon.svg_.png","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/www.miracleave.co.jp\/contents\/wp-json\/wp\/v2\/posts\/1509","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.miracleave.co.jp\/contents\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.miracleave.co.jp\/contents\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.miracleave.co.jp\/contents\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.miracleave.co.jp\/contents\/wp-json\/wp\/v2\/comments?post=1509"}],"version-history":[{"count":8,"href":"https:\/\/www.miracleave.co.jp\/contents\/wp-json\/wp\/v2\/posts\/1509\/revisions"}],"predecessor-version":[{"id":2368,"href":"https:\/\/www.miracleave.co.jp\/contents\/wp-json\/wp\/v2\/posts\/1509\/revisions\/2368"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.miracleave.co.jp\/contents\/wp-json\/wp\/v2\/media\/1516"}],"wp:attachment":[{"href":"https:\/\/www.miracleave.co.jp\/contents\/wp-json\/wp\/v2\/media?parent=1509"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.miracleave.co.jp\/contents\/wp-json\/wp\/v2\/categories?post=1509"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.miracleave.co.jp\/contents\/wp-json\/wp\/v2\/tags?post=1509"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}