Microsoft MVP성태의 닷넷 이야기
잘못된 Task 사용으로 인한 데드락 관련 질문 입니다. [링크 복사], [링크+제목 복사],
조회: 11097
글쓴 사람
엄태영 (copy3850 at nate.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

안녕하세요 ?

UI가 존재하는 SynchronizationContext가 있는 환경에서
비동기 처리 Task의 결과 처리를 잘못 사용하는 경우 데드락을 유발하는 경우가 있는데요

아래 유명한 블로그의 내용 처럼요
https://blog.stephencleary.com/2012/07/dont-block-on-async-code.html

위 블로그에서는 ASP.NET context 에도 동일하게 적용 된다고 설명이 나와 있고 저도 그렇게 생각하고 있었습니다.

그런데 실제 테스트 해보았을때 ASP.NET 환경에서는 데드락 상황이 나오지 않던데 그 이유가 궁금하여 질문 드립니다.

다음은 제가 테스트 했던 코드 입니다. [매우 간단하기에 그냥 본문에 코드를 작성해 보겠습니다.]


// Controller
public class TestController : Controller
{
    [HttpGet]
    public IActionResult TestEndpointAsync()
    {
        var jsonTask = this.TestAsync();
        string jsonString = jsonTask.Result;
        return Ok(jsonString); // 정상 응답
    }

    private async Task<string> TestAsync()
    {
        using(var client = new HttpClient())
        {
            var jsonString = await client.GetStringAsync("~~~~~~~~~~");
            return jsonString;
        }
    }
}

환경은 ASP.NET (.NET 8.0) Web API 입니다.
테스트는 스웨거 페이지를 통해 호출 했습니다.
* 혹시 몰라서 윈폼에서는 데드락 발생되는 걸 확인 했습니다.

ASP.NET 환경에서는 무조건 데드락 상황이 나오는 것이 아닌 어떤 조건이 맞아야 발생 되는 것인가요 ?
아니면 내부적으로 뭔가 이런 위험 요소는 회피 되도록 바뀐 것인가요 ?


[연관 글]






[최초 등록일: ]
[최종 수정일: 1/12/2024]


비밀번호

댓글 작성자
 



2024-01-12 09시51분
ASP.NET Core/5+부터 AspNetSynchronizationContext는 더 이상 존재하지 않습니다. 즉, SynchronizationContext가 없습니다.

참고로, 해당 응용 프로그램 환경에 SynchronizationContext가 제공되는지 여부는 SynchronizationContext.Current 값이 null인 걸로 확인할 수 있습니다. 시간되시면 다음의 글도 가볍게 읽어보시고. ^^

C# - SynchronizationContext 기본 사용법
; https://www.sysnet.pe.kr/2/0/13190
정성태
2024-01-12 09시53분
인용해 주신 그 분의 블로그에도 다음과 같은 내용을 담고 있습니다.

ASP.NET Core SynchronizationContext
; https://blog.stephencleary.com/2017/03/aspnetcore-synchronization-context.html
정성태
2024-01-12 09시57분
헉, Core부터 SynchronizationContext 가 존재하지 않았군요 !
당연하게도 있을 줄 알았는데 답변 감사합니다.
엄태영

... 61  62  63  64  65  66  67  [68]  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
888김재영7/5/201014368TFS에 반드시! SQL Report랑 SharePoint(or WSS)가 붙어야 합니까? [2]
887임동찬7/2/201015690WCF sendTimeout에 관하여... [1]
886김재영6/16/201015698스레드 선언시 (Parameterized/)ThreadStart에 정의되는 메소드의 위치에 질문이 있습니다. [3]
885장근배6/13/201023102Win32Exception 창 핸들 에러 [1]
883채동민6/10/201015287비동기 DB 쿼리관련 질문
884정성태6/10/201016742    답변글 [답변]: 비동기 DB 쿼리관련 질문
881최준영5/24/201016516load되지않은 아이템 load하는 방법? [1]
880임상일5/10/201018612VS2010 TestManager를 통한 UI Test 관련 질문입니다. [2]파일 다운로드1
879정용훈5/3/201019851wcf 인증 문제 [2]
878채동민4/20/201019051WCF에서 maxItemsInObjectGraph 오류 관련 질문드립니다. [2]
872날쌘돌이4/8/201021751Windows7 에서 IIS에서 폼인증 으로 디버깅.. [1]파일 다운로드1
871영초4/7/201017109실버라이트로 스캐너 구동 프로그램이 가능할까요? [1]
869김재영4/6/201015995이미 실행된 어셈블리 컨트롤 권한을 다른 어셈블리에서 가져올 수 있습니까? [2]
868Lime3/5/201019596WCF 에서의 DataTable 사용 [2]
867Dani...2/18/201019729Question - HTTP 401.3 on DELETE, PUT verbs [6]파일 다운로드1
865박근대2/16/201016209WCF 오류 문의. [1]
863날쌘돌이1/31/201018550ActiveX Cab에서 닷넷 dll 등록 [1]
862장근배1/28/201016326AppPolId를 알 수 있는 방법이 있는지요? [1]
864장근배2/1/201015984    답변글 [답변]: AppPolId를 알 수 있는 방법이 있는지요?
858생초보1/26/201016355안녕하세요.. 파일 생성 처리 문제로 .... [2]
857꼭지1/22/201022097How to support Basic + Windows authentication mode in WCF(RESTful service) [4]파일 다운로드2
856질의자1/13/201020053vcredist_x86 배포 관련 여쭙습니다. [1]
855임동찬1/13/201018151이벤트 핸들러와 쓰레드의 관계 2 [4]파일 다운로드2
854임동찬1/12/201018442이벤트 핸들러와 쓰레드의 관계 [1]
853장근배1/12/201018042압축 프로그램,, [1]
852임동찬1/6/201015428base.OnStart(agrs) [1]
... 61  62  63  64  65  66  67  [68]  69  70  71  72  73  74  75  ...