{
    "componentChunkName": "component---src-templates-blog-post-jsx",
    "path": "/post/use-docker-instead-of-dotenv/",
    "result": {"data":{"site":{"siteMetadata":{"title":"WEB EGG","author":"Leko - CTO at Yuimedi"}},"markdownRemark":{"id":"b20bbd11-88b1-5a1f-8807-2a7df3ac2fde","excerpt":"こんにちは。 一時期はAnsibleにお熱でしたが、最近はDocker(-compose)にお熱です。 ※それぞれ全く別のツールですが、“開発環境を作る”という視点で見れば手段は違えど目的は同じだと思ってます。 Dockerを利用するようになり、環境変数の注入が簡単になったので気づけば.env…","html":"<p>こんにちは。<br>\n一時期はAnsibleにお熱でしたが、最近はDocker(-compose)にお熱です。<br>\n※それぞれ全く別のツールですが、“開発環境を作る”という視点で見れば手段は違えど目的は同じだと思ってます。</p>\n<p>Dockerを利用するようになり、環境変数の注入が簡単になったので気づけば.env系のライブラリ要らなくなっているなあと気づきました。<br>\nどんな風に、と言われてもドキュメントの通り使ったらそうなる、としか言い様が無いのですが、<br>\n一応備忘録として残しておこうと思います。</p>\n<!--more-->\n<h2 id=\"docker-runコマンド\" style=\"position:relative;\"><a href=\"#docker-run%E3%82%B3%E3%83%9E%E3%83%B3%E3%83%89\" aria-label=\"docker runコマンド permalink\" class=\"autolink-header before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>docker runコマンド</h2>\n<div class=\"gatsby-highlight\" data-language=\"text\"><pre class=\"language-text\"><code class=\"language-text\">docker run {SOME_CONTAINER} -e SOME_VAR1=SOME_VALUE1 -e SOME_VAR2=SOME_VALUE2</code></pre></div>\n<p>というように<code>e</code>オプションを与えれば環境変数を指定可能です。</p>\n<h2 id=\"dockerにenvファイルを読み込ませる\" style=\"position:relative;\"><a href=\"#docker%E3%81%ABenv%E3%83%95%E3%82%A1%E3%82%A4%E3%83%AB%E3%82%92%E8%AA%AD%E3%81%BF%E8%BE%BC%E3%81%BE%E3%81%9B%E3%82%8B\" aria-label=\"dockerにenvファイルを読み込ませる permalink\" class=\"autolink-header before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>Dockerに.envファイルを読み込ませる</h2>\n<div class=\"gatsby-highlight\" data-language=\"text\"><pre class=\"language-text\"><code class=\"language-text\">docker run {SOME_CONTAINER} --env-file .env</code></pre></div>\n<p>のように、環境変数が記述されたファイルを指定可能です。<br>\n書式は<code>.env</code>でよく使ってるそのままの書式で指定可能です。</p>\n<p><strong>これがdotenv系ライブラリが不要になった要因です</strong><br>\nわざわざプログラム上から読み込まなくても、コンテナ内の環境変数をあらかじめ設定しておけるので要らなくなりました。</p>\n<p>本番サーバでDockerを使わず、更にdotenvを利用したい場合、結局dotenvによせざるを得ないんですが、<br>\nPaaSとか使ってるなら、dotenvを本番で使うケースは稀だろうと思います。</p>\n<h2 id=\"docker-composeでの利用\" style=\"position:relative;\"><a href=\"#docker-compose%E3%81%A7%E3%81%AE%E5%88%A9%E7%94%A8\" aria-label=\"docker composeでの利用 permalink\" class=\"autolink-header before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>Docker composeでの利用</h2>\n<p>Docker composeで指定できるオプションは基本的に<code>docker run</code>に渡せるオプションに対応しています。<br>\n環境変数周りに関しても例外ではありません。</p>\n<div class=\"gatsby-highlight\" data-language=\"yaml\"><pre class=\"language-yaml\"><code class=\"language-yaml\"><span class=\"token key atrule\">version</span><span class=\"token punctuation\">:</span> <span class=\"token string\">'2'</span>\n<span class=\"token key atrule\">services</span><span class=\"token punctuation\">:</span>\n  <span class=\"token key atrule\">app</span><span class=\"token punctuation\">:</span>\n    <span class=\"token key atrule\">env_file</span><span class=\"token punctuation\">:</span> .env\n    <span class=\"token key atrule\">links</span><span class=\"token punctuation\">:</span>\n      <span class=\"token punctuation\">-</span> redis\n  <span class=\"token key atrule\">redis</span><span class=\"token punctuation\">:</span>\n    <span class=\"token key atrule\">image</span><span class=\"token punctuation\">:</span> <span class=\"token string\">'redis:latest'</span></code></pre></div>\n<p>というように、.envを読み込ますことが可能です。<br>\nただ、個人的に気持ち悪いと感じているのが、<code>docker-compose.yml</code>内の依存関係のはずなのに.envと別ファイルに依存関係が分離されてしまうことです。</p>\n<p>例えば↑の例で言うとappコンテナにはRedisというホスト名のリンクが追加されているので、redisに接続する際のホスト名は<code>redis</code>固定のはずです。<br>\n各開発者のローカル設定によらず、同じdocker-compose.ymlを使う以上絶対に固定の値なのに、気持ち悪い。</p>\n<h2 id=\"docker-composeで固定値とenvを混在させる\" style=\"position:relative;\"><a href=\"#docker-compose%E3%81%A7%E5%9B%BA%E5%AE%9A%E5%80%A4%E3%81%A8env%E3%82%92%E6%B7%B7%E5%9C%A8%E3%81%95%E3%81%9B%E3%82%8B\" aria-label=\"docker composeで固定値とenvを混在させる permalink\" class=\"autolink-header before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>Docker composeで固定値と.envを混在させる</h2>\n<p>ということで現状使っている暫定的な対応策です。</p>\n<div class=\"gatsby-highlight\" data-language=\"yaml\"><pre class=\"language-yaml\"><code class=\"language-yaml\"><span class=\"token key atrule\">version</span><span class=\"token punctuation\">:</span> <span class=\"token string\">'2'</span>\n<span class=\"token key atrule\">services</span><span class=\"token punctuation\">:</span>\n  <span class=\"token key atrule\">app</span><span class=\"token punctuation\">:</span>\n    <span class=\"token key atrule\">environment</span><span class=\"token punctuation\">:</span>\n      <span class=\"token key atrule\">REDIS_URL</span><span class=\"token punctuation\">:</span> <span class=\"token string\">'redis://redis'</span>\n    <span class=\"token key atrule\">env_file</span><span class=\"token punctuation\">:</span> .env\n    <span class=\"token key atrule\">links</span><span class=\"token punctuation\">:</span>\n      <span class=\"token punctuation\">-</span> redis\n  <span class=\"token key atrule\">redis</span><span class=\"token punctuation\">:</span>\n    <span class=\"token key atrule\">image</span><span class=\"token punctuation\">:</span> <span class=\"token string\">'redis:latest'</span></code></pre></div>\n<p><code>environment</code>と<code>env_file</code>は両立できるので、</p>\n<ul>\n<li>Git管理されるべき固定値は<code>docker-compose.yml</code>の中の<code>environment</code>セクションに記述</li>\n<li>Git管理してはいけない変動地は<code>.env</code>にファイルとして外出し</li>\n</ul>\n<p>と分けています。<br>\n.envというファイルパスに依存しているだけなので、その中身は何であっても構いません。<br>\n具体的な値を抜いた枠を<code>.env.example</code>等として作成しておき、<br>\n環境構築時に<code>cp .env.example .env</code>してもらって任意の値を使用する、という方法が無難かなぁ、と思っています。</p>\n<h2 id=\"まとめ\" style=\"position:relative;\"><a href=\"#%E3%81%BE%E3%81%A8%E3%82%81\" aria-label=\"まとめ permalink\" class=\"autolink-header before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>まとめ</h2>\n<p>Dockerはいいぞ。</p>\n<p>Docker composeを使いだすと、コンテナを複数個使うハードルが途端に下がり、<br>\nつい「コンテナ=物理サーバ」という境界線を引いてしまいがちですが、「コンテナ=プロセス」と捉えることを忘れないようにすれば、考えはシンプルなまま便利さを享受できると思います。</p>","timeToRead":4,"frontmatter":{"title":"Docker(compose)使い始めてから.env系のライブラリを使わなくなってた","tags":["Docker","Redis"],"date":"November 01, 2016","featuredImage":null}}},"pageContext":{"slug":"/use-docker-instead-of-dotenv/","previous":{"fields":{"slug":"/knowhow-of-my-service-in-hamee/"},"frontmatter":{"title":"ユーザーの声を集める要望フォーラムを作って1年半が経った","tags":null}},"next":{"fields":{"slug":"/how-to-use-redmine-with-docker-in-japanese/"},"frontmatter":{"title":"RedmineのDockerコンテナとMySQLで日本語を使えるようにするまで","tags":["Docker","Docker compose","MySQL","Redmine"]}}}},
    "staticQueryHashes": ["2585454260","2954598359"]}