LoginSignup
24

More than 5 years have passed since last update.

Lodgeをherokuで動かす(ついでにheroku button)

Last updated at Posted at 2014-09-15

Lodgeとは

Lodgeは、オープンソースの情報共有アプリです。

herokuにデプロイしてみた

「データを外部業者に預けずにオンプレで管理できる」のが特色のlodgeを、クラウド環境にデプロイするのは色々と相反している気もしますが、気にしない方針でいきます。
あとついでにheroku buttonを使ってみました。

こんな感じで編集しました

つまり、やったこと

  • 環境変数設定を
    • app.jsonに一部書く
    • config/environments/production.rbに一部書く
  • bundle installしてGemfile.lockを.gitignoreから外す
  • config/database.ymlを書いて.gitignoreから外す
  • 自分のlodgeのREADME.mdにheroku buttonを追加

herokuボタンを押した後の流れ

github上でforkしてローカルから自分のlodgeにpushしたのがこちらになります。

さっきREADMEに置いたherokuボタンを押します。
herokuボタンを押したあとは、普通にherokuボタンデプロイの流れです。

こんな画面。
App Nameを入力すると(必須ではない)その名前がサブドメインの名前(xxx.herokuapp.comのホスト名)になります。

new

下のほうでデプロイボタンを押します。環境変数を編集したりしてもいいですが、基本的にそのままで動くはずです。

deploy

しばらく待ちます。assets:precompileとかmigrateとかが正常終了するとこうなります。

「View it」を叩くと、デプロイされたlodgeのトップ画面に飛びます。

注意としては、無料といえどアドオンを使っていること、cleardb(mysqlアドオン)は無料だと5MBしか使えないので、そのままだとビジネス用途は難しいと思います。
sendgridも一日の送信数とかが割りと少なかったはず。

以上です。

参考

以下、蛇足的メモ

herokuにデプロイするために編集したこと詳細

.gitignore

herokuにデプロイするために、Gemfile.lockとconfig/database.ymlをignore対象から外します。

diff --git a/.gitignore b/.gitignore
index 5271928..710789e 100644
--- a/.gitignore
+++ b/.gitignore
@@ -23,9 +23,6 @@
 /log/*.log
 /tmp

-/config/database.yml
-
-/Gemfile.lock
 /vendor/bundle
 lodge_development
 lodge_test
@@ -40,4 +37,4 @@ public/uploads/
 .env

 # Mac finder artifacts
-.DS_Store
\ No newline at end of file
+.DS_Store

Gemfile

データベースのアダプタを自動判定している部分をmysqlに決めうちしてしまいます
(postgresはちょっと詳しくないので、、)

diff --git a/Gemfile b/Gemfile
index f861c18..848d4b2 100644
--- a/Gemfile
+++ b/Gemfile
@@ -96,30 +96,4 @@ group :test do
   gem 'launchy'
 end

-# Include database gems for the adapters found in the database
-# configuration file
-require 'erb'
-require 'yaml'
-database_file = File.join(File.dirname(__FILE__), "config/database.yml")
-if File.exist?(database_file)
-  database_config = YAML::load(ERB.new(IO.read(database_file)).result)
-  adapters = database_config.values.map {|c| c['adapter']}.compact.uniq
-  if adapters.any?
-    adapters.each do |adapter|
-      case adapter
-      when 'mysql2'
-        gem "mysql2", '~> 0.3'
-      when /postgresql/
-        gem "pg", '~> 0.17'
-      when /sqlite3/
-        gem "sqlite3", '~> 1.3'
-      else
-        warn("Unknown database adapter `#{adapter}` found in config/database.yml")
-      end
-    end
-  else
-    warn("No adapter found in config/database.yml, please configure it first")
-  end
-else
-  warn("Please configure your config/database.yml first")
-end
+gem 'mysql2'

Gemfile.lock

bundle install後に追加。

diff --git a/Gemfile.lock b/Gemfile.lock
new file mode 100644
index 0000000..a01e01e
--- /dev/null
+++ b/Gemfile.lock
@@ -0,0 +1,416 @@
+ (省略)

README.md

herokuボタンのドキュメントを参考に、ボタンを設置

diff --git a/README.md b/README.md
index 4246894..be73a8c 100644
--- a/README.md
+++ b/README.md
@@ -4,6 +4,8 @@ Lodge
 [![Coverage Status](https://coveralls.io/repos/lodge/lodge/badge.png)](https://coveralls.io/r/lodge/lodge)
 [![Code Climate](https://codeclimate.com/github/lodge/lodge/badges/gpa.svg)](https://codeclimate.com/github/lodge/lodge)

+[![Deploy](https://www.herokucdn.com/deploy/button.png)](https://heroku.com/deploy)
+
 =====

 ## これは何?

app.json

README.mdに書かれている環境変数や、DBとSMTPのアドオンなどを設定します。

  • ポイント
    • cleardbとsendgridはそれぞれmysqlとSMTPのherokuアドオンです(無料プラン)
    • 環境変数LODGE_DOMAINは新規登録時のメールアドレス存在確認時に、コールバックリンクとして利用されます。ドメイン名がわかっている場合は、herokuボタンを押した後に書き換えるといいと思います
    • GOOGLE_CLIENT_IDとGOOGLE_CLIENT_SECRETは、その認証方式を使わないようであれば、特に埋めなくても大丈夫でした
diff --git a/app.json b/app.json
new file mode 100644
index 0000000..71e5069
--- /dev/null
+++ b/app.json
@@ -0,0 +1,22 @@
+{
+  "addons": [
+    "cleardb",
+    "sendgrid"
+  ],
+  "env" : {
+    "LODGE_DOMAIN"              : "example.com",
+    "SECRET_KEY_BASE"           : "__some_random_string__",
+    "DEVISE_SECRET_KEY"         : "__some_random_string__",
+    "GOOGLE_CLIENT_ID"          : "FILL_THE_CLIENT_ID",
+    "GOOGLE_CLIENT_SECRET"      : "FILL_THE_CLIENT_SECRET",
+    "DELIVERY_METHOD"           : "smtp",
+    "MAIL_SENDER"               : "lodge@example.com",
+    "SMTP_PORT"                 : "587",
+    "SMTP_AUTH_METHOD"          : "plain",
+    "SMTP_ENABLE_STARTTLS_AUTO" : "true",
+    "LODGE_THEME"               : "lodge"
+  },
+  "scripts": {
+    "postdeploy": "bundle exec rake db:migrate"
+  }
+}

config/database.yml

  • cleardb(mysqlアドオン)の設定をベタに書きます
diff --git a/config/database.yml b/config/database.yml
new file mode 100644
index 0000000..39ac335
--- /dev/null
+++ b/config/database.yml
@@ -0,0 +1,3 @@
+# mysql
+# in heroku, use CLEARDB_DATABASE_URL
+<% ENV['DATABASE_URL'] = ENV['CLEARDB_DATABASE_URL'].to_s.sub(/\Amysql/){'mysql2'} %>
diff --git a/config/environments/production.rb b/config/environments/production.rb
index 7aa2d7b..eaa333a 100644
--- a/config/environments/production.rb
+++ b/config/environments/production.rb
@@ -93,11 +93,11 @@ Rails.application.configure do
   # SMTPの指定
   config.action_mailer.delivery_method = ENV["DELIVERY_METHOD"].to_sym
   config.action_mailer.smtp_settings = {
-    :address              => ENV["SMTP_ADDRESS"],
+    :address              => 'smtp.sendgrid.net',
     :port                 => ENV["SMTP_PORT"],
     :domain               => ENV["LODGE_DOMAIN"],
-    :user_name            => ENV["SMTP_USERNAME"],
-    :password             => ENV["SMTP_PASSWORD"],
+    :user_name            => ENV["SENDGRID_USERNAME"],
+    :password             => ENV["SENDGRID_PASSWORD"],
     :authentication       => ENV["SMTP_AUTH_METHOD"].to_sym,
     :enable_starttls_auto => ENV["SMTP_ENABLE_STARTTLS_AUTO"],
   }

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
24