Masahiro KONISHI
mkoni****@sea*****
2013年 4月 13日 (土) 18:15:05 JST
こんにちは。 groonga コマンドのバグを発見しましたので、取り急ぎ報告します。 Mac OS X 等、kqueue を用いる環境(USE_KQUEUE が define される環境)では、 `-d' オプションを付けて groonga コマンドを実行すると、下記のエラーを吐いて プロセスがすぐに終了します。 | 2013-04-13 17:17:26.657910|e| syscall error 'poll' (Bad file descriptor) 原因は、kqueue(2) の実行後に fork(2) しているためだと思われます。 以下に引用した OS X の manpages に記載されている通り、kqueue(2) で返された ファイルディスクリプタは fork(2) で生成された子プロセスに引き継がれません。 従って、groonga.c において、daemonize() を grn_com_event_init() よりも 先に呼び出す必要があります。 | The kqueue() system call creates a new kernel event queue and returns a | descriptor. The queue is not inherited by a child created with fork(2). ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 以上です。 --- 小西 昌裕 / Masahiro KONISHI mkoni****@sea*****