2016年08月11日
川俣晶の縁側ソフトウェア技術雑記total 1315 count

Windows10のアニバーサリーアップデートでParallel.ForEachを使用すると正常に動作しない問題

Written By: 川俣 晶連絡先

問題 §

 OS, SDKともにWindows10のアニバーサリーアップデートしたところ、Parallel.ForEachで数万件単位の大量の処理を並列動作させていた処理がVisual Studioの出力ウィンドウに以下のような例外情報(一部を抜粋)を出して正常に動作しない。(処理中に途中から出るようになる)

EventSource Error: EventSourceException while processing event "TraceOperationEnd"

EventSource Error: EventSourceException while processing event "TraceSynchronousWorkEnd"

EventSource Error: EventSourceException while processing event "TraceOperationBegin"

EventSource Error: EventSourceException while processing event "TraceSynchronousWorkEnd"

EventSource Error: EventSourceException while processing event "TraceOperationBegin"

EventSource Error: EventSourceException while processing event "TraceSynchronousWorkBegin"

EventSource Error: EventSourceException while processing event "RunningContinuation"

原因 §

 不明。ただし、MaxDegreeOfParallelismに正の値を指定すると問題がなかった。-1を指定するかあるいは全く指定しない場合はNG。

対応 §

MaxDegreeOfParallelismにEnvironment.ProcessorCountの値を設定して回避した。

正常に動かないケース §

            await Task.Run(() =>

            {

                Parallel.ForEach(source,  (src) =>

                {

                    body(src).Wait();

                });

            });

動いたケース §

            await Task.Run(() =>

            {

                var opt = new ParallelOptions();

                opt.MaxDegreeOfParallelism = Environment.ProcessorCount;

                Parallel.ForEach(source, opt, (src) =>

                {

                    body(src).Wait();

                });

            });

感想 §

「未確認だが、アニバーサリーアップデートのSDKは互換度が低く、他にも引っかかっているソフトがあるらしい」

「初物はそんなもので、徐々にこなれて安定していくのではないの?」

「そうだろうと思うが目の前のOSで自作ソフトがちゃんと動かないことも困る」

Facebook

キーワード【 川俣晶の縁側ソフトウェア技術雑記
【技術雑記】の次のコンテンツ
2016年
08月
18日
Microsoft Store Services SDK 10.0で、UWPがAdMediatorControlからAdControlに移行が強要される問題
3days 0 count
total 779 count
【技術雑記】の前のコンテンツ
2016年
08月
09日
C# PadとC# interactiveで結果が違うケース
3days 0 count
total 725 count
2016年08月11日
川俣晶の縁側ソフトウェア技術雑記total 1315 count

Windows10のアニバーサリーアップデートでParallel.ForEachを使用すると正常に動作しない問題

Written By: 川俣 晶連絡先

問題 §

 OS, SDKともにWindows10のアニバーサリーアップデートしたところ、Parallel.ForEachで数万件単位の大量の処理を並列動作させていた処理がVisual Studioの出力ウィンドウに以下のような例外情報(一部を抜粋)を出して正常に動作しない。(処理中に途中から出るようになる)

EventSource Error: EventSourceException while processing event "TraceOperationEnd"

EventSource Error: EventSourceException while processing event "TraceSynchronousWorkEnd"

EventSource Error: EventSourceException while processing event "TraceOperationBegin"

EventSource Error: EventSourceException while processing event "TraceSynchronousWorkEnd"

EventSource Error: EventSourceException while processing event "TraceOperationBegin"

EventSource Error: EventSourceException while processing event "TraceSynchronousWorkBegin"

EventSource Error: EventSourceException while processing event "RunningContinuation"

原因 §

 不明。ただし、MaxDegreeOfParallelismに正の値を指定すると問題がなかった。-1を指定するかあるいは全く指定しない場合はNG。

対応 §

MaxDegreeOfParallelismにEnvironment.ProcessorCountの値を設定して回避した。

正常に動かないケース §

            await Task.Run(() =>

            {

                Parallel.ForEach(source,  (src) =>

                {

                    body(src).Wait();

                });

            });

動いたケース §

            await Task.Run(() =>

            {

                var opt = new ParallelOptions();

                opt.MaxDegreeOfParallelism = Environment.ProcessorCount;

                Parallel.ForEach(source, opt, (src) =>

                {

                    body(src).Wait();

                });

            });

感想 §

「未確認だが、アニバーサリーアップデートのSDKは互換度が低く、他にも引っかかっているソフトがあるらしい」

「初物はそんなもので、徐々にこなれて安定していくのではないの?」

「そうだろうと思うが目の前のOSで自作ソフトがちゃんと動かないことも困る」

Facebook

キーワード【 川俣晶の縁側ソフトウェア技術雑記
【技術雑記】の次のコンテンツ
2016年
08月
18日
Microsoft Store Services SDK 10.0で、UWPがAdMediatorControlからAdControlに移行が強要される問題
3days 0 count
total 779 count
【技術雑記】の前のコンテンツ
2016年
08月
09日
C# PadとC# interactiveで結果が違うケース
3days 0 count
total 725 count
【技術雑記】のコンテンツ全リスト【技術雑記】の表紙

このコンテンツを書いた川俣 晶へメッセージを送る

[メッセージ送信フォームを利用する]

メッセージ送信フォームを利用することで、川俣 晶に対してメッセージを送ることができます。

この機能は、100%確実に川俣 晶へメッセージを伝達するものではなく、また、確実に川俣 晶よりの返事を得られるものではないことにご注意ください。

このコンテンツへトラックバックするためのURL

http://mag.autumn.org/tb.aspx/20160811141436
サイトの表紙【技術雑記】の表紙【技術雑記】のコンテンツ全リスト 【技術雑記】の入手全リスト 【技術雑記】のRSS1.0形式の情報このサイトの全キーワードリスト 印刷用ページ

管理者: 川俣 晶連絡先

Powered by MagSite2 Version 0.25 (Alpha-Test) Copyright (c) 2004-2017 Pie Dey.Co.,Ltd.