2016年2月14日日曜日

【Rails4.2.xx】 Using Capistrano3

  • Published Date:Feb. 14, 2016

Article Summary

This article is how to use Capistrano3.

環境

  • rails4.2.5 & centos6.5
  • ruby2.3.0
  • rbenv
  • unicorn

About capistrano

Capistrano3 is deployment tool. This is writtern by Ruby, it is good for rails app.
Other programing languages can be also available Capistrano3. if you use rails app, you can use many convient functions.

Purposes of use

deployment is hard job. On the other hand, these tasks are delicate.
if you faile deployment operation, many customers have such a bad influence.

if you use capistrano, it is easy to deploy web app.
In terms of secirity, deployment should be executed automatically.

cap install

At first, Add Capistrano to your project's Gemfile.

{project_folder}/Gemfile

group :development do
  # Access an IRB console on exception pages or by using <%= console %> in views
  gem 'web-console', '~> 2.0'
  gem 'capistrano', '~> 3.2.1'
  gem 'capistrano-ssh-doctor', '~> 1.0'
  gem 'capistrano-rails'
  gem 'capistrano-rbenv', github: "capistrano/rbenv"
  gem 'capistrano-bundler', "~> 1.1.0"
  gem 'capistrano3-unicorn' # unicornを使っている場合のみ
end

install.

terminal

rbenv exec bundle install

cap install.

terminal

bundle exec cap install

mkdir -p config/deploy
create config/deploy.rb
create config/deploy/staging.rb
create config/deploy/production.rb
mkdir -p lib/capistrano/tasks
Capified

cap command creates all necessary configuration files.
if your app need other environments, you make file manually. In my case, Local env is development. Staging env is operation verification. Production env is public site. So, my cap files are default settings.
Next step is to set deployment setting.

Setting Capfile

My enviroment uses rbenv. add capistrano/rbenv to Capfile.

{project_folder}/Capfile

require 'capistrano/rbenv'

confirm version of ruby which running rails.

terminal

[root@vagrant-centos65 ~]# ruby -v
ruby 2.3.0p0 (2015-12-25 revision 53290) [x86_64-linux]

add version of ruby to Capfile.

{project_folder}/Capfile

require 'capistrano/rbenv'

set :rbenv_ruby, '2.3.0'

Next, add rbenv path to Capfile.

terminal

[root@vagrant-centos65 ~]# which rbenv
/usr/local/rbenv/bin/rbenv

add "/usr/local/rbenv" to Capfile.

{project_folder}/Capfile

require 'capistrano/rbenv'

set :rbenv_ruby, '2.3.0'
set :rbenv_custom_path, '/usr/local/rbenv'

Use Bundler.

{project_folder}/Capfile

require 'capistrano/bundler'

add other libraries. assets compile, unicorn restart, db migrate, site-map update.


require 'capistrano/rbenv'

set :rbenv_ruby, '2.3.0'
set :rbenv_custom_path, '/usr/local/rbenv'

require 'capistrano/rails/assets'
require 'capistrano/rails/migrations'
require 'capistrano/rails'
require 'capistrano/bundler'
require 'capistrano3/unicorn'

config/deploy.rb

This step is to set deploy.rb. This file describes common deployment operation.
add git infomation to Capfile.

{project_folder}/Capfile

set :application, 'sampleweb'
set :repo_url, 'git@xxxxxxxx:test/sample_web.git'

# Default value for :scm is :git
set :scm, :git

Capistrano get source code using git clone command. On Linux, Set information of git , as you can use git clone command.

rbenv uses the system Ruby.

{project_folder}/Capfile

set :rbenv_type, :system # :system or :user
set :rbenv_ruby, '2.3.0'

add symbolic link to Capfile.

{project_folder}/Capfile

set :linked_dirs, %w{bin log tmp/pids tmp/cache tmp/sockets bundle public}

add pid file to Capfile.
By default, unicorn_rails will create a PID file. this path is not default.

{project_folder}/Capfile

set :unicorn_pid, -> {"#{shared_path}/tmp/pids/unicorn.pid"}

add default enviroment to Capfile.

{project_folder}/Capfile

