仿照 scrapy 的设计用 scala 写了一个爬虫框架

2016-01-31 18:55:10 +08:00
 gaocegege
homepage: http://gaocegege.com/scrala
github: https://github.com/gaocegege/scrala

写着玩的,用来学习 scala 的造轮子作品,代码很简单,读起来很快,有感兴趣的同学一起来呀(捂脸
6923 次点击
所在节点    Scala
7 条回复
wuhx
2016-01-31 23:25:51 +08:00
赞,才发现 v2 也有 Scala 节点,不过貌似上一条帖子是 100 多天前了

看了一下代码,建议增加爬虫超时重试,用 akka 的 supervisor strategy 处理各种异常会非常愉快。
gaocegege
2016-02-01 08:37:35 +08:00
@wuhx 0.0 本身对 scala 非常不熟,感觉充满了各种 trick~supervisor strategy 容我去 Google 下~

最近打算新加的 feature 是分布式,打算做成 manager/worker 的架构
wuhx
2016-02-01 09:51:45 +08:00
@gaocegege 只要不涉及 type level 编程, Scala 还是很容易上手的。 分布式才是 akka 的强项啊
gaocegege
2016-02-01 09:57:37 +08:00
@wuhx 嗯嗯~是想把 worker 做成 stateless, long-running 的,这就需要 manager 去做服务发现,运行起来的时候去找 worker ,感觉还挺麻烦的~

不过 akka remote actor 真的好方便~
gaocegege
2016-02-01 09:58:12 +08:00
@wuhx 嗯对哈哈~现在就是把 scala 当作带着函数式的 java 在用~
wuhx
2016-02-01 13:47:18 +08:00
@gaocegege akka 的 actor 的成本低,你的 worker 反正是 stateless 的,不如设计成 per-request actor ,用的时候现做,那就就不用找 worker 了。 或者启一个 Router actor ,自动维护一个 worker queue ,你配一下 roudrobin 或者自定义规则的 dispatcher 就好了,非常方便,而且会比你自己实现的性能更好。
gaocegege
2016-02-01 17:01:49 +08:00
@wuhx 受教,回去试试看

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/254642

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX