디시인사이드 갤러리

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

갤러리 본문 영역

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

ㅆㅇㅆ(124.216) 2025.10.29 01:28:46
조회 249 추천 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 - -
2899516 ㅆㅇㅆ가 만든 타로 사이트 고졸이 하루아침에 만드는 정도인데 ㅇㅇ(121.140) 10.30 102 5
2899515 내가 병렬 프로그래밍 때문에 피시방 가야겠다 ㅠ [3] 프갤러(222.97) 10.30 91 0
2899514 대학원 자퇴하고 싸피나 오토에버 임베디드 가는거 어케 생각? [8] 프갤러(117.111) 10.30 131 0
2899513 [두산로보틱스] 로키부트캠프 AI·로봇 엔지니어 양성과정 7기 모집 (~ 프갤러(14.32) 10.30 55 0
2899512 와 ㅋㅋ [5] 에이도비갤로그로 이동합니다. 10.30 107 0
2899511 간혹 희안한 사상을 가진 애들이 있네 [9] 루도그담당(211.184) 10.30 162 0
2899510 흠.. 컨디션 조절이 가장 힘듬 미세조정 [2] ♥벼락부자냥덩♥갤로그로 이동합니다. 10.30 74 0
2899509 자라 ㅇㅅㅇ [1] 헤르 미온느갤로그로 이동합니다. 10.30 52 0
2899508 근데 이재용도 이재명 빨다가 [1] 프갤러(175.212) 10.30 142 0
2899507 이제 우라나라도 핵잠 보유하는거냐? [2] 루도그담당(118.235) 10.30 85 0
2899506 아버지 수술하셔서 스트레스 받는데 아하 까지 날 건드려서 짜증남. 넥도리아2025(14.35) 10.30 45 0
2899505 침대 뭐삼 병원에서 쓰는 침대 에이스는 너무 비싸고, 넥도리아2025(14.35) 10.30 41 0
2899504 또 하나의 원종이가 각성했다기 보다 프갤러(175.208) 10.30 71 0
2899503 공원 ㅇㅅㅇ [1] 헤르 미온느갤로그로 이동합니다. 10.30 53 0
2899501 ㅈ됐다 또 하나의 원종이가 각성했다 프갤러(39.7) 10.30 74 0
2899500 태연 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 10.30 38 0
2899499 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 10.30 54 0
2899497 이런 회사도 있네 ㅇㅇ(106.101) 10.30 57 0
2899496 사실 ㅆㅇㅆ가 지금 행복한 이유도 [1] 프갤러(175.212) 10.30 91 4
2899495 ㅇ하 하지 마라 가비지컬렉터다. 사람 어이가 없어서, 아픈것도 애기 못해 넥도리아2025(14.35) 10.30 41 0
2899493 아베 총격범 오늘 첫 공판…방청객 700명 넘게 줄서 넥도리아2025(14.35) 10.30 44 0
2899491 요미코 알만한 사람은 다 탈갤했겠지? [3] ㅇㅇ갤로그로 이동합니다. 10.30 62 0
2899490 나는조현병이야 나는내향적이야 [1] 손발이시립디다갤로그로 이동합니다. 10.30 75 0
2899488 ㅆㅇㅆ야 행복할 수 있을 때 많이 행복해둬라 [2] ㅇㅇ(51.195) 10.30 110 2
2899479 늘 생각하지만 당장 애니메이션 구현 하나 하는것도 며칠씩 걸리고 ㅆㅇㅆ(124.216) 10.30 59 0
2899464 님들 저 잘건데 응원 부탁드립니다 [5] 공기역학갤로그로 이동합니다. 10.30 66 0
2899460 리눅스 설치하면 기존 파일들 날아감? [1] 프갤러(79.110) 10.30 62 0
2899454 내가 코딩 유튜버를 안믿는 이유 [5] ㅆㅇㅆ(124.216) 10.29 153 1
2899448 이번에 PHP로 된 게시판 마이그레이션 150만에 옴 [16] ㅆㅇㅆ(124.216) 10.29 134 0
2899446 그리고 개발문서만 본다고 전문가 되는거 아니다 [1] ㅇㅇ(106.101) 10.29 95 1
2899445 인생은 왜 이리 매일매일 배울게많고 즐거울까 [2] ㅆㅇㅆ(124.216) 10.29 75 0
2899444 ㅆㅇㅆ야 고생 많았따 ㅇㅇ(124.48) 10.29 107 2
2899442 좆됐다. 우주 팽창속도 감소중. [1] 프갤러(110.8) 10.29 90 0
2899441 법왜곡죄 chironpractor갤로그로 이동합니다. 10.29 50 0
2899440 오늘 2시간 동안 떠들고 4만원 받음. [2] ㅆㅇㅆ(124.216) 10.29 99 0
2899437 지피티 코드 던져주길래 이거 안돌아갈거라니까 뭔 지랄을 하는지 ㅆㅇㅆ(124.216) 10.29 65 0
2899432 갑자기 앱 2개를 다음주 말까지 만들라함. [6] 프갤러(211.234) 10.29 116 0
2899419 금값이 다시 살살 올라가네 chironpractor갤로그로 이동합니다. 10.29 66 0
2899418 웹브라우저 tts 결국 운영체제 따라가는건가 보네 [1] 프갤러(110.8) 10.29 79 0
2899414 추모 강요는 좀 ㅇㅅㅇ [2] 류류(203.229) 10.29 77 0
2899407 무안공항은 왜 추모 안함? [9] chironpractor갤로그로 이동합니다. 10.29 114 0
2899399 오 대박이네. 웹 브라우저에 tts 내장되어 있네 프갤러(27.170) 10.29 47 0
2899389 요새 불법충들 트렌드가 [3] 프갤러(121.185) 10.29 82 1
2899388 예전에 위키 프로젝트인가 그거 만든다던 사람 있던거 같은데 어케 됬음? [4] 프갤러(121.185) 10.29 74 0
2899386 트럼프 "부정선거는 개소리. 이재명은 훌륭한분" 야옹아저씨갤로그로 이동합니다. 10.29 110 0
2899385 마트에서 생굴 사왔음 오늘 저녁은 굴이다 [2] chironpractor갤로그로 이동합니다. 10.29 47 0
2899382 나한테 파이썬 배워두라고 알려줬던 연구실 동료였던 나딤(파키스탄인) ㅆㅇㅆ(124.216) 10.29 82 0
2899381 아버지 수술 끝나서 한 5시간 하셔서... [2] 넥도리아(119.195) 10.29 59 0
2899380 근데 파이썬이 다양성을 포용안하면 그것도 이상한게 ㅆㅇㅆ(124.216) 10.29 57 0
2899379 이번 트럼프정부 파이썬 150만달러 이야기 봤냐 너네? [5] ㅆㅇㅆ(124.216) 10.29 123 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2