{"id":1715,"date":"2022-07-21T21:26:21","date_gmt":"2022-07-21T12:26:21","guid":{"rendered":"https:\/\/www.miracleave.co.jp\/contents\/?p=1715"},"modified":"2023-05-22T11:34:38","modified_gmt":"2023-05-22T02:34:38","slug":"post-1715","status":"publish","type":"post","link":"https:\/\/www.miracleave.co.jp\/contents\/1715\/post-1715\/","title":{"rendered":"Docker\u3067Python\u00d7Django\u00d7Vue.js\u306e\u74b0\u5883\u3092\u69cb\u7bc9\u3059\u308b(\u30b5\u30fc\u30d0\u30fc\u8d77\u52d5\u7de8)"},"content":{"rendered":"\n<p>\u3053\u3093\u306b\u3061\u306f\u3001\u7af9\u6751\u3067\u3059\uff01<\/p>\n\n\n\n<p>\u5148\u6708\u3001\u5f0a\u793e\u3067\u5b9f\u65bd\u3057\u305fmirameet\u300c\u73fe\u5834\u3067\u5f79\u7acb\u3064\u5b9f\u8df5Vue.js!\uff5eEC\u30b5\u30a4\u30c8\u3092\u4f5c\u6210\u3057\u3066\u307f\u308b\uff5e\u300d\u3067\u306f\u89e6\u308c\u306a\u304b\u3063\u305f\u3001Docker\u3092\u7528\u3044\u3066\u306e\u74b0\u5883\u69cb\u7bc9\u90e8\u5206\u306b\u3064\u3044\u3066\u3001\u5099\u5fd8\u9332\u3082\u517c\u306d\u3066\u66f8\u3044\u3066\u3044\u304d\u305f\u3044\u3068\u601d\u3044\u307e\u3059\u3002<\/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\u308a\u307e\u3057\u305f\u3002<br>\u30d0\u30c3\u30af\u30a8\u30f3\u30c9(server)\u3068\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9(client)\u3067\u30d5\u30a9\u30eb\u30c0\u3092\u5206\u3051\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><img decoding=\"async\" width=\"295\" height=\"496\" src=\"https:\/\/www.miracleave.co.jp\/contents\/wp-content\/uploads\/2022\/07\/image.png\" alt=\"\" class=\"wp-image-1716\" srcset=\"https:\/\/www.miracleave.co.jp\/contents\/wp-content\/uploads\/2022\/07\/image.png 295w, https:\/\/www.miracleave.co.jp\/contents\/wp-content\/uploads\/2022\/07\/image-178x300.png 178w\" sizes=\"(max-width: 295px) 100vw, 295px\" \/><\/figure>\n\n\n\n<h2 class=\"wp-block-heading\">docker-compose.yml<\/h2>\n\n\n\n<p>Python\u74b0\u5883\u3068Vue.js\u74b0\u5883\u3092\u5225\u30b5\u30fc\u30d0\u30fc\u3067\u69cb\u7bc9\u3059\u308b\u306e\u3067\u3001docker-compose.yml\u3092\u6e96\u5099\u3057\u307e\u3059\u3002<br>\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u3092server\u3001\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u3092client\u3068\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u30fbdocker-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\n  server:\n    build:\n      context: .\/server\n      dockerfile: Dockerfile\n    volumes:\n     - &#39;.\/server:\/usr\/src&#39;\n    ports:\n     - &quot;8000:8000&quot;\n    tty: true\n    stdin_open: true\n\n  client:\n    build:\n      context: .\/client\n      dockerfile: Dockerfile\n    volumes:\n     - &#39;.\/client\/mysite:\/usr\/src&#39;\n    ports:\n     - &quot;8080:8080&quot;\n    tty: true\n    stdin_open: true\n    depends_on:\n     - server\n    environment:\n     - NODE_ENV=development\n<\/code><\/pre><\/div>\n\n\n\n<p>client\u5074\u306e\u8a2d\u5b9a\u3067\u3001\u4f9d\u5b58\u95a2\u4fc2\u3092\u300cdepends_on\u300d\u306b\u3066\u660e\u793a\u3057\u307e\u3059\u3002<br>\u307e\u305f\u3001\u30b3\u30f3\u30c6\u30ca\u8d77\u52d5\u3092\u6301\u7d9a\u3055\u305b\u308b\u305f\u3081\u306b\u300ctty: true\u300d\u3092\u8a2d\u5b9a\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Dockerfile(server, client)<\/h2>\n\n\n\n<p>server\u7528\u3001client\u7528\u306eDockerfile\u3092\u305d\u308c\u305e\u308c\u6e96\u5099\u3057\u307e\u3059\u3002<br>\u305d\u308c\u305e\u308c\u306eWORKDIR\u306b\u306f\u3001docker-compose.yml\u306evolumes\u3067\u8a2d\u5b9a\u3057\u305f\u300c\/usr\/src\u300d\u3092\u6307\u5b9a\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u30fbDockerfile(server\u7528)<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code># pull official base image\nFROM python:3.9-slim-buster\n\nWORKDIR \/usr\/src\n\n# set working directory\nENV PYTHONDONTWRITEBYTECODE 1\nENV PYTHONUNBUFFERED 1\n\n# install system dependencies\nRUN apt-get update \\\n    &amp;&amp; apt-get clean\n\n# install dependencies\nRUN pip install --upgrade pip\nCOPY .\/requirements.txt .\nRUN pip install -r requirements.txt\n\n# add app\nCOPY . .\n<\/code><\/pre><\/div>\n\n\n\n<p>\u30fbDockerfile(client\u7528)<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code># pull official base image\nFROM node:16-alpine\n\nWORKDIR \/usr\/src\n\nENV HOST 0.0.0.0\nEXPOSE 8080\n<\/code><\/pre><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">requirements.txt<\/h2>\n\n\n\n<p>Python\u74b0\u5883\u69cb\u7bc9\u6642\u3001pip\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3055\u305b\u308b\u30d1\u30c3\u30b1\u30fc\u30b8\u3092requirements.txt\u306b\u8a18\u8f09\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u30fbrequirements.txt<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>asgiref==3.5.0\nDjango==3.2.12\ndjangorestframework==3.13.1\ndjango-cors-headers==3.11.0\ndjango-filter==2.4.0\npytz==2021.3\nsqlparse==0.4.2<\/code><\/pre><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">\u30b3\u30f3\u30c6\u30ca\u8d77\u52d5<\/h2>\n\n\n\n<p>\u5fc5\u8981\u306a\u30d5\u30a1\u30a4\u30eb\u3092\u7528\u610f\u3057\u305f\u3089\u3001\u4ee5\u4e0b\u30b3\u30de\u30f3\u30c9\u3067\u30d3\u30eb\u30c9\u3057\u3001\u30b3\u30f3\u30c6\u30ca\u3092\u8d77\u52d5\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>docker-compose up -d --build<\/code><\/pre><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\uff1aDjango\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3092\u4f5c\u6210\u3059\u308b<\/h2>\n\n\n\n<p>\u30b3\u30f3\u30c6\u30ca\u304c\u8d77\u52d5\u3057\u305f\u3089\u3001Django\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3092\u4f5c\u6210\u3059\u308b\u70ba\u306bserver\u30b3\u30f3\u30c6\u30ca\u306b\u5165\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>docker-compose exec server bash<\/code><\/pre><\/div>\n\n\n\n<p>\u30b3\u30f3\u30c6\u30ca\u306b\u5165\u3063\u305f\u3089\u3001\u4ee5\u4e0b\u9806\u756a\u3067\u30b3\u30de\u30f3\u30c9\u3092\u6253\u3061\u3053\u307f\u307e\u3059\u3002<br>\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u307e\u3067\u4e00\u6c17\u306b\u5b9f\u65bd\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>django-admin startproject config .\npython manage.py startapp api\npython manage.py make migrations\npython manage.py migrate<\/code><\/pre><\/div>\n\n\n\n<p>\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u304c\u7d42\u308f\u3063\u305f\u3089\u3001\u30b5\u30fc\u30d0\u30fc\u3092\u8d77\u52d5\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>python manage.py runserver 0.0.0.0:8000<\/code><\/pre><\/div>\n\n\n\n<p><a href=\"http:\/\/localhost:8000\/\" target=\"_blank\" rel=\"noreferrer noopener\">http:\/\/localhost:8000\/<\/a>\u306b\u30a2\u30af\u30bb\u30b9\u3057\u3001Django\u306e\u30b9\u30bf\u30fc\u30c8\u753b\u9762\u304c\u8868\u793a\u3055\u308c\u3066\u3044\u308c\u3070OK\u3067\u3059\u3002<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><img decoding=\"async\" width=\"980\" height=\"922\" src=\"https:\/\/www.miracleave.co.jp\/contents\/wp-content\/uploads\/2022\/07\/image-1.png\" alt=\"\" class=\"wp-image-1717\" srcset=\"https:\/\/www.miracleave.co.jp\/contents\/wp-content\/uploads\/2022\/07\/image-1.png 980w, https:\/\/www.miracleave.co.jp\/contents\/wp-content\/uploads\/2022\/07\/image-1-300x282.png 300w, https:\/\/www.miracleave.co.jp\/contents\/wp-content\/uploads\/2022\/07\/image-1-768x723.png 768w\" sizes=\"(max-width: 980px) 100vw, 980px\" \/><\/figure>\n\n\n\n<h2 class=\"wp-block-heading\">\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\uff1aVue.js\u3067\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3092\u4f5c\u6210\u3059\u308b<\/h2>\n\n\n\n<p>server\u30b3\u30f3\u30c6\u30ca\u306b\u5165\u3063\u305f\u307e\u307e\u306a\u306e\u3067exit\u30b3\u30de\u30f3\u30c9\u3067\u629c\u3051\u308b\u304b\u3001\u65b0\u305f\u306a\u30bf\u30fc\u30df\u30ca\u30eb\u3092\u7acb\u3061\u4e0a\u3052\u3066\u304f\u3060\u3055\u3044\u3002<br>\u4ee5\u4e0b\u30b3\u30de\u30f3\u30c9\u3067client\u30b3\u30f3\u30c6\u30ca\u306b\u5165\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>docker-compose exec client sh<\/code><\/pre><\/div>\n\n\n\n<p>\u7d9a\u3044\u3066\u3001Vue CLI\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>npm install -g @vue\/cli<\/code><\/pre><\/div>\n\n\n\n<p>Vue\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3092\u4f5c\u6210\u3057\u307e\u3059\u3002<br>\u30db\u30b9\u30c8\u5074\u306b\u304a\u3051\u308bmysite\u76f4\u4e0b\u306b\u4f5c\u6210\u3057\u305f\u3044\u305f\u3081\u3001\u30ab\u30ec\u30f3\u30c8\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u3067\u6307\u5b9a\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>vue create .<\/code><\/pre><\/div>\n\n\n\n<p>\u30b3\u30de\u30f3\u30c9\u5b9f\u884c\u5f8c\u3001\u30ab\u30ec\u30f3\u30c8\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u306b\u4f5c\u6210\u3059\u308b\u304b\u3069\u3046\u304b\u805e\u304b\u308c\u308b\u306e\u3067\u3001\u300cy\u300d\u3092\u9078\u629e\u3057\u307e\u3059\u3002<br>\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3059\u308bVue\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u306f\u3001\u7279\u306b\u7406\u7531\u304c\u7121\u3051\u308c\u30703\u7cfb\u3092\u9078\u629e\u3057\u3066\u5927\u4e08\u592b\u3067\u3059\u3002<br>\u79c1\u306f\u3001\u73fe\u5728\u306e\u73fe\u5834\u30672\u7cfb\u3092\u4f7f\u7528\u3057\u3066\u3044\u308b\u3053\u3068\u3082\u3042\u308a\u30012\u7cfb\u3067\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u307e\u3057\u305f\u3002<\/p>\n\n\n\n<p>Vue\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u304c\u4f5c\u6210\u3055\u308c\u305f\u3089\u3001\u30b5\u30fc\u30d0\u30fc\u3092\u8d77\u52d5\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<div class=\"hcb_wrap\"><pre class=\"prism line-numbers lang-plain\"><code>npm run serve<\/code><\/pre><\/div>\n\n\n\n<p><a href=\"http:\/\/localhost:8080\/\" target=\"_blank\" rel=\"noreferrer noopener\">http:\/\/localhost:8080\/<\/a>\u306b\u30a2\u30af\u30bb\u30b9\u3057\u3001\u8d77\u52d5\u3055\u308c\u3066\u3044\u308b\u304b\u78ba\u8a8d\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<figure class=\"wp-block-image size-full is-resized\"><img decoding=\"async\" src=\"https:\/\/www.miracleave.co.jp\/contents\/wp-content\/uploads\/2022\/07\/image-2.png\" alt=\"\" class=\"wp-image-1719\" width=\"653\" height=\"718\" srcset=\"https:\/\/www.miracleave.co.jp\/contents\/wp-content\/uploads\/2022\/07\/image-2.png 653w, https:\/\/www.miracleave.co.jp\/contents\/wp-content\/uploads\/2022\/07\/image-2-273x300.png 273w\" sizes=\"(max-width: 653px) 100vw, 653px\" \/><\/figure>\n\n\n\n<h2 class=\"wp-block-heading\">\u7d42\u308f\u308a\u306b<\/h2>\n\n\n\n<p>\u3053\u308c\u3067\u3001\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u3001\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u306e\u30b5\u30fc\u30d0\u30fc\u304c\u7acb\u3061\u4e0a\u304c\u308a\u307e\u3057\u305f\uff01<br>\u3053\u3053\u307e\u3067\u74b0\u5883\u3092\u69cb\u7bc9\u3057\u305f\u5f8c\u306f\u3001docker-compose.yml\u306b\u30b5\u30fc\u30d0\u30fc\u8d77\u52d5\u306ecommand\u3092\u8a2d\u5b9a\u3057\u3066\u304a\u3051\u3070\u3001<br>\u30b3\u30f3\u30c6\u30ca\u8d77\u52d5\u6642\u306b\u7acb\u3061\u4e0a\u304c\u308b\u306e\u3067\u697d\u3067\u3059\u3002\uff08\u30d5\u30ed\u30f3\u30c8\u30b5\u30fc\u30d0\u30fc\u306f\u8d77\u52d5\u306b\u5c11\u3057\u6642\u9593\u304c\u304b\u304b\u308a\u307e\u3059\uff09<\/p>\n\n\n\n<p>\u4eca\u56de\u306f\u30b5\u30fc\u30d0\u30fc\u8d77\u52d5\u7de8\u3068\u3044\u3046\u3053\u3068\u3067\u3001\u6b21\u56de\u306fCORS\u8a8d\u8a3c\u3084Django\u306esetting.py\u306e\u8a2d\u5b9a\u7b49\u306b\u3064\u3044\u3066\u66f8\u3051\u308c\u3070\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u3067\u306f\u307e\u305f\u6b21\u56de\u306e\u30c6\u30c3\u30af\u30d6\u30ed\u30b0\u3067\u304a\u4f1a\u3044\u3057\u307e\u3057\u3087\u3046\uff01<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u3053\u3093\u306b\u3061\u306f\u3001\u7af9\u6751\u3067\u3059\uff01 \u5148\u6708\u3001\u5f0a\u793e\u3067\u5b9f\u65bd\u3057\u305fmirameet\u300c\u73fe\u5834\u3067\u5f79\u7acb\u3064\u5b9f\u8df5Vue.js!\uff5eEC\u30b5\u30a4\u30c8\u3092\u4f5c\u6210\u3057\u3066\u307f\u308b\uff5e\u300d\u3067\u306f\u89e6\u308c\u306a\u304b\u3063\u305f\u3001Docker\u3092\u7528\u3044\u3066\u306e\u74b0\u5883\u69cb\u7bc9\u90e8\u5206\u306b\u3064\u3044\u3066\u3001\u5099\u5fd8\u9332\u3082\u517c\u306d\u3066\u66f8\u3044\u3066\u3044\u304d\u305f\u3044\u3068\u601d\u3044\u307e [&hellip;]<\/p>\n","protected":false},"author":17,"featured_media":1723,"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":[35,24,25,34,79],"class_list":["post-1715","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-tech","tag-django","tag-docker","tag-mirameet","tag-python","tag-vue-js"],"jetpack_featured_media_url":"https:\/\/www.miracleave.co.jp\/contents\/wp-content\/uploads\/2022\/07\/docker-eyecatch.png","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/www.miracleave.co.jp\/contents\/wp-json\/wp\/v2\/posts\/1715","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\/17"}],"replies":[{"embeddable":true,"href":"https:\/\/www.miracleave.co.jp\/contents\/wp-json\/wp\/v2\/comments?post=1715"}],"version-history":[{"count":8,"href":"https:\/\/www.miracleave.co.jp\/contents\/wp-json\/wp\/v2\/posts\/1715\/revisions"}],"predecessor-version":[{"id":2341,"href":"https:\/\/www.miracleave.co.jp\/contents\/wp-json\/wp\/v2\/posts\/1715\/revisions\/2341"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.miracleave.co.jp\/contents\/wp-json\/wp\/v2\/media\/1723"}],"wp:attachment":[{"href":"https:\/\/www.miracleave.co.jp\/contents\/wp-json\/wp\/v2\/media?parent=1715"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.miracleave.co.jp\/contents\/wp-json\/wp\/v2\/categories?post=1715"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.miracleave.co.jp\/contents\/wp-json\/wp\/v2\/tags?post=1715"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}