디시인사이드 갤러리

갤러리 이슈박스, 최근방문 갤러리

갤러리 본문 영역

에이도비야. 경력 15년 인정이야한다만 개념적으로 틀렸다. 설명해줌

ㅆㅇㅆ(124.216) 2025.10.29 01:28:46
조회 250 추천 0 댓글 0
														

1. 니가 작성한 테스트의 문제


lru_cache는 메모이제션 캐싱이고


lambada_:store_instance 는 'DI 컨테이너를 통한 애플리 케이션 스코프 싱글톤 인스턴스임'


이 캐싱차이는 너도 알거라 생각한다. 인스턴스 캐싱을 말하는데 왜 자꾸 메모이제션 캐싱을 이야기하냐 FAST API가 원하는 양식을 구현하는거임


2.asyncio.gather는 단일스레드내 비동기 동시성임


내가 테스트하려는건 parallelism임


이 상황에서 변경가능한(mutable)상태를 공유하는 싱글톤은 데이터 레이스가 발생함


3. 실행모델에 대한 오해


unvicorn -- worker2 같이 별개 os 프로세스 2개 띄우는건데 이게 뭐가 문제임? 당연히 메모리간 이고


4. Depends 방식은 리퀘스트 스코프(웹) 방식이고, 이건 VectorStore는 애플리케이션 스코프다.


FastAPI에서도 lifeSpan 쓰라고 한다.


import concurrent.futures
import threading
import time

# --- 1. '에이도비'가 주의해서 쓰면 된다는 '가변 싱글톤' ---
# (예시로 든 'dict'처럼 '가변 상태(counter)'를 가짐)

class NaiveMutableSingleton:
    _instance = None
   
    def __new__(cls):
        # 고전적인 싱글톤 구현
        if cls._instance is None:
            time.sleep(0.0001) # 스레드 충돌을 유도하기 위한 약간의 딜레이
            cls._instance = super().__new__(cls)
            cls._instance.counter = 0 # <-- 이것이 '공유된 가변 상태'
        return cls._instance

    def increment(self):
        """
        이 함수는 '스레드 안전(Thread-Safe)'하지 않는다
        """
        current_val = self.counter  # 1. 값 읽기 (Read)
       
        # --- 위험 구간 (Critical Section) ---
        # 이 시점에 다른 스레드가 끼어들어 'current_val'을 동시에 읽을 수 있음!
        time.sleep(0.0001) # 다른 스레드가 끼어들 시간을 강제로 만듦
        # --- 위험 구간 끝 ---
       
        self.counter = current_val + 1 # 2. 값 쓰기 (Write)

# --- 2. '에이도비'의 테스트(asyncio)가 아닌, '진짜 병렬' 테스트 ---
# 멀티 스레드 (ThreadPoolExecutor)를 사용

NUM_THREADS = 10     # 10개의 스레드 (병렬 에이전트)
NUM_TASKS_PER_THREAD = 100 # 각 스레드가 100번씩 작업
TOTAL_TASKS = NUM_THREADS * NUM_TASKS_PER_THREAD # 총 예상 값 = 10 * 100 = 1000

print(f"--- '가변 싱글톤' 병렬 안정성 테스트 ---")
print(f"{NUM_THREADS}개의 병렬 스레드(에이전트)가 싱글톤의 counter를 {NUM_TASKS_PER_THREAD}번씩 총 {TOTAL_TASKS}번 증가시킵니다.")
print("('에이도비' 주장: '주의해서 쓰면' 문제없다)")
print("('내' 주장: '가변 싱글톤'은 병렬 환경에서 데이터 경쟁을 일으킨다)\n")

def run_task(task_id):
    s = NaiveMutableSingleton()
    for _ in range(NUM_TASKS_PER_THREAD):
        s.increment()
    # print(f"스레드 {task_id} 완료...") # 주석 해제 시 더 복잡하게 얽힘

# 진짜 병렬 실행
with concurrent.futures.ThreadPoolExecutor(max_workers=NUM_THREADS) as executor:
    futures = [executor.submit(run_task, i) for i in range(NUM_THREADS)]
    concurrent.futures.wait(futures)

# --- 3. 결과 ---
final_counter = NaiveMutableSingleton().counter

print("\n--- 테스트 결과 ---")
print(f"예상 최종 값 (기대 값): {TOTAL_TASKS}")
print(f"실제 최종 값 (측정 값): {final_counter}")

