我希望这对您的一些观点有所帮助:
1/2/3/4)Akka可以与使用java.io.InputStream和java.io.OutputStream的库一起很好地工作.参见本页,特别是本部分:http://doc.akka.io/docs/akka/snapshot/scala/io.html
A ByteStringBuilder can be wrapped in a java.io.OutputStream via the asOutputStream method. Likewise, ByteIterator can we wrapped in a java.io.InputStream via asInputStream. Using these, akka.io applications can integrate legacy code based on java.io streams.
1)您说通过网络获取文件.我通过HTTP猜测吗?您可以查看异步HTTP库.有很多相当成熟的异步HTTP库.我喜欢在Scala中使用Spray Client,因为它建立在akka之上,因此在akka环境中播放效果很好.它支持GZIP,但不支持PGP.
4)另一个选择:文件是否足够小以存储在内存中?如果是这样,您将不必担心异步,因为您将不会执行任何IO.等待IO时不会阻塞,而是因为内存速度很快而一直在使用CPU.
5)JDBC正在阻止.您以SQL查询作为参数调用方法,返回类型是包含数据的结果集.该方法必须在执行IO时阻塞才能返回此数据.
有一些Java async database drivers,但是我所看到的所有东西似乎都没有得到维护,因此我没有使用它们.