디시인사이드 갤러리

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

갤러리 본문 영역

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

ㅆㅇㅆ(124.216) 2025.10.29 01:28:46
조회 307 추천 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/10 - -
AD 겨울가전 SALE! 쿨한 겨울 HOT세일 운영자 25/11/12 - -
2901137 어제 지옥철이지 않았니 출퇴근 시간. 넥도리아(14.35) 11.08 87 0
2901135 근데 학교에서 하는거랑 실무랑은 좀 다르게 봐야해 이유가 뭐냐면 ㅆㅇㅆ(124.216) 11.08 89 6
2901132 교수가 자바 스윙하라고 한건 그냥 렌더러 때문일껄 [5] ㅆㅇㅆ(124.216) 11.08 166 5
2901131 자바 스윙을 교수가 너무 좋아함 [17] 프갤러(182.222) 11.08 169 1
2901130 AI가 만든 빌런 갤러 누가 있을까 [2] ㅇㅇ갤로그로 이동합니다. 11.08 109 0
2901128 국민의힘과 일기토 해서, 매일 1달에 1번 꼴로 차단당합니다. 넥도리아(14.35) 11.07 72 0
2901127 우스이 이제 조롱을 즐기는 경지에 이른듯 [1] 헬마스터갤로그로 이동합니다. 11.07 106 1
2901126 음기 충전 [3] 발명도둑잡기(118.216) 11.07 126 0
2901125 누가 나한테 20~30만짜리 의뢰좀 줬음 좋겠어 ㅆㅇㅆ(124.216) 11.07 90 5
2901124 위시캣 아니면 비싼돈을 받기가 힘든듯. 근데 위시캣은 경력위주라 ㅆㅇㅆ(124.216) 11.07 99 5
2901122 매번 학생들 앞에서 직접 차례대로 구현하기 차력쇼하니까 체력이 안남노 ㅆㅇㅆ(124.216) 11.07 93 5
2901121 사람 ㅈㄴ 많아 [8] 따당갤로그로 이동합니다. 11.07 131 0
2901120 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ [2] ♥KiTTY냥덩♥갤로그로 이동합니다. 11.07 106 0
2901119 나무 위키 링크했더니만 ㅋㅋ 글삭되었넬 나르시갤로그로 이동합니다. 11.07 66 0
2901118 헿헿 러빠돌이 나만 나오면 빤스런이지 ㅋㅋ 나르시갤로그로 이동합니다. 11.07 63 0
2901115 어머니 휴대폰 irecovery랑 빈곤 퇴치 앱이 깔려있다. [1] 넥도리아(119.195) 11.07 89 0
2901112 지금 학생이 웹툰작가인데 이 학생 그림으로 겜만들고싶어 [1] ㅆㅇㅆ(124.216) 11.07 115 5
2901111 요즘 억까가 심해서 갤에서 난동이나 부릴까 싶지만 [2] 프갤러(110.8) 11.07 88 0
2901109 애널은 모기 없길.. [3] ♥KiTTY냥덩♥갤로그로 이동합니다. 11.07 93 0
2901108 [1인`1개] 배달의 민족 30,000 원 짜리 쓸 사람 써 ! [1] ㅇㅇ(223.39) 11.07 76 0
2901107 살다살다 보석새끼가 제정신이란 말은 처음듣네 [2] 프갤러(110.8) 11.07 105 1
2901106 나르시 동네 친근한 아저시 같았는데 [2] 에이도비갤로그로 이동합니다. 11.07 121 0
2901105 씨발 존나 힘들어 그냥 [2] ㅆㅇㅆ(124.216) 11.07 135 6
2901104 내가 원하던거 성공했다 [4] 루도그담당(58.239) 11.07 92 0
2901102 러빨러 증세가 1년전보다 심해졌어 [16] 나르시갤로그로 이동합니다. 11.07 126 0
2901101 이 사람이 받아들이는 정보가 결국 지 지능의 한계를 못벗어난다. [5] 프갤러(223.53) 11.07 102 0
2901100 나님 청력테스트 하니까 10대 후반 나옴 ㅇㅅㅇ [1] ♥KiTTY냥덩♥갤로그로 이동합니다. 11.07 84 0
2901098 한국 프로그래머 기술 공유 ㅋㅋㅋㅋ [3] 프갤러(223.63) 11.07 136 0
2901096 내가 맨날 러스트 개쩐다 알려줘도 받아먹질 못하잖아 [6] 프갤러(223.63) 11.07 104 0
2901095 세상사는게 배구공(119.202) 11.07 75 0
2901086 프로그래밍 독학입문 해봐도 괜찮을까요.. [1] 프갤러(117.111) 11.07 75 0
2901085 배구공 = 넥도리아냐 [1] ㅇㅇ(118.235) 11.07 106 0
2901082 ㅆㅇㅆ한테 해주고 싶은말 [2] ㅇㅇ(118.235) 11.07 148 5
2901079 프갤에 고수들이 모이려면 [9] 배구공(119.202) 11.07 107 0
2901077 베네수엘라 사례를 보면 나같은 좌파라도 1찍을 할 수 없는 이유가 나온다 chironpractor갤로그로 이동합니다. 11.07 86 0
2901076 오늘은 저녁도 햄버거네 [3] 프갤러(112.169) 11.07 87 0
2901075 내 얘기 ㅋㅋ) 진정한 개발자의 행보 ㅋㅋ [12] 나르시갤로그로 이동합니다. 11.07 139 0
2901071 시발 세상이 내게 너무 많은 역할을 요구하네 [3] 프갤러(27.172) 11.07 104 0
2901069 러빨러 보면 자기 작품도 없고 전문성도 없어 ㅎㅎ [1] 나르시갤로그로 이동합니다. 11.07 81 0
2901068 솔직히 지금 하고 있는일들 다 제값 받았으면 월급 400쯤됐을텐데 ㅆㅇㅆ(124.216) 11.07 103 5
2901065 산뽀해야겠군 [6] ㅇㅇ(122.199) 11.07 96 0
2901064 근데 러빨럼들 고졸에 국비 출신들인가.. [8] 나르시갤로그로 이동합니다. 11.07 100 0
2901063 오늘은 뉴 아키텍쳐를 guiyom에 적용해야지 ㅋㅋ [1] 나르시갤로그로 이동합니다. 11.07 60 0
2901062 오늘은 집에서 진정한 프로그래밍을 할 수 있겠군. [4] 프갤러(218.154) 11.07 114 0
2901061 고졸 지잡 폐급이 연세대욕하고 있노 ㅋㅋ [4] ㅇㅇ(118.235) 11.07 120 6
2901060 한달 뒤 넥도리아(112.156) 11.07 60 0
2901058 강인공지능 좋아하지 말라. 님의 적이다. [6] 나르시갤로그로 이동합니다. 11.07 101 0
2901057 회사에서 1시간 놀다오는 사람들 많지? [2] ㅇㅇ(211.234) 11.07 91 0
2901056 AGI는 나르시시스트 AI로 결국은 변질되기 마련이다 나르시갤로그로 이동합니다. 11.07 55 0
2901055 AGI가 '인류에게 해악으로 작용'할 수 있는 근거 나르시갤로그로 이동합니다. 11.07 60 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2