디시인사이드 갤러리

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

갤러리 본문 영역

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

ㅆㅇㅆ(124.216) 2025.10.29 01:28:46
조회 273 추천 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 - -
2900848 쌀먹도 요건만 따지면 취직때보다 더 버니까 범재 아님? ㅆㅇㅆ(124.216) 00:59 34 0
2900846 "맘다니 승리 요인은 Z세대의 외로움" 발명도둑잡기(211.246) 00:52 31 0
2900845 방금 레전드 좆같은 일 겪음 [3] ㅇㅇ갤로그로 이동합니다. 00:50 74 0
2900844 범재가 취직이면 나 범재 맞네. [23] ㅆㅇㅆ(124.216) 00:46 121 0
2900843 ㅆㅇㅆ가 범재면 취직했겠지 ㅇㅇ(211.36) 00:37 42 1
2900842 신분 세습 [1] 발명도둑잡기(211.246) 00:37 78 0
2900841 api를 통한 초대코드 추가까지 완성해버렸다. [1] 프갤러(110.8) 00:28 41 0
2900840 새벽배송 토론 유감 발명도둑잡기(211.246) 00:25 25 0
2900839 절대 권력은 절대 부패한다 [1] 발명도둑잡기(211.246) 00:21 35 0
2900838 냥덩이 썰기 발명도둑잡기(118.235) 00:14 27 0
2900837 산뽀 마렵네 [1] ㅇㅇ(122.199) 00:02 38 0
2900836 호놀룰루~ ♥KiTTY냥덩♥갤로그로 이동합니다. 11.05 20 0
2900835 나님 감을 따르자면 눈빛이 왠지 섬찟함.. ♥KiTTY냥덩♥갤로그로 이동합니다. 11.05 62 0
2900834 세면대 손잡이 부러진지 2년정도... 어쩌냐 분해해볼려고 넥도리아(119.195) 11.05 20 0
2900833 텐션있게! ♥KiTTY냥덩♥갤로그로 이동합니다. 11.05 60 0
2900832 아이피를 조작도 가능함? [4] 샤프로채점함갤로그로 이동합니다. 11.05 63 0
2900830 오늘은 bearer token 헤더 처리를 추가했다. 프갤러(110.8) 11.05 30 0
2900829 왜 자꾸 냥덩이 보고 여자냐고 묻는것임? [2] ♥KiTTY냥덩♥갤로그로 이동합니다. 11.05 50 0
2900828 냥덩이 마음이 따뚯해졋오..☀+ [1] ♥KiTTY냥덩♥갤로그로 이동합니다. 11.05 41 0
2900827 ㅋㅅㅋ [1] ♥KiTTY냥덩♥갤로그로 이동합니다. 11.05 32 0
2900824 두트윈으로 일관성 있게 [2] 루도그담당(58.239) 11.05 44 0
2900822 if else를 안쓰기 위해서 getattr 쓴다는건 대체 뭔소리지 ㅆㅇㅆ(124.216) 11.05 42 0
2900821 하긴 나같은 특급 러스트 프로그래머도 좀 헤메는데 확률형 문장생성기가 프갤러(110.8) 11.05 35 0
2900820 그냥 빨리 영하로 떨어졋으면.. ♥KiTTY냥덩♥갤로그로 이동합니다. 11.05 50 0
2900817 창문 열어놓고 모기약 뿌렷는데 왜앵거린 ㅅㅂ ♥KiTTY냥덩♥갤로그로 이동합니다. 11.05 49 0
2900816 씨발 모기새끼 존나 쌔니 ♥KiTTY냥덩♥갤로그로 이동합니다. 11.05 49 0
2900815 나님 씻엇어양⭐+ ♥KiTTY냥덩♥갤로그로 이동합니다. 11.05 42 0
2900814 제미나이 cli써봤는데 아주 속 터져 죽겠구나. 프갤러(110.8) 11.05 41 0
2900812 이론 개씨팔 모기 또 있네 ♥KiTTY냥덩♥갤로그로 이동합니다. 11.05 55 0
2900809 두트윈으로 이동 변화량 로직 만드는 중인데 [4] 루도그담당(58.239) 11.05 57 0
2900807 님들 실갤에 올라온거 봄? [7] ㅇㅇ(118.235) 11.05 111 4
2900804 헬마스터님 자꾸 이런식으로 비협조적으로 나온다면 저도 당신의 뉴프로에 [5] ㅆㅇㅆ(124.216) 11.05 85 0
2900802 원래 슈퍼스타는 빠와 까를 미치게 만듬. 근데 까가 존재한다? [3] ㅆㅇㅆ(124.216) 11.05 74 0
2900801 프로그래머는 원래 범재가 폐급 같아 보여 [2] 프갤러(110.8) 11.05 70 0
2900800 배 안고파서 저녁 안 먹구What더니 애매하넹.. [5] ♥KiTTY냥덩♥갤로그로 이동합니다. 11.05 77 0
2900790 범재가 아니라 폐급이잖냐 [1] ㅇㅇ(118.235) 11.05 53 2
2900784 아무래도 피곤해서 안되겠다. 바이브 해버려야겠다. [1] 프갤러(27.176) 11.05 55 0
2900783 🎬 [글로벌 AI Creator Challenge : 상금 $5000 Supercent(14.32) 11.05 41 0
2900782 프로그래밍은 천재는 많은데 나같은 범재도 할 수 있는 영역이 넓어서 좋아 ㅆㅇㅆ(124.216) 11.05 55 0
2900781 최근 업워크 330달러 의뢰 하나때문에 밤낮이 바꼈는데 ㅆㅇㅆ(124.216) 11.05 42 0
2900780 러스트 빌런이 많다고 한번 해볼까 혹하다니 한심하구나 [3] 프갤러(223.38) 11.05 71 0
2900778 요새 의식적으로 코드 3할 이상은 무조건 타이핑으로 하려고 함 [2] ㅆㅇㅆ(124.216) 11.05 68 0
2900777 많이드세요. [1] 배구공(121.151) 11.05 48 0
2900776 나는 베트남 개발자가 한국 개발 대체가 힘들다 느끼는게 문화권 문제임 [3] ㅆㅇㅆ(124.216) 11.05 101 0
2900775 러스트 빌런 우스이로 개명함 [2] 헬마스터갤로그로 이동합니다. 11.05 60 0
2900774 나님 요즘 뿡야 우렁차게 잘 나오는듯? [4] ♥KiTTY냥덩♥갤로그로 이동합니다. 11.05 59 0
2900773 프로그래밍은 암달의 법칙 즉 시스템 전체의 성능은 ㅆㅇㅆ(124.216) 11.05 45 0
2900772 러스트로 웹할때 어차피 마샬링 비용때문에 핵심만 바꿈 [12] ㅆㅇㅆ(124.216) 11.05 85 0
2900771 이제보니 러스트 빌런이 하나가 아니었네 [6] 에이도비갤로그로 이동합니다. 11.05 84 0
2900770 한국 최초의 컴퓨터관련 서적 베스트셀러 [1] 배구공(121.151) 11.05 68 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2