본문 바로가기
반응형

Develop233

데드락을 유도하는 코루틴 사용법 서론 이 글은 코루틴을 사용하다 겪었던 장애를 소개하는 글이다. 장애 원인이 밝혀지기까지 복잡한 과정이 있었으나, 모두 생략하고 코루틴에 대한 내용만 골라내 설명한다. 장애 원인은 무엇이었는지, 그 원인을 유도한 상황은 무엇인지, 어떻게 해결했는지 등을 정리해 보도록 하겠다. 코루틴에서 발생할 수 있는 데드락 (feat. runBlocking) 데드락이 발생할 수 있는 예제를 가져와보았다. 이 예제에는 두 가지 가정이 존재한다.dispatcher는 스레드를 2개까지 할당할 수 있는 디스패처async(dispatcher) { ... } 의 ...은 동기 호출이라 중단될 일이 없다🔻 실행 가능한 예제코드더보기아래 코드를 실행하면 애플리케이션이 종료되지 않는다. 그 이유는 하단에서 자세히 살펴보겠다.fun .. 2025. 1. 11.
구조적 동시성 이해하기 (feat. goto의 역사) 이 글은 'Notes on structured concurrency, or: Go statement considered harmful'을 번역한 글입니다. 원작자의 허락하에 번역하였음을 분명히 밝힙니다. 좀 더 쉬운 표현을 위해 의역한 부분도 있으니, 원문이 궁금한 분들은 링크를 참고하시길 바랍니다. Thanks to Nathanial J. Smith for allowing the translation. Notes on structured concurrency, or: Go statement considered harmful — njs blogvorpus.org 모든 동시성 API는 코드를 동시 실행할 방법이 필요하다. 다음은 몇 가지 예시다.go myfunc(); .. 2024. 12. 23.
[Kotest] Kotest 활용 간단 가이드 Kotest란? 🤔 공식 사이트에 가보면 Kotest를 아래와 같은 말로 표현하고 있다.Kotest is a flexible and elegant multi-platform test framework for Kotlin with extensive assertions and integrated property testing 위의 말을 보면 총 3가지 정도의 기능을 제공하고 있다. 각 기능들을 독립적으로 사용할 수 있는데, 이는 Kotest가 독립적으로 나뉜 여러 개의 하위 프로젝트들로 구성되어 있기에 가능한 일이다. (3가지 기능을 모두 사용하고 싶다면 의존성도 각자 추가해야 한다는 의미이다.) 일단 어떤 기능들을 제공하고 있는지부터 살펴보자. 1. 유연하고 우아한 멀티 플랫폼 테스트 프레임워크다.👉 .. 2024. 10. 27.
Spring MVC + Coroutines 에 대한 고민 🤔 문제의 시작 우리 팀은 Spring MVC와 Coroutines, Kotlin을 사용하는 레포가 있다. 신규 API를 개발해서 호출하니 NoClassDefFoundError가 발생했다. MonoKt를 찾지 못한다고 한다. 모든 API에서 발생하는 건 아니고 코루틴을 적용한 API에서만 발생하였다.Handler dispatch failed: java.lang.NoClassDefFoundError: kotlinx/coroutines/reactor/MonoKt 많은 곳에서 kotlinx.coroutines.reactor 의존성을 추가하라는 말만 있을 뿐, 명쾌한 해결 방법이나 원인에 대해 알기는 어려웠다. WebFlux를 사용하는 것도 아닌데 reactor와 관련된 의존성을 왜 추가해야 하는지 이해가 안.. 2024. 9. 30.
[Coroutines] 코루틴과 공유 상태 코루틴 스터디를 하며 정리 중인 시리즈 글왜 코루틴을 써야할까?[Coroutines] 코루틴 빌더, 코루틴 컨텍스트[Coroutines] 구조화된 동시성[Coroutines] 코루틴 스코프 함수[Coroutines] 디스패처[Coroutines] 코루틴과 공유상태 코루틴 코루틴의 이름에는 아래와 같은 뜻이 담겨있다.co: 함께, 협력하는routine: 특정한 일을 처리하기 위한 일련의 명령coroutine: 함께 실행되는 루틴. 서로 간에 스레드 사용을 양보하며 함께 실행됨 코루틴은 항상 하나의 스레드 위에서 동작하지는 않는다. 코루틴 디스패처와 스레드풀의 연관 관계는 '[Coroutine] 디스패처' 포스트를 참고하길 바란다. 코루틴은 일시 중단이 일어나면 다른 코루틴에게 스레드를 양보한다는 점을 기억.. 2024. 7. 31.
[Coroutines] 코루틴 디스패처 코루틴 스터디를 하며 정리 중인 시리즈 글왜 코루틴을 써야할까?[Coroutines] 코루틴 빌더, 코루틴 컨텍스트[Coroutines] 구조화된 동시성[Coroutines] 코루틴 스코프 함수[Coroutines] 디스패처[Coroutines] 코루틴과 공유상태 💥 디스패처 코루틴 컨텍스트에 대해 학습할 때 디스패처에 대해 간단히 학습하고 넘어갔었다. 이 글에서는 디스패처를 좀더 자세히 알아볼 예정이다. 영단어 디스패처는 사람이나 차량 등을 필요한 곳에 보내는 것을 담당하는 사람이라는 뜻이다. 코루틴에서의 디스패처는 코루틴을 스레드로 보내는 역할(어떤 환경에서 실행될지 결정하는 역할)을 한다.  📌 CoroutineDispatcher의 동작CoroutineDispatcher는 아래와 같은 그림처럼 .. 2024. 7. 8.
[Coroutines] 코루틴 스코프 함수 코루틴 스터디를 하며 정리 중인 시리즈 글왜 코루틴을 써야할까?[Coroutines] 코루틴 빌더, 코루틴 컨텍스트[Coroutines] 구조화된 동시성[Coroutines] 코루틴 스코프 함수[Coroutines] 디스패처[Coroutines] 코루틴과 공유상태 🎉 coroutineScope 코루틴 스코프 함수는 중단함수 내에서 스코프가 필요할 때 사용한다. coroutineScope는 코루틴 스코프 함수의 일종이다. 🔸 coroutineScope 로 인해 중단되는 코루틴coroutineScope는 새로운 코루틴을 생성하면 작업이 끝날 때까지 coroutineScope를 호출한 코루틴을 중단시킨다. 아래 예제를 보면 println이 순차적으로 진행되는 것을 볼 수 있다.suspend fun main.. 2024. 6. 29.
[Coroutines] 구조화된 동시성, 코루틴 스코프 코루틴 스터디를 하며 정리 중인 시리즈 글왜 코루틴을 써야할까?[Coroutines] 코루틴 빌더, 코루틴 컨텍스트[Coroutines] 구조화된 동시성[Coroutines] 코루틴 스코프 함수[Coroutines] 디스패처[Coroutines] 코루틴과 공유상태 🎄 구조화된 동시성'왜 코루틴을 써야할까?'에서 구조화된 동시성에 대해 아주 잠깐 설명했었다. 이 포스팅을 통해서 좀 더 자세한 이야기를 다뤄보려고 한다.  구조화된 동시성(Structured Concurrency)이란, 비동기 작업을 구조화함으로써 비동기 프로그래밍을 보다 안정적이고 예측 가능하게 만드는 원칙이다. 코틀린 코루틴은 비동기 작업인 코루틴을 부모-자식 관계로 구조화함으로써 코루틴을 안전하게 관리 및 제어하게 만들어졌다. 구조화된.. 2024. 6. 29.
[Coroutines] 코루틴 빌더, 코루틴 컨텍스트 코루틴 스터디를 하며 정리 중인 시리즈 글왜 코루틴을 써야할까?[Coroutines] 코루틴 빌더, 코루틴 컨텍스트[Coroutines] 구조화된 동시성[Coroutines] 코루틴 스코프 함수[Coroutines] 디스패처[Coroutines] 코루틴과 공유상태 🔅 코루틴 빌더 코틀린 코루틴은 코루틴을 일시 중단시킨다. 이런 방식을 통해 스레드를 블로킹할 때보다 훨씬 가볍게 사용할 수 있다. 그런데 이 코루틴 중단은 중단 함수 내에서만 일어날 수 있다. 그리고 중단함수는 중단함수 내에서만 호출되어야 한다. 중단함수가 최초로 시작되는 지점은 어디일까? 바로 코루틴 빌더다. 🔸 코루틴 빌더중단 함수가 시작되는 지점모든 코루틴 빌더는 자신의 Job을 생성 (Job에 대한 설명은 하단에 있다.)launch.. 2024. 6. 23.
반응형