本当は怖い less

tl;dr

パイプから大きいデータを less に渡すとメモリ死する。

パイプから読むとき

必要に応じて動的にバッファが確保される。起動直後に G とか押すと全部メモリにのる。GB オーダーのファイルでそういうことすると死ぬ。

どうしたらいいの

-B オプションをつかうと、動的にメモリを確保せず 64 KB(Amazon Linux 64bit の場合)または -b オプションで指定されたサイズのみをバッファに使用する。

そもそも

less で GB オーダーのファイル開く意味が分からない。grep とかでしぼってから less に渡そう。

Rails + CircleCI で MySQL の utf8mb4 をつかう

前提

ActiveRecordをutf8mb4で動かす - Qiita

気合でコンテナ上の MySQL の設定を変更する

circle.yml
database:
  override:
    - mysql -u root -e 'set global innodb_file_format = Barracuda'
    - mysql -u root -e 'set global innodb_file_per_table = 1'
    - mysql -u root -e 'set global innodb_large_prefix = 1'
    - bundle exec rake db:create db:schema:load --trace