set :default_env, { path: "/usr/local/rbenv/shims:/usr/local/rbenv/bin:$PATH" }

When you execute deploy, capistrano execute assets precompile. Code is follow.

{project_folder}/Capfile

  namespace :assets do
    Rake::Task['deploy:assets:precompile'].clear_actions
    
    desc "Precompile assets"
    task :precompile do
      puts "-----nothing-------"
    end
  end

When you execute deploy, capistrano restart unicorn. Code is follow.

{project_folder}/Capfile

  desc 'Restart application'
  task :restart do
    on roles(:app), in: :sequence, wait: 5 do
      invoke 'unicorn:restart'
      # Your restart mechanism here, for example:
      # execute :touch, release_path.join('tmp/restart.txt')
    end
  end

Define Multiple Stages

Capistrano3 can define multiple stages.
At first, define staging.rb.

I use vagrant as staging environment. write code of ssh login.

{project_folder}/config/deploy/staging.rb

role :app, %w{root@192.168.33.50}
role :web, %w{root@192.168.33.50}
role :db,  %w{root@192.168.33.50}

set :ssh_options, {
  verbose: :debug,
  auth_methods: %w(password),
  password: "vagrant"
}

deploy test

execute deploy.

terminal

vagrant ssh

cd {project_folder}

bundle exec cap staging deploy:check

if error occurs, fix error.
you should pay attention to user permission. and you confirm as you can use git clone command.
execute command by root permission.

terminal

