디시인사이드 갤러리

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

갤러리 본문 영역

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

ㅆㅇㅆ(124.216) 2025.10.29 01:28:46
조회 344 추천 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/24 - -
이슈 [디시人터뷰] 충무로가 주목하는 신예, '세계의 주인' 서수빈 운영자 25/11/24 - -
AD 대학생 필수템! What's in my Bag 운영자 25/11/21 - -
2900387 쎄엑쓰의 개똥철학에 대한 너의 무관심에 무관심하다. [5] 프갤러(218.154) 11.03 111 1
2900386 ㅆㅇㅆ 쟤는 왜 자꾸 개똥철학을 여따쓰는거냐 ㅇㅇ(118.235) 11.03 102 4
2900385 출근하자마자 잠옴 [3] 루도그담당(211.184) 11.03 115 3
2900384 시들시들한 국화 2.. ㅇㅅㅇ [2] 헤르 미온느갤로그로 이동합니다. 11.03 91 0
2900383 태연 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 11.03 66 0
2900382 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 11.03 80 0
2900381 벡터db도 json도 결국 rdb에 들어갔고 [1] ㅇㅇ(211.186) 11.03 96 0
2900378 GDB 공부하면서 느끼는데 아파치 그래프 엔진 얹어서 [1] ㅆㅇㅆ(124.216) 11.03 104 1
2900377 플랫폼 백엔드를 만들어봐야하나 ㅆㅇㅆ(124.216) 11.03 107 0
2900376 혼자 개발하기 ㅈㄴ 빡세네 [4] 재현갤로그로 이동합니다. 11.03 167 0
2900375 neo4j 과제 해보면서 느낀건데 GDB로 DB 만들어보고 싶은데 [1] ㅆㅇㅆ(124.216) 11.03 99 0
2900372 lg 프갤러(49.165) 11.03 130 0
2900355 인구주택 총조사 ㅈㄴ 수상하네 [2] 야옹아저씨갤로그로 이동합니다. 11.03 171 1
2900349 계절이 비뀐다 [5] 개멍청한유라갤로그로 이동합니다. 11.03 106 0
2900347 요새 학생들 ai 교육 시킨다고 neo4j 쓰던데 [2] ㅆㅇㅆ(124.216) 11.03 181 0
2900346 내 조언하나 하겠습니다 [4] 박민준갤로그로 이동합니다. 11.03 142 0
2900340 하나시테~~ 프갤러(180.80) 11.03 82 0
2900337 뉴프로가 어디임 카드캡터체리갤로그로 이동합니다. 11.03 91 0
2900335 나특허 있는데 돈이 없네 [3] 프갤러(58.77) 11.03 115 0
2900320 다시 생각해보면 순서를 정하는건 의미가 있었다. [1] 프갤러(110.8) 11.03 112 0
2900314 피애로가 보이질 않는다 어딜간거뇨 [2] 카드캡터체리갤로그로 이동합니다. 11.02 102 0
2900308 사실 돈 벌기 귀찮아요 [9] 루도그담당(58.239) 11.02 119 0
2900301 자기 전에 막걸리나 한 잔 해야지 [9] chironpractor갤로그로 이동합니다. 11.02 101 0
2900299 거창하게 작업 순서를 정해놨지만 결국 섞어서 해야하는구나. [1] 프갤러(110.8) 11.02 80 0
2900298 smithery notion mcp연결도움좀.. ㅇㅇ갤로그로 이동합니다. 11.02 94 0
2900289 미래의 어느 역사학자들의 대화라는데 (에필로그) 프갤러(211.210) 11.02 50 0
2900288 미래의 어느 역사학자들의 대화라는데 (요약편) 프갤러(211.210) 11.02 68 0
2900287 미래의 어느 역사학자들의 대화라는데 프갤러(211.210) 11.02 49 0
2900285 별들에게 물어봐 같은 드라마 만들 돈으로 [1] 프갤러(211.210) 11.02 74 1
2900284 청룡영화제 뭐 이런 단어 [1] 프갤러(211.210) 11.02 80 0
2900283 요즘 좌파 화교 특 [1] 프갤러(211.210) 11.02 70 1
2900275 아이폰이 롤리팝을 이긴 것처럼 프갤러(118.235) 11.02 57 0
2900274 화교의 속마음 프갤러(118.235) 11.02 64 0
2900273 알고보니 어렸을 때 치파오 입고 있었고 프갤러(118.235) 11.02 56 1
2900272 기안84 수상한 건 프갤러(118.235) 11.02 93 0
2900271 디시에 글 쓸 때 중국 족보 얼마나 섞여있는지 프갤러(118.235) 11.02 69 0
2900270 부천역 bj들 내쫒는 분위기네 프갤러(118.235) 11.02 67 0
2900269 문쌤 공포라디오 왜이리 무섭냐 [8] 개멍청한유라갤로그로 이동합니다. 11.02 81 0
2900268 사령 [2] chironpractor갤로그로 이동합니다. 11.02 66 0
2900263 러스트 인생 40 년 갈아 넣었습니다. [1] 프갤러(59.16) 11.02 91 0
2900245 헬조선 입에 달고 사는 애들 [9] 루도그담당(58.239) 11.02 111 0
2900242 문경십자가 살인사건 [4] 개멍청한유라갤로그로 이동합니다. 11.02 175 0
2900229 그레셤의 법칙이 더닝크루거에 선행한다 [2] chironpractor갤로그로 이동합니다. 11.02 105 0
2900228 정적 웹 사이트 생성기 검토해봤는데 [4] 프갤러(110.8) 11.02 105 0
2900227 문화에 힘을 왜 쓰냐 다 구란데 프갤러(211.210) 11.02 77 0
2900226 부천역 bj들 내쫒는 분위기네 프갤러(211.210) 11.02 75 0
2900225 김창욱 김제동 김이나 같은 프갤러(211.210) 11.02 68 0
2900210 [애니뉴스] 선행컷! 이 멋진 세계에 폭염을! 프갤러(121.172) 11.02 50 0
2900207 내가 웹 서비스를 굳이 러스트로 만드는 이유 [6] 프갤러(110.8) 11.02 161 0
2900206 임베디드가 진짜 편한 게 뭐냐면 [16] 에이도비갤로그로 이동합니다. 11.02 203 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2