디시인사이드 갤러리

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

갤러리 본문 영역

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

ㅆㅇㅆ(124.216) 2025.10.29 01:28:46
조회 356 추천 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/12/01 - -
AD 따뜻한 겨울나기! 방한용품 SALE 운영자 25/11/27 - -
2903747 개발자 관련 카톡 옵챗 보고 있으면 [6] 루도그담당(58.233) 11.21 120 0
2903746 서울에 급진적인 성장을 30년넘게 경험했는데 [1] 타이밍뒷.통수한방(1.213) 11.21 103 0
2903745 김종국, 결혼 발표 24일 만 결별 소식…’각자의 길’ 발명도둑잡기(39.7) 11.21 112 0
2903744 80년대 컴퓨터 학원 [2] 발명도둑잡기(39.7) 11.21 107 0
2903743 imsplayer 노래방 발명도둑잡기(39.7) 11.21 66 0
2903742 폭스레인저 리메이크 소스 발명도둑잡기(39.7) 11.21 89 0
2903741 사람인 이력서 첨쓰는데 헬프 [2] ㅇㅇ갤로그로 이동합니다. 11.21 103 0
2903740 나이먹으니깐 잠이 안온다 먹는건 많이먹게되고 [1] 타이밍뒷.통수한방(1.213) 11.21 75 0
2903737 슬프다..일이 없다. [2] cvs.갤로그로 이동합니다. 11.21 101 0
2903736 문서 구조 개선을 위한 체크리스트 20항목 [2] amdc갤로그로 이동합니다. 11.21 100 0
2903735 조별과제 기능구현 다 마치고 내용 채우는 단계에서 엎자는 놈 나옴 [1] ㅇㅇ(121.127) 11.21 111 0
2903734 러스트라는 훌륭한 언어가 있는 시대에 사는것에 감사하다. [1] 프갤러(221.149) 11.21 107 0
2903732 자료구조 알고리즘 인강은 누구꺼 봐야됨? [4] 프갤러(106.245) 11.21 147 0
2903731 내가 외국인 거르는 기준이 한국에 집착하는 외국인들임 [1] 타이밍뒷.통수한방(1.213) 11.21 172 1
2903730 냥덩이 [1] 발명도둑잡기(118.216) 11.21 84 0
2903729 근데 귀 문제 이명은 아닌게 [8] 루도그담당(58.233) 11.21 140 0
2903728 소설 단 발명도둑잡기(118.216) 11.21 62 0
2903727 냥덩이 스타일 영상 발명도둑잡기(118.216) 11.21 84 0
2903726 요즘 책읽는게 너무 귀찮다 프갤러(182.231) 11.21 90 0
2903725 인생은 즐겨야 한다 chironpractor갤로그로 이동합니다. 11.21 103 0
2903724 아직도 못 깨닫는 내로남불 러스트 빠돌이 ㅋㅋ [14] 나르시갤로그로 이동합니다. 11.21 167 3
2903723 PHP 배우고 있는데 잘 하고 있는걸까 [4] 프갤러(182.231) 11.21 160 0
2903722 귀에서 이명 들려서 [18] 루도그담당(118.235) 11.21 163 0
2903721 [대한민국] 국힘! 최강의 카드를 쥔 장동혁 대표 프갤러(121.172) 11.21 104 0
2903720 소시오패스 의심해봐도 되냐? [8] 프갤러(118.235) 11.21 112 1
2903719 항아리를 파서 조각을.. ㅇㅅㅇ [3] 헤르 미온느갤로그로 이동합니다. 11.21 106 0
2903718 태연 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 11.21 65 0
2903717 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 11.21 90 0
2903716 언제나 애매하게 아는 새끼들이 가장 문제임 [15] ㅇㅇ(124.48) 11.21 587 7
2903715 품질팀이 내가만든 자동화 코드 달래 [8] ㅇㅇ(118.235) 11.21 208 3
2903713 자바 싫어하는 이유 [10] 프갤러(110.8) 11.21 205 0
2903712 인버스 안팔고 버티길 잘했네 [6] chironpractor갤로그로 이동합니다. 11.21 132 0
2903711 뿡애인줄 알앗는데 끙야엿넹.. [2] ♥KiTTY냥덩♥갤로그로 이동합니다. 11.21 126 0
2903710 눈치없는 사람이 계속 호감표시하면 어떻게 대처해야할까 [2] ㅁㅁㅅ갤로그로 이동합니다. 11.21 119 0
2903709 ❤✨☀⭐⚡☘⛩☃나님 시작합니당☃⛩☘⚡⭐☀✨❤ [1] ♥KiTTY냥덩♥갤로그로 이동합니다. 11.21 66 0
2903708 아니 모기가 2마리가 있다고 [3] 루도그담당(58.233) 11.21 82 0
2903707 나님 모닝 끙야중 ☀+ [1] ♥KiTTY냥덩♥갤로그로 이동합니다. 11.21 123 0
2903706 최상위권 탑 명문대 합격 퍼펙트 가이드!% 프갤러(121.142) 11.21 83 1
2903705 개좆병신씨발병신코드리뷰어개패버리고싶은데어떡하냐 [3] 프갤러(86.12) 11.21 135 0
2903700 Skt 얘네 또 뭔 지랄을 했길레 ㅇㅇ(118.235) 11.21 119 0
2903698 음기 충전 발명도둑잡기(118.235) 11.21 126 0
2903696 상냥한 남자에게 발명도둑잡기(118.216) 11.21 61 0
2903695 나는 특별히 싫어하는 언어는 없는데 [1] 발명도둑잡기(118.216) 11.21 118 1
2903692 자바 싫어하는 사람들은 이유가 뭐임? [1] 프갤러(140.248) 11.21 130 0
2903689 오늘의 영상 기획, 발명 실마리: 음악,영화골든벨, 퀴즈 자동 생성 장치 발명도둑잡기(118.216) 11.21 59 0
2903688 프로그래밍 언어 선호 논쟁이 무익한 이유 발명도둑잡기(118.216) 11.21 154 0
2903687 러스트가 병신언어인 이유 프갤러(180.80) 11.21 90 0
2903685 나 등장 [3] 루도그담당(58.239) 11.21 107 1
2903682 와 지갑 잃어버린 줄 알고 깜짝 놀랐다 발명도둑잡기(118.216) 11.21 65 0
2903681 내일 용인간다 마소 주식도 0.002주에서 0.003주 정도 된다. 넥도리아(220.74) 11.20 78 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2