if final_counter == TOTAL_TASKS:
    print("\n결과: ✅ 성공 (이론상 거의 불가능한 확률)")
else:
    print(f"\n결과: ❌ 대실패! (값이 깨짐)")
    print(f"이유: {TOTAL_TASKS - final_counter}번의 쓰기(write) 작업이 '데이터 경쟁'으로 인해 유실됨.")
    print("이것이 '공유된 가변 상태'를 병렬로 접근할 때의 위.")

print("\n--- 결론 ---")
print("1. '에이도비'의 `asyncio.gather` 테스트는 '단일 스레드' 비동기라 이 문제를 발견조차 못함")
print("2. '주의해서 쓴다'는 말은, 모든 'increment' 함수에 'Lock'을 걸어야 한다는 뜻이며, 이는 코드를 복잡하게 하고 성능을 저하시킴.")
print("3. 내 방식(DI + Lifespan)은 애초에 이런 '가변 상태'를 공유하지 않고,")
print("   '스레드 세이프'하거나 '불변'한 객체의 '참조'를 주입하므로, 아키텍처 수준에서 이 위험이 없음.")



24b0d121e09c28a8699fe8b115ef0469933efebd


다시한번 말하지만 리소스 정리 빼먹은거 지적해준거 고맙게 생각함


그냥 어차피 꺼지면 리소스 정리되니까 빼먹었는데 명시적으로 넣는게 맞지.


근데 그건 그거고 


이건 이거임.


너는 자꾸 '다중 이용자가 쓴다' 이걸로 착각하는데


그게 아님.


추천 비추천

0

고정닉 0

0

원본 첨부파일 1

댓글 영역

