More Related Content
Similar to バッチを Akka Streams で再実装したら100倍速くなった話 #ScalaMatsuri (20)
バッチを Akka Streams で再実装したら100倍速くなった話 #ScalaMatsuri
- 3. Copyright © 2016 TIS Inc. All rights reserved.
今日話すこと
Akka Streams を使ってバッチの処理速度を100倍にした事例
- 5. Copyright © 2016 TIS Inc. All rights reserved.
バッチ処理
毎日夜間に、その日の取引情報をCSVファイルに書き出す
- 7. Copyright © 2016 TIS Inc. All rights reserved.
DBから一括で時刻順の取引情報を取得し、一行ずつ処理し、
一行ずつファイルへ書き出す
- 8. Copyright © 2016 TIS Inc. All rights reserved.
問題は何か
処理が終わるのが遅い。応急処置でなんとか凌いでいる。
- 10. Copyright © 2016 TIS Inc. All rights reserved.
調査環境として仮想マシンを構築。
本番環境と同じリソースを割り当て。
‣
‣
‣
‣
- 14. Copyright © 2016 TIS Inc. All rights reserved.
ボトルネックはどこか?
スワップ領域が大量に消費
0
1000
2000
3000
4000
5000
6000
0:00 0:20 0:40 1:00 1:20 1:40 2:00 2:20 2:40
- - Memory - - Swap
‣
- 21. Copyright © 2016 TIS Inc. All rights reserved.
ボトルネックは解消されたのか?
メモリ不足は解消
0
1000
2000
3000
4000
5000
6000
7000
0:00 0:05 0:10 0:15 0:20 0:25
- - Memory - - Swap
‣
- 24. Copyright © 2016 TIS Inc. All rights reserved.
少しずつデータを取得。処理を並列で行う。
ただし、取得したデータの並びは維持。
‣
- 25. Copyright © 2016 TIS Inc. All rights reserved.
DBから時刻順のデータを少しずつ取得。並列で処理。
取得した順序で書き出し。
- 27. Copyright © 2016 TIS Inc. All rights reserved.
Akka Streams は Reactive Streams の Akka を使った実装
‣
‣
- 29. Copyright © 2016 TIS Inc. All rights reserved.
Reactive Streams の Publisher を通じてデータを
ストリーミングするAPIを提供
Streams
- 31. Copyright © 2016 TIS Inc. All rights reserved.
既存のバッチと同じ結果が得られるように実装。
キャッシュも既存のものと同様に実装。
- 40. Copyright © 2016 TIS Inc. All rights reserved.
調査環境として仮想マシンを構築。
本番環境と同じリソースを割り当て。
‣
‣
‣
‣
- 44. Copyright © 2016 TIS Inc. All rights reserved.
ボトルネックは解消されたのか?
メモリ不足は発生していない
0
200
400
600
800
1000
1200
1400
1600
1800
2000
0:00 0:00 0:01 0:02 0:03 0:04 0:05 0:05 0:06 0:07 0:08 0:09
- - Memory - - Swap
‣
- 50. Copyright © 2016 TIS Inc. All rights reserved.
ハードウェアを変更せずに大幅な性能改善できた。
experimental なので本番環境への適用は注意。
- 52. Copyright © 2016 TIS Inc. All rights reserved.
ストリームなのにメモリ不足。Slick の streaming API を使っ
てデータを取得しているのに一括で取得されてしまう。
- 53. Copyright © 2016 TIS Inc. All rights reserved.
MySQL固有の問題
解決方法: enableStreamingResults() を設定
- 54. Copyright © 2016 TIS Inc. All rights reserved.
非同期キャッシュ - spray-caching
非同期ノンブロッキングでスレッドセーフなキャッシュ
- 57. Copyright © 2016 TIS Inc. All rights reserved.
2016年2月2日 7:00PM-10:30PM、場所は西新宿
- 58. Copyright © 2016 TIS Inc. All rights reserved.
2016年2月2日 7:00PM-10:30PM、場所は西新宿