LoginSignup
8
8

More than 5 years have passed since last update.

Norikraのオプションをまとめておく

Posted at

毎回忘れるたびにJRubyを起動してオプションを確認していると死にたくなるので、Norikraのオプションをまとめておく。そのうち@tagomorisさんががんばってドキュメントを書いてくれることを信じている。

ログローテートの設定があることとかもさっき気がついた。

オプション 説明 [デフォルト]
-H, [--host=HOST] listenするアドレスを指定する [0.0.0.0]
-P, [--port=N] ポートを指定する [26571]
-d, [--daemonize] デーモンとして起動する
-s, [--stats=STATS] ステータスファイルを指定する [なし]
-p, [--pidfile=PIDFILE] PIDファイルを指定する [/var/run/norikra/norikra.pid]
-l, [--logdir=LOGDIR] ログディレクトリを指定する [なし]
[--outfile=OUTFILE] デーモン化したときに標準出力の内容が出力されるファイル [${logdir}/norikra.out]
--log-filesize=LOG-FILESIZE] ローテートするサイズを指定する [10MB]
--log-backups=N バックアップを残しておく数 [10]

stats fileを指定しよう

Norikraはステータスファイルを指定するとそこに実行中のクエリの内容を保存してくれる。次回起動すると、そのクエリを復元してくれる仕掛けである。

norikra start --stats /path/to/data/norikra.stats.json

パフォーマンス周り

Javaアプリケーションということで、-Xmxはとりあえず指定したけど、他はよくわからない感じだ。
松竹梅的なノリの--micro--small--middle--largeがあるけど、おそらくそれぞれのスレッド数を指定する様だ。とりあえず--middleにしておいたけどよく考えたら4コアしかないマシンなので--smallの方がよさそう。標準がどれかよくわかんなかったけど、--microだと思う。

秒間100位しか流してなくて、実行してるクエリも1min分くらいしか処理してないのを3つ位なので、いまのところ気になってない。

output of bundle exec norikra help start

Usage:
  norikra start [-Xxxx] [other options]

Options:
  -H, [--host=HOST]                   # host address that server listen [0.0.0.0]
  -P, [--port=N]                      # port that server uses [26571]
  -s, [--stats=STATS]                 # status file path to load/dump targets, queries and server configurations [none]
      [--suppress-dump-stat]          # specify not to update stat file with updated targets/queries/configurations on runtime [false]
  -d, [--daemonize]                   # daemonize Norikra server [false (foreground)]
  -p, [--pidfile=PIDFILE]             # pidfile path when daemonized [/var/run/norikra/norikra.pid]
                                      # Default: /var/run/norikra/norikra.pid
      [--outfile=OUTFILE]             # stdout redirect file when daemonized [${logdir}/norikra.out]
      [--micro]                       # development or testing (inbound:0, outbound:0, route:0, timer:0, rpc:2)
      [--small]                       # virtual or small scale servers (inbound:1, outbount:1, route:1, timer:1, rpc:2)
      [--middle]                      # rackmount servers (inbound:4, outbound:2, route:2, timer:2, rpc:4)
      [--large]                       # high performance servers (inbound: 6, outbound: 6, route:4, timer:4, rpc: 8)
      [--inbound-threads=N]           # number of threads for inbound data
      [--outbound-threads=N]          # number of threads for outbound data
      [--route-threads=N]             # number of threads for events routing for query execution
      [--timer-threads=N]             # number of threads for internal timers for query execution
      [--inbound-thread-capacity=N]
      [--outbound-thread-capacity=N]
      [--route-thread-capacity=N]
      [--timer-thread-capacity=N]
      [--rpc-threads=N]               # number of threads for rpc handlers
      [--web-threads=N]               # number of threads for WebUI handlers
  -l, [--logdir=LOGDIR]               # directory path of logfiles when daemonized [nil (console for foreground)]
      [--log-filesize=LOG-FILESIZE]   # log rotation size [10MB]
      [--log-backups=N]               # log rotation backups [10]
      [--more-quiet]                  # set loglevel as ERROR
  -q, [--quiet]                       # set loglevel as WARN
  -v, [--verbose]                     # set loglevel as DEBUG
      [--more-verbose]                # set loglevel as TRACE
  -h, [--help]                        # show this message
8
8
0

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
8
8