디시인사이드 갤러리

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

갤러리 본문 영역

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

ㅆㅇㅆ(124.216) 2025.10.29 01:28:46
조회 274 추천 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
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 해외에서 겪는 불합리한 대우에 대응 잘 할 것 같은 스타는? 운영자 25/11/03 - -
AD 저녁 뭐먹지? 오늘의 메뉴 추천! 운영자 25/10/31 - -
2900691 잡긴 잡았는데 한 마리 아닐경우가 걱정.. [2] ♥KiTTY냥덩♥갤로그로 이동합니다. 11.04 92 0
2900690 누워서 자려는데 갑자기 뭔가 눈에 걸리적 거리다 설마.. ♥KiTTY냥덩♥갤로그로 이동합니다. 11.04 38 0
2900689 와 개 ㅅㅂ.. ♥KiTTY냥덩♥갤로그로 이동합니다. 11.04 44 0
2900688 아이고 갤이 또 씹창이 났구만 ㅇㅇ(122.199) 11.04 42 0
2900687 [애니뉴스] 선행컷! 이 멋진 세계에 축복을! 프갤러(121.172) 11.04 25 0
2900686 나님 주무시기전 소통⭐+ 질문 받음 [5] ♥KiTTY냥덩♥갤로그로 이동합니다. 11.04 58 0
2900677 뀨? ♥KiTTY냥덩♥갤로그로 이동합니다. 11.04 67 0
2900668 나님 애널 일찍 졸린듯? 영차끙차 나씻주준? ♥KiTTY냥덩♥갤로그로 이동합니다. 11.04 68 0
2900666 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ ♥KiTTY냥덩♥갤로그로 이동합니다. 11.04 64 0
2900664 자기객관화 ♥KiTTY냥덩♥갤로그로 이동합니다. 11.04 45 0
2900658 알고보니 어렸을 때 치파오 입고 있었고 프갤러(211.210) 11.04 41 0
2900657 기안84 수상한 건 프갤러(211.210) 11.04 64 0
2900656 요즘 좌파 화교 특 프갤러(211.210) 11.04 34 0
2900650 부천역 bj들 내쫒는 분위기네 프갤러(211.210) 11.04 47 0
2900647 학생들 꽤나 스택이랑 힙 어려워하네 [3] ㅆㅇㅆ(104.28) 11.04 87 0
2900646 나는조현병이야 나는내향적이야 손발이시립디다갤로그로 이동합니다. 11.04 60 0
2900645 점심에 먹었던 짜장면이 생각나 [6] 루도그담당(58.239) 11.04 57 0
2900641 누가 자꾸 냥덩이글에 댓글유령짓 하는거야..? [1] ♥KiTTY냥덩♥갤로그로 이동합니다. 11.04 44 0
2900639 냥덩이 고양이 고기 먹었다고 인증 [1] 발명도둑잡기(118.235) 11.04 67 0
2900638 러스트나 배우고 기뻐해라 프갤러(211.234) 11.04 38 0
2900637 ‘배우고 그것을 때때로 익히니 기쁘지 않겠는가’ 발명도둑잡기(118.235) 11.04 19 0
2900636 나님 저녁맘마 인증❤+ [1] ♥KiTTY냥덩♥갤로그로 이동합니다. 11.04 53 0
2900635 공부해서 남 주냐 발명도둑잡기(118.235) 11.04 27 0
2900634 “나는 여색을 좋아하듯이 덕을 좋아하는 사람을 보지 못하였다.” [1] 발명도둑잡기(118.235) 11.04 37 0
2900633 상수, 변수란 사람이 있구나 발명도둑잡기(39.7) 11.04 54 0
2900632 하프마라톤 정도 뛰면 회복이 잘 안 되는군 ♥KiTTY냥덩♥갤로그로 이동합니다. 11.04 42 0
2900631 뛰어 보려구 햤는데 아직 저번 마라똔 여파가 있는듯 ♥KiTTY냥덩♥갤로그로 이동합니다. 11.04 39 0
2900630 [대한민국] 윤석열 대통령 재판 - 법정에서 위증하는 곽종근 프갤러(121.172) 11.04 42 0
2900628 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ ♥KiTTY냥덩♥갤로그로 이동합니다. 11.04 35 0
2900627 토스 새끼들은 옵션거래를 하라고 왜 추천하는거냐 미친놈들 아님? [2] ㅆㅇㅆ(104.28) 11.04 101 0
2900625 [단독] 정보사, 안규백 장관 보고 없이 휴민트 부서 서류 등 이전 시도 발명도둑잡기(39.7) 11.04 36 0
2900624 매일 배운다는 것은 살아있다는 것이고 [2] ㅆㅇㅆ(104.28) 11.04 62 0
2900623 매일 배우고 일할 것이 많으니 난 참으로 행복한 인물이구나 ㅆㅇㅆ(104.28) 11.04 40 0
2900622 진정한 프로그래밍하러 가야하는데 출퇴근 시간이 너무 오래 걸린다. [1] 프갤러(218.154) 11.04 63 0
2900621 나도 프갤에 자극받아서 장사 자동화 손놓고 있던거 다시 하는중 [4] chironpractor갤로그로 이동합니다. 11.04 69 0
2900620 졸작으로 챗봇 만들건데 앱vs웹 뭐가 나을까 [3] ㅇㅇ(106.101) 11.04 54 0
2900619 투비 소프트 폐업 검색하니 제글이 가장먼저 [4] 헬마스터갤로그로 이동합니다. 11.04 71 0
2900618 구글 누리끼리해졌노 ㅇㅇ(122.199) 11.04 53 0
2900617 여기 미드레벨 이상 개발자 얼마나 있냐? [1] 프갤러(125.244) 11.04 58 0
2900616 일요일날 여성분 10-1 결정사 가입했다는걸 대놓고 사생활에서 애기하세요 넥도리아2025(14.35) 11.04 34 0
2900615 프갤에서 취직 조언을 듣기 힘든게 여기는 대체로 [2] ㅆㅇㅆ(104.28) 11.04 91 2
2900614 국비 어찌해야할까요 한번만 부탁드립니다. [2] ㅇㅇ(211.246) 11.04 83 0
2900613 콘덴서 쇼트하면 모르는 영상 까지 나온다 페라까지... 넥도리아2025(14.35) 11.04 28 0
2900612 지금 커서 서버 터진거냐? 갑자기안되노 [1] 프갤러(125.244) 11.04 52 0
2900611 누구에게도 야동보면서 애기못하는 콘덴서 쇼트 핀셋 넥도리아2025(14.35) 11.04 27 0
2900610 파이썬 경력 5시간 ㅁㅌㅊ.. [5] 칠시갤로그로 이동합니다. 11.04 96 1
2900609 오늘의 업무 중앙도서관 API 받아서 DB에 있는 데이터와 맞는지 대칭후 ㅆㅇㅆ(104.28) 11.04 40 0
2900608 확실히 SVN 쓰다가 깃으로 전환하니 일거리가 많다 ㅆㅇㅆ(104.28) 11.04 47 0
2900607 근데 나는 졸업과제 옛날부터 다 나혼자 했는데 [2] ㅆㅇㅆ(104.28) 11.04 54 0
2900606 C# 써본지 백만년 되간다 진짜 ㅆㅇㅆ(104.28) 11.04 44 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2