전체 댓글 0
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 영포티룩도 멋지게 소화할 것 같은 40대 스타는? 운영자 25/10/27 - -
AD 저녁 뭐먹지? 오늘의 메뉴 추천! 운영자 25/10/31 - -
2899317 존중을 할 마음이 들게 처신을 해야지 [9] 에이도비갤로그로 이동합니다. 10.29 129 3
2899316 <저스트 메이크업> 한대서 생각나는 예전 글 발명도둑잡기(118.235) 10.29 60 0
2899315 INTJ가 남 권위를 제일 개무시한다 [3] 발명도둑잡기(118.235) 10.29 79 2
2899311 주간 운세 이거 좀 잘못된거같은데 다시해야겠다 [3] ㅆㅇㅆ(124.216) 10.29 74 0
2899310 오늘의 소설, 영화 실마리: 인공지능이 거짓 선동 독재 발명도둑잡기(118.235) 10.29 38 0
2899309 오늘의 발명 실마리: 인공지능의 거짓말 실력 정량화 발명도둑잡기(118.235) 10.29 39 0
2899304 20대초때 여기서 웹떌깜된다는글만안봣어도 [1] 프갤러(222.120) 10.29 106 0
2899296 AI 세금, 기본소득 발명도둑잡기(118.235) 10.29 58 0
2899291 80년대 게임 디지타이저 도트 발명도둑잡기(118.235) 10.29 46 0
2899289 내 코드로 그냥 설명해줌. 왜 그렇게 짜야만했는지. ㅆㅇㅆ(124.216) 10.29 95 0
2899288 너가 나한테 외주 맡기고 명세주면 네 말대로 구현하겠지 ㅆㅇㅆ(124.216) 10.29 62 0
2899287 테스트 가져옴. 애초에 diff로 값 추가하는 방식으로 갈거라 ㅆㅇㅆ(124.216) 10.29 50 0
에이도비야. 경력 15년 인정이야한다만 개념적으로 틀렸다. 설명해줌 ㅆㅇㅆ(124.216) 10.29 250 0
2899283 ㅆㅇㅆ야 자신 있으면 테스트를 하라니까 [13] 에이도비갤로그로 이동합니다. 10.29 153 1
2899281 호미들(Homies) - 완공 발명도둑잡기(118.235) 10.29 37 0
2899280 프갤 안하는게 정신 건강에 좋은듯. [1] 프갤러(106.101) 10.29 94 0
2899279 주제파악 안되는 사람들의 모임. ㅇㅇ(106.101) 10.28 71 0
2899278  경제 저격수의 양심선언 "미국이 개도국 지원하는 건.." [1] 발명도둑잡기(39.7) 10.28 54 0
2899277 너희들은 부모님께 효도해라... [2] 넥도리아(220.74) 10.28 96 0
2899273 윤석열과 이영지 발명도둑잡기(39.7) 10.28 98 0
2899271 "'서울 아파트 보유' 미국인 63%, '한강벨트'에" 발명도둑잡기(39.7) 10.28 46 0
2899270 한강벨트 아파트 수천채 산 미국인…중국인은 이 동네 몰렸다 발명도둑잡기(39.7) 10.28 55 0
2899269 "무상제공 평택기지, 연 임대료 4조원이라고 美 설득" 발명도둑잡기(39.7) 10.28 35 0
2899268 “트럼프의 약탈에 맞서 미 대사관·미군기지 임대료 받자” 발명도둑잡기(39.7) 10.28 47 0
2899267 [단독] 주한미국대사관 45년간 ‘공짜’ 사용 발명도둑잡기(39.7) 10.28 64 0
2899266 supabase 아무리 생각해도 너무 편한거 같음. [1] ㅆㅇㅆ(124.216) 10.28 78 0
2899265 서울 청년창업 지원 [5] 발명도둑잡기(39.7) 10.28 87 0
2899263 종교는 마약인가 [2] 발명도둑잡기(39.7) 10.28 69 0
2899258 유럽 각국 야간 노동시 임금 가산 [2] 발명도둑잡기(39.7) 10.28 57 1
2899256 아.. 밥만 먹으면 잠오는거 미치겠네 [7] chironpractor갤로그로 이동합니다. 10.28 94 0
2899255 새벽배송이 좋으면 [4] 발명도둑잡기(39.7) 10.28 76 0
2899253 ‘쿠팡’도 합류한 3차 택배 대화기구, ‘새벽·휴일 배송’ 논의 발명도둑잡기(39.7) 10.28 65 0
2899251 이번에 구두 계약했던 사무실 방세를 지좆대로 6만원 올려서 포기함 [15] ㅆㅇㅆ(124.216) 10.28 111 0
2899240 디씨앱 트루먼쇼 봤다 발명도둑잡기(39.7) 10.28 47 0
2899236 트럼프 다카이치 희토류 공급망 동맹 ㄷㅅㄷ ♥벼락부자냥덩♥갤로그로 이동합니다. 10.28 78 0
2899234 저녁 발명도둑잡기(39.7) 10.28 39 0
2899232 오타니 mlb 씹어먹는즁인 ㄷㅅㄷ ♥벼락부자냥덩♥갤로그로 이동합니다. 10.28 74 0
2899230 좌좀 스프레이는 없나여? [2] ♥벼락부자냥덩♥갤로그로 이동합니다. 10.28 47 0
2899229 아 근데 타로 사이트 애드센스 진짜 안붙네 [4] ㅆㅇㅆ(124.216) 10.28 86 0
2899228 계산해보니 일정 꽤 촉박하구낭 ♥벼락부자냥덩♥갤로그로 이동합니다. 10.28 33 0
2899226 간식 [1] 발명도둑잡기(39.7) 10.28 74 0
2899225 李 “한국은 일본이 아니다”… 기업이 美투자 주도 EU모델 거론 발명도둑잡기(39.7) 10.28 52 0
2899224 라이브러리 업뎃햇더니 에러 폭격 [9] 헬마스터갤로그로 이동합니다. 10.28 88 0
2899223 “트럼프도 놀랐다!” 이재명의 한마디 "한국은 일본이 아니다" 발명도둑잡기(39.7) 10.28 52 0
2899222 야 근데 아이피좀 고만 바꿔라. 차단해서 신경 안쓰는데 [2] ㅆㅇㅆ(124.216) 10.28 74 0
2899221 ㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋ 프갤에도 유머통이 있었노 ㅋㅋㅋ [2] ♥벼락부자냥덩♥갤로그로 이동합니다. 10.28 68 0
2899220 아무튼 난 천재개발자라고!!! [1] ㅇㅇ(118.235) 10.28 98 3
2899219 치킨집 들어가서 손님이 남긴 음식들 주워먹어도 되냐? [3] ㅇㅇ1갤로그로 이동합니다. 10.28 62 0
2899218 원종이가 더 능력남임 ㅋㅋ ㅇㅇ(118.235) 10.28 43 2
2899217 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ ♥벼락부자냥덩♥갤로그로 이동합니다. 10.28 29 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2