Fork me on GitHub
#clojure-japan
<
2016-02-19
>
blackenedgold02:02:13

zeromqまあまあ良い感じですね。jzmqだとライブラリのビルドが面倒だったのでjeromqにしましたがそれなりのパフォーマンスには。

blackenedgold02:02:31

ところでwith-openとcore.asyncを同時に使うとやばい、とかってありますか?

solicode02:02:29

特にないと思います。

blackenedgold02:02:59

with-open下でgo使ったらリソースが既に閉じられていてエラーになったんですよね…何かマズかったんでしょうか。

athos03:02:31

goマクロの中でwith-openを呼ぶのは問題なさそうな気がしますけど、goマクロ自体はチャネルを返してくるだけで制御が戻ってきてしまうので、goマクロ内で外側のwith-openでオープンしたリソースにアクセスするとエラーになる可能性はありますね

athos03:02:08

with-openとlazy seqを一緒に使うのと似た問題かと

blackenedgold03:02:22

うーむ。一応with-open内に制御はとどまっているんですよね。ringのサーバを立ち上げているので。

athos03:02:48

うーん、状況が分からないのでなんとも…

blackenedgold03:02:51

(defn -main [& args]
  (with-open [f (io/reader (first args))]
    (let [routine (fuction-that-start-gorutine f)]
      ...
      (run-server (site #'routes) {:port 8080}))))

athos03:02:43

function-that-start-goroutineの戻り値は何ですか?

blackenedgold03:02:18

えーっと、内部で2つのgoroutine(タイマーと本スレッド)を作っていて、そのうちのタイマーです。

athos03:02:36

うーん、なんでしょう。仮に with-open を使わずに (fuction-that-start-gorutine (io/reader (first args))) とした場合はエラーにはならないんですか?

blackenedgold03:02:52

そうです。

blackenedgold03:02:21

なので今letで運用してるんですがちょっと気持ち悪いんですよね。

athos03:02:29

なるほど。たしかに気持ちは悪いですけど、そのファイルがサーバを落とすまで開きっぱなしでいいならそれでもいい気はします。

blackenedgold03:02:14

そうですね。とりあえずはこれでやっていきます。 原因が分からないのは気になるのでそれはまた調べますか。

solicode03:02:16

もしかして run-server って async ですか?

blackenedgold03:02:40

run-serverでブロックしますね。

athos03:02:43

ちなみにエラーメッセージはどんな感じですか?

blackenedgold03:02:51

closedSequenceみたいな…いまはもうエラー直してるのですぐには出ませんでしたね。

blackenedgold03:02:11

(lazy-seqとwith-openの時と同じエラーですね

solicode03:02:21

サーバ何を使ってますか?http-kit?

solicode03:02:03

http-kit の run-server は async だと思いますよ。 run-server の後 println とかを入れてみてください。たぶん、そのせいだと思います。

blackenedgold03:02:19

なるほど…

blackenedgold03:02:40

確かにprintされました。ありがとうございます。