読者です 読者をやめる 読者になる 読者になる

Cloud9がディスクfullになってしまう事象の解決法

ruby on rails

Cloud9でrailsアプリを開発してHerokuにデプロイしていると、tmpファイルに圧迫されてディスクfullになってしまう。

以下のコマンドで比較的使用量の大きいディレクトリを確認できる。

du -h -t 50M

Herokuを使用している場合、おそらく、以下のディレクトリの使用量が大きいはず。

~/.local/share/heroku/tmp

上記tmpディレクトリ内のtmpファイルを削除すれば当面のディスクfull状態は解消できる

cd ~/.local/share/heroku/tmp
rm -rf *
※ちゃんと該当ディレクトリに移動して削除してね。ルートディレクトリなんかで上記rmコマンドたたくと大事故になりますよ。

削除に関しては自己責任でお願いします。

MySQLでレコードがあればUPDATE、なければINSERTする方法

MySQL
INSERT hoge_table (column1, column2, column3) 
  VALUES (value1, value2, value3)
ON DUPLICATE KEY UPDATE 
  column1=VALUES(column1), 
  column2=VALUES(column2), 
  column3=VALUES(column3);

UPDATE以降のVALUES関数はINSERTで指定された値を参照するためのもの。 つまり、上記SQLは、hoge_tableに該当レコードがなければcolumn1=value1、column2=value2、column3=value3で 新規レコードを作成する。 該当レコードがあれば、column1=value1、column2=value2、column3=value3でUPDATEする となる。

CentOS7でjavaの実行環境を切り替えるコマンド

Java

CentOS7でjavaの実行環境を切り替えるコマンド

alternatives --config java

log4j2とShutdownHookについて注意事項

Java

log4j2の設定ファイルでshutdownHookをdisableにしておかないと、タイミングによっては、アプリより先にlog4j2がシャットダウンしてしまって、 アプリのshutdownHook内でログの出力ができなくなる場合がある。

設定例は以下のとおり。

<Configuration shutdownHook="disable">
・
・
</Configuration>

Ruby on Railsのgenerateでテストを作成しないようにする

ruby on rails

Ruby on Railsのgenerateでcontrollerやmodelを作成する際、テストコードが作られないようにする方法

rails generate controller Hoges --no-test-framework
rails generate model Hoge --no-test-framework

Heroku環境でRuby on RailsアプリにBasic認証を掛ける方法

ruby on rails
1. application_controller.rbに以下の一文を追加する
http_basic_authenticate_with :name => ENV['BASIC_AUTH_USERNAME'], :password => ENV['BASIC_AUTH_PASSWORD'] if Rails.env == "production"
2. Herokuの環境変数Basic認証用のユーザー名とパスワードを設定する。
heroku config:add BASIC_AUTH_USERNAME="username" BASIC_AUTH_PASSWORD="password"

Javascriptでチェックボックスとテキストボックスの状態を連動させる方法

javaScript

チェックボックスのチェック状態とテキストボックスの入力可否を連動させる方法を ググったけどよく分からなかったので、自前でその方法を考えてみた。

HTML
<input name="target-checkbox" type="checkbox" id="target_check_0" value="target_num_0">
<input id="target_num_0" type="number" disabled>
<input name="target-checkbox" type="checkbox" id="target_check_1"  value="target_num_1">
<input id="target_num_1" type="number" disabled>
Javascript
$('[name=target-checkbox]').change(function() {
    var value = $(this).val();
    $('#' + value).prop('disabled', !$(this).prop('checked'));
});

チェックボックスのvalue値とテキストボックスのIDを紐付けて制御する。

チェックボックスとテキストボックスの組み合わせが複数あったとしても、 チェックボックスが同じname属性を持てば、同じ様に制御できる。

もっと最適な実装があればそちらに差し替えたい。