D, [2016-02-01T08:48:42.485315 #11434] DEBUG -- tcpsocket[3fe196317614]: received packet nr 55 type 96 len 12
I, [2016-02-01T08:48:42.485343 #11434]  INFO -- net.ssh.connection.session[3fe1963eb554]: channel_eof: 7
D, [2016-02-01T08:48:42.485384 #11434] DEBUG -- tcpsocket[3fe196317614]: received packet nr 56 type 97 len 12
I, [2016-02-01T08:48:42.485407 #11434]  INFO -- net.ssh.connection.session[3fe1963eb554]: channel_close: 7
D, [2016-02-01T08:48:42.485469 #11434] DEBUG -- tcpsocket[3fe196317614]: queueing packet nr 46 type 97 len 28
INFO [ca5786bf] Finished in 0.034 seconds with exit status 0 (successful).

check is success. On production environment, execute deploy.

deploy

execute production deploy.

terminal

I, [2016-01-26T06:40:47.922269 #745]  INFO -- net.ssh.connection.session[3fdd4a672b9c]: channel_data: 66 29b
DEBUG [159535d3]    Successful ping of Google
D, [2016-01-26T06:40:47.923078 #745] DEBUG -- tcpsocket[3fdd4a0a92ec]: received packet nr 465 type 94 len 44
I, [2016-01-26T06:40:47.923165 #745]  INFO -- net.ssh.connection.session[3fdd4a672b9c]: channel_data: 66 27b
DEBUG [159535d3]    Successful ping of Bing
D, [2016-01-26T06:40:47.923676 #745] DEBUG -- tcpsocket[3fdd4a0a92ec]: received packet nr 466 type 98 len 44

... // something 

INFO [db1051b1] Finished in 0.102 seconds with exit status 0 (successful).

Conclusion

Capistrano3 is convenient deployment tool.
In my case, I use Capistrano 3 with java and php.

Production environment should be automated. I recommend that you define capistrano, before you start project.

See you.

日本語

2016年2月1日月曜日

rails4.2.x Combine div tag with link_to

  • Published Date:Feb. 1, 2016

Article Summary

Explain how to combine div tag with link_to.

日本語で読む

Environment

  • rails4.2.4
  • ruby2.3.0

link_to

When you create web app on Rails, there are opportunities to combine div tag with a tag.
For example, HTML source, as follows:

{app_folder}/app/view/xxx.erb

<a href="">
<div>
 // image or text
</div>
</a>

A HTML described above could be combined div tag with like_to tag, as follows:

{app_folder}/app/view/xxx.erb

<%= link_to test_path(@test) do %>
<div>
 // image or text
</div>
<% end %>

link_to tag block surrounds div tag, Creates a link tag of div.

Conclusion

Blocks are one of the most useful function of ruby.
if you have a little time, I recommend that you study block of ruby.

See you.

日本語

2016年1月7日木曜日

elasticsearch. plugin install failed. SSLException java.security.ProviderException

  • Published Date:Jun. 7, 2016

Article Summary


On Elasticsearch, When I executed bin/plugin command, SSLException java.security.ProviderException occurred.
This article describes how to modify this error.
日本語で読む

Environment


  • vagrant centos6.5
  • elasticsearch2.1.1
  • java(OpenJDK) version 1.7.0_91

Failure of kuromoji plugin installation.


kurimoji is the Japanese Analysis plugin. elasticsearch 2.1 integrates this plugin as official.
So, this plugin can be installed using the plugin manager.

terminal

sudo /usr/share/elasticsearch/bin/plugin install --verbose analysis-kuromoji

Failed: SSLException[java.security.ProviderException: java.security.KeyException]; nested: ProviderException[java.security.KeyException]; nested: KeyException;
ERROR: failed to download out of all possible locations

But, in my environment, plugin installation failed.

Switch Java Version


The cause of the failure is java version.
so, I checked java version.

terminal

// centos
yum search java | grep openjdk
java-1.6.0-openjdk.x86_64 : OpenJDK Runtime Environment
java-1.6.0-openjdk-demo.x86_64 : OpenJDK Demos
java-1.6.0-openjdk-devel.x86_64 : OpenJDK Development Environment
java-1.6.0-openjdk-javadoc.x86_64 : OpenJDK API Documentation
java-1.6.0-openjdk-src.x86_64 : OpenJDK Source Bundle
java-1.7.0-openjdk.x86_64 : OpenJDK Runtime Environment
java-1.7.0-openjdk-demo.x86_64 : OpenJDK Demos
java-1.7.0-openjdk-devel.x86_64 : OpenJDK Development Environment
java-1.7.0-openjdk-javadoc.noarch : OpenJDK API Documentation
java-1.7.0-openjdk-src.x86_64 : OpenJDK Source Bundle
java-1.8.0-openjdk.x86_64 : OpenJDK Runtime Environment
java-1.8.0-openjdk-debug.x86_64 : OpenJDK Runtime Environment with full debug on
java-1.8.0-openjdk-demo.x86_64 : OpenJDK Demos
java-1.8.0-openjdk-demo-debug.x86_64 : OpenJDK Demos with full debug on
java-1.8.0-openjdk-devel.x86_64 : OpenJDK Development Environment
java-1.8.0-openjdk-devel-debug.x86_64 : OpenJDK Development Environment with
java-1.8.0-openjdk-headless.x86_64 : OpenJDK Runtime Environment
java-1.8.0-openjdk-headless-debug.x86_64 : OpenJDK Runtime Environment with full
java-1.8.0-openjdk-javadoc.noarch : OpenJDK API Documentation
java-1.8.0-openjdk-javadoc-debug.noarch : OpenJDK API Documentation for packages
java-1.8.0-openjdk-src.x86_64 : OpenJDK Source Bundle
java-1.8.0-openjdk-src-debug.x86_64 : OpenJDK Source Bundle for packages with

There is java-1.8.0-openjdk.
Next, check using java version.

terminal

alternatives --config java

There are 2 programs which provide 'java'.

  Selection    Command
-----------------------------------------------
   1           /usr/lib/jvm/jre-1.5.0-gcj/bin/java
*+ 2           /usr/lib/jvm/jre-1.7.0-openjdk.x86_64/bin/java


java-1.8.0-openjdk is not installed.
I will install it.

terminal

sudo yum install -y java-1.8.0-openjdk

check using java version.

terminal

java -version
java version "1.7.0_91"

Java version is still not changed. I will switch java version.

terminal

sudo alternatives --config java

There are 3 programs which provide 'java'.

  Selection    Command
-----------------------------------------------
   1           /usr/lib/jvm/jre-1.5.0-gcj/bin/java
*+ 2           /usr/lib/jvm/jre-1.7.0-openjdk.x86_64/bin/java
   3           /usr/lib/jvm/jre-1.8.0-openjdk.x86_64/bin/java

Enter to keep the current selection[+], or type selection number: 3

I check using java version again.

terminal

java -version
openjdk version "1.8.0_65"
OpenJDK Runtime Environment (build 1.8.0_65-b17)
OpenJDK 64-Bit Server VM (build 25.65-b01, mixed mode)

Version was changed to java-1.8.0-openjdk.

Reinstallation of kurimoji plugijn


On java-1.8.0-openjdk, bin/plugin command executes again.

terminal

sudo /usr/share/elasticsearch/bin/plugin install --verbose analysis-kuromoji

Downloading .DONE
- Plugin information:
Name: analysis-kuromoji
Description: The Japanese (kuromoji) Analysis plugin integrates Lucene kuromoji analysis module into elasticsearch.
Site: false
Version: 2.1.1
JVM: true
 * Classname: org.elasticsearch.plugin.analysis.kuromoji.AnalysisKuromojiPlugin
 * Isolated: true
Installed analysis-kuromoji into /usr/share/elasticsearch/plugins/analysis-kuromoji

It worked out.
just in case, I will check installed plugin.

terminal

sudo /usr/share/elasticsearch/bin/plugin list
Installed plugins in /usr/share/elasticsearch/plugins:
    - analysis-kuromoji

I want to continie to using java7.

terminal

sudo alternatives --config java

There are 3 programs which provide 'java'.

  Selection    Command
-----------------------------------------------
   1           /usr/lib/jvm/jre-1.5.0-gcj/bin/java
*  2           /usr/lib/jvm/jre-1.7.0-openjdk.x86_64/bin/java
 + 3           /usr/lib/jvm/jre-1.8.0-openjdk.x86_64/bin/java

Enter to keep the current selection[+], or type selection number: 2

java -version
java version "1.7.0_91"
OpenJDK Runtime Environment (rhel-2.6.2.2.el6_7-x86_64 u91-b00)
OpenJDK 64-Bit Server VM (build 24.91-b01, mixed mode)

sudo /usr/share/elasticsearch/bin/plugin list
Installed plugins in /usr/share/elasticsearch/plugins:
    - analysis-kuromoji

It worked out.

Conclusion


On elasticsearch2.1.1, if you want to execute plugin command, you must update to java version 8.
Once installed, you can use by java version 7.

But I recommend that you makes your app environment latest. update work is very important.

See you

Reference Site


日本語


2016年1月6日水曜日

Rails5. Update work of rails v5.0.0 beta 1 from rails4. Page 2

  • Published Date:Jun. 6, 2016

Environment


  • rails 4.2.4, rails 4.2.5 → rails5.0.0 beta1
  • ruby 2.2.3
  • rbenv rbenv 0.4.0-183-gc18a3f9

Article Summary


Rails 5.0.0 Beta1 Released. I think Rails 5 will probably be released in spring of 2015.
But, if you change from rails 4 to rails 5 in Gemfile, your app would not operate correctly.

Currently, I'm doing much trial and error. At same time, I understood a lot of things. so, I write what I understood.
This article is a continuation from previous article.
read in Japanese

config.logger is unsupported


I took a lot of time this error. Rails 4.2.x implements log rotation from this setting. But this setting is fatal error on Rails 5.0.0 beta1.
So, you must change the following description.

Before

{project_folder}/config/environments/test.rb(development.rb and production.rb)

  config.logger = Logger.new('log/development.log', 'daily')

After

{project_folder}/config/environments/test.rb(development.rb and production.rb)

  # remove
  # config.logger = Logger.new('log/development.log', 'daily')

you must implement log rotation by another way.

cannot load such file -- sass


This error shows sass file was fail to read. So, remove sass file. Your app is launched normally.
This error shows that your app was fail to read sass file. You should remove sass file. if you do, your app will be launched successfully.

bin/setup


Compared with rails 4, this file was changed many settings.
For instance, rake commands were changed to rails commands.
you should use termial commnad.

terminal

rake rails:update

this command can overwrite bin/setup file. before execute, I recommend that git branch switch to new git branch.

Other


These files had better change to file of rails5.
you create sample rails 5 project, and your app should compared with sample rails 5 by diff.


// change
config/environments/development.rb

// new file
active_record_belongs_to_required_by_default.rb

Summary


Applied the contents of previous article and this article, I modified rails code. My app was be able to launch rails 5 successfully.
I plan to release my app on production mode in a few weeks.

See you.

Recommended Book for Rails 4 Developer


For Improving your ruby programming.


Administrating Site(createing rails)


Useful site


Japanese


Rails5 Update work of rails v5.0.0 beta 1 from rails4. Page 1

  • Published Date:Jun. 6, 2016

Environment


  • rails 4.2.4, rails 4.2.5 → rails5.0.0beta1
  • ruby 2.2.3
  • rbenv rbenv 0.4.0-183-gc18a3f9

Article Summary


Rails 5.0.0Beta1 Released. I think Rails 5 will probably be released in spring of 2015.
But, if you change from rails 4 to rails 5 in Gemfile, your app would not operate correctly.

Currently, I'm doing much trial and error. At same time, I understood a lot of things. so, I write what I understood.

Japanese

Spring is unsupported


On Rails 5.0.0Beta1, Spring gem is not available. So, if your app uses spring, you should remove spring gem.
if you use Bundler, you should do the follow.

terminal

vi Gemfile

// comment out
#gem 'spring'
#gem 'spring-commands-rspec'

rbenv exec bundle exec gem uninstall spring
rbenv exec bundle exec gem uninstall spring-commands-rspec

kaminari is unsupported


On Rails 5.0.0Beta1, kaminari gem is not available. it occurs ActionView::MissingTemplate.
if you want to use kaminari, you should change to latest kaminari gem.
if you use Bundler, you should change the Gemfile.

Before

{project_folder}/Gemfile

gem 'kaminari'

After

{project_folder}/Gemfile

gem 'kaminari', github: 'amatsuda/kaminari'

After you modified Gemfile, execute bundle update.

terminal

rbenv exec bundle install

Using kaminari 1.0.0.alpha (was 0.16.3) from git://github.com/amatsuda/kaminari.git (at master)

DEPRECATION WARNING: `serve_static_files` is deprecated and will be removed in Rails 5.1.


serve_static_files became deprecated. This is from Rails 4.2, and will remove it completely on Rails 5.1.
So, you must change the following description.

Before

{project_folder}/config/environments/test.rb(development.rb and production.rb)

  # Configure static asset server for tests with Cache-Control for performance.
  config.serve_static_files  = true

After

{project_folder}/config/environments/test.rb(development.rb and production.rb)

  # Configure static asset server for tests with Cache-Control for performance.
  config.public_file_server.enabled  = true

DEPRECATION WARNING: `static_cache_control` is deprecated and will be removed in Rails 5.1.


static_cache_control became deprecated. This will be also removed completely on Rails 5.1.
So, you must change the following description.

Before

{project_folder}/config/environments/test.rb(development.rb and production.rb)

  # config.serve_static_assets = ENV['RAILS_SERVE_STATIC_FILES'].present?
  config.static_cache_control = 'public, max-age=3600'

After

{project_folder}/config/environments/test.rb(development.rb and production.rb)

  # config.serve_static_assets = ENV['RAILS_SERVE_STATIC_FILES'].present?
  config.public_file_server.headers = { 'Cache-Control' => 'public, max-age=3600' }

DEPRECATION WARNING: before_filter is deprecated and will be removed in Rails 5.1.


before_filter became deprecated. This method is very useful, but removed completely on Rails 5.1.
So, you must change the following description.

Before

{projectfolder}/app/controllers/application_controller.rb

class ApplicationController < ActionController::Base
  # Prevent CSRF attacks by raising an exception.
  # For APIs, you may want to use :null_session instead.
  protect_from_forgery with: :exception

  before_filter :set_locale
  
  // something

end

After

{projectfolder}/app/controllers/application_controller.rb

class ApplicationController < ActionController::Base
  # Prevent CSRF attacks by raising an exception.
  # For APIs, you may want to use :null_session instead.
  protect_from_forgery with: :exception

  before_action :set_locale
  
  // something

DEPRECATION WARNING: use_transactional_fixtures= is deprecated and will be removed from Rails 5.0.


use_transactional_fixtures became deprecated. This is still unsupported on Rspec. So, you must not modify this.

Summary


if you think rails 5 update, it takes a lot of times.
so, you create new git branch soon, take measures.

I always think that rails major updating is difficult. But rails 5 updating is easier than rails 4 updating.
Rails has always evolved. This time is also same.

See you

Recommended Book for Rails 4 Developer


For Improving your ruby programming.


Administrating Site(createing rails)


Useful site


Japanese

2016年1月4日月曜日

Execute Rpsec Test. remote true ajax method on Rails Controller.

  • Published Date:Jun. 4, 2016

Article Summary


On Rails, developer can easy to implement ajax.
But, in case of doing rspec test, you must write code in a deffrent way from normal controller rspec test.

This article describes how toimplement "remote ajax rspec".

Environment


  • ruby 2.2.4
  • rails 4.2.5
  • spec-rails 3.0.2

Noraml Controller Implementation


Generally, when developers implement rails controller of rspec, implement like the following example.

/app/controller/test_controller.rb

post :confirm, @params

Detail Explanation

  • controller: test_controller.rb
  • method : confirm
  • method type : post
  • parameter : @params

This is general implementation method of rails controller.
Let's change rspec test from this to "remote true" ajax method.

"remote true" ajax method Controller Implementation


Using xhr, Rspec can call ajax method of controller.

/app/controller/test_controller.rb

xhr :post, :confirm, @params

Very easy.
Enjoy Rspec Life.

See you.

Recommended Book for Rails 4 Developer


For Improving your ruby programming.


Administrating Site(createing rails)


日本語

2016年1月3日日曜日

Update Ruby Version On Using Rails 4. Update from Ruby 2.2.4 to Ruby 2.3.0.

  • Published Date:Jun. 3, 2016

Article Summary


This article describes how to update from Ruby 2.2.4 to Ruby 2.3.0 on Rails 4.

Environment


  • Rails4.2.5
  • Ruby2.2.4 → Ruby2.3.0

Switch Ruby2.3.0


ruby 2.3.0 to proceed with the description in the premise on which it is installed.

terminal

// switch ruby version
rbenv global 2.3.0

ruby -v
ruby 2.3.0p0 (2015-12-25 revision 53290) [x86_64-linux]

Install required Gem


Install required Gem for ruby 2.3.0p0.

terminal

// confirm gem version.
rbenv exec gem -v
2.5.1

rbenv exec gem list --local

*** LOCAL GEMS ***

bigdecimal (1.2.8)
did_you_mean (1.0.0)
io-console (0.4.5)
json (1.8.3)
minitest (5.8.3)
net-telnet (0.1.1)
power_assert (0.2.6)
psych (2.0.17)
rake (10.4.2)
rdoc (4.2.1)
test-unit (3.1.5)

// install bundler for ruby 2.3.0p0 
rbenv exec gem install bundler

rbenv exec gem list --local

*** LOCAL GEMS ***

bigdecimal (1.2.8)
bundler (1.11.2)
did_you_mean (1.0.0)
io-console (0.4.5)
json (1.8.3)
minitest (5.8.3)
net-telnet (0.1.1)
power_assert (0.2.6)
psych (2.0.17)
rake (10.4.2)
rdoc (4.2.1)
test-unit (3.1.5)

After Confirming ruby 2.3.0 and gem, Install required gem for rails project.

terminal

// move project folder
cd {prohect_folder}

// confirm gemfile.lock

// execute bundle install
rbenv exec bundle install --path /home/vagrant/vanish/dev/vendor/bundle

Bundle complete! 18 Gemfile dependencies, 70 gems now installed.

After completion, you execute test to confirm degradation.

terminal

// execute test
rbenv exec bundle exec rspec

Finished in 0.7514 seconds (files took 6.03 seconds to load)
42 examples, 0 failures, 4 pending

Worked out well.

Conclusion


In my case, It was easy to change from Ruby 2.2.4 to Ruby 2.3.0.
You should try it.
From now on, I will try to implement new function of Ruby 2.3.0.
Thank you for reading this article.

See you.

Recommended Book for Rails 4 Developer


For Improving your ruby programming.


Administrating Site(createing rails)


日本語