디시인사이드 갤러리

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

갤러리 본문 영역

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

ㅆㅇㅆ(124.216) 2025.10.29 01:28:46
조회 248 추천 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 - -
2899784 알고보니 어렸을 때 치파오 입고 있었고 프갤러(211.210) 10.31 20 0
2899783 기안84 수상한 건 프갤러(211.210) 10.31 34 0
2899782 김창욱 김제동 오은영 같은 프갤러(211.210) 10.31 20 1
2899781 부천역 bj들 내쫒는 분위기네 프갤러(211.210) 10.31 15 0
2899780 나님 왤캐 특별하실깡..? ♥KiTTY냥덩♥갤로그로 이동합니다. 10.31 20 0
2899777 ㅆㅇㅆ도 진짜 대단하다 ㅋㅋㅋㅋ ㅇㅇ(124.48) 10.31 40 0
2899776 아 그냥 개 씨발 속터져가지고 모르겠음 [8] ㅆㅇㅆ(124.216) 10.31 63 0
2899775 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ ♥KiTTY냥덩♥갤로그로 이동합니다. 10.31 16 0
2899774 Fastapi 관련 뉴비 질문 받아주세요.. [10] ㅇㅇ(61.97) 10.31 63 0
2899773 플러터 인생 40 년 갈아 넣었습니다. [1] 프갤러(59.16) 10.31 27 0
2899772 진심으로 하는 소리인데 ㅆㅇㅆ야 병원 한번 가봐라 ㅇㅇ(124.48) 10.31 43 0
2899771 한국 프로그래머들이 저능해서 러스트 못쓰고 있는 내가 불쌍해 프갤러(110.8) 10.31 20 0
2899768 갤러리 난타전이 정말 어질어질하다. [1] 헬마스터갤로그로 이동합니다. 10.31 32 0
2899767 ㅆㅇㅆ 불쌍한 새끼 [1] ㅇㅇ(124.48) 10.31 52 0
2899765 요즘 의욕이 확 떨어져서 구직급여 받으면서 좀 쉬고 싶은데 [1] 프갤러(110.8) 10.31 31 0
2899764 뭐야 "새 회사"에서 짤림? [1] 프갤러(110.8) 10.31 37 0
2899763 124.48 얼탱이가 터져서 헛웃음 나오노 ㅋㅋㅋ [2] ㅆㅇㅆ(124.216) 10.31 47 0
2899762 공기업 납품 ㅇㅈㄹ 싸고 있네 ㅋㅋㅋㅋㅋㅋㅋ ㅇㅇ(124.48) 10.31 37 0
2899761 나씻주준⭐+ ♥KiTTY냥덩♥갤로그로 이동합니다. 10.31 16 0
2899760 저 아래 레디스 문제 그냥 공식 문서에도 있는 문제인데 [2] ㅆㅇㅆ(124.216) 10.31 48 0
2899759 병먹금 하세요 [2] 발명도둑잡기(211.246) 10.31 26 0
2899757 뭐? 프리랜서? ㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋ ㅇㅇ(106.101) 10.31 28 0
2899756 공기업 납품? ㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋ ㅇㅇ(106.101) 10.31 32 0
2899750 참 불쌍한게 자기가 다중이한다고 내가 대화한걸 다중이로 몰아버리노 [4] ㅆㅇㅆ(124.216) 10.31 44 0
2899748 애초에 니 다중이로 자문자답하던거 까먹었냐? ㅇㅇ(106.101) 10.31 37 0
2899747 선생님들 실무에서 레디스로 루아스크립트 많이 사용하나요?(기술선 [15] 프갤러(116.33) 10.31 98 0
2899746 ㅆㅇㅆ야 그런데 난 정말 다중이는 안한다 ㅇㅇ(106.101) 10.31 33 0
2899744 자바 파이썬 증오하는 이유. [1] 프갤러(59.16) 10.31 28 0
2899743 오늘따라 ㅆㅇㅆ가 존나 불쌍하다 [2] ㅇㅇ(106.101) 10.31 55 0
2899742 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ ♥KiTTY냥덩♥갤로그로 이동합니다. 10.31 16 0
2899741 ㅆㅇㅆ 스토킹하는 놈도 발명도둑잡기(211.234) 10.31 27 0
2899740 오늘도 그녀와 함께 오붓한 밤을 넥도리아2025(14.35) 10.31 17 0
2899739 내가 참여중인 사프가 6,000팀중에 30팀안에 들었음 [1] 따당갤로그로 이동합니다. 10.31 39 0
2899738 ㅂㅅ 발명도둑잡기(211.234) 10.31 34 0
2899737 나님 끙야가 끙구멍에 걸린 느낌.. ♥KiTTY냥덩♥갤로그로 이동합니다. 10.31 40 0
2899736 국민의힘 갤러리 내란 십새가 맨날 30일마다 댓글 쓰지도 않았는데 차단네 [1] 넥도리아2025(14.35) 10.31 28 0
2899735 ㅆㅇㅆ장애인새끼 또 소설 쓰고 있네 ㅇㅇ(118.235) 10.31 50 1
2899734 오늘 이전에 프갤서 연락줬던 학생 연락와서 인사하니 기분좋노 ㅋㅋ [7] ㅆㅇㅆ(124.216) 10.31 78 0
2899733 빡칠땐 산책을 한다 [7] chironpractor갤로그로 이동합니다. 10.31 46 0
2899731 BOYNEXTDOOR (보이넥스트도어) 'Hollywood Action' 발명도둑잡기(118.216) 10.31 18 0
2899730 내향적인간이.. 우울증이나 조현병 잘 걸린다고 누가 그러던데..ㅇㅅㅇ [2] 헤르 미온느갤로그로 이동합니다. 10.31 34 0
2899729 최미니 사퇴해. 넥도리아2025(14.35) 10.31 21 0
2899717 [현장에서] 트럼프 1박 2일에 부쳐: 언제까지 미국을 섬겨야 하나 발명도둑잡기(118.216) 10.31 42 0
2899716 내가 관심있는 여성들 발명도둑잡기(118.216) 10.31 28 0
2899715 <착한 여자 부세미> 한대서 생각나는 예전 글 발명도둑잡기(118.216) 10.31 25 0
2899714 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ [2] ♥KiTTY냥덩♥갤로그로 이동합니다. 10.31 48 0
2899713 해가 넘 짤바져서 ♥KiTTY냥덩♥갤로그로 이동합니다. 10.31 28 0
2899712 옛날 자본금 몇천으로 인력업체세우는게 [15] 배구공(119.202) 10.31 71 0
2899711 유명 女스타, 해외 촬영 중 사망 발명도둑잡기(118.216) 10.31 25 0
2899709 트럼프 가고 “극우 청천벽력”…윤석열의 윤 자도 안 꺼내고 떠났다 발명도둑잡기(118.216) 10.31 52 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2