디시인사이드 갤러리

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

갤러리 본문 영역

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

ㅆㅇㅆ(124.216) 2025.10.29 01:28:46
조회 349 추천 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 - -
AD 따뜻한 겨울나기! 방한용품 SALE 운영자 25/11/27 - -
2901604 점마는 내가 저것만 하는줄 아는건가 ㅆㅇㅆ찡갤로그로 이동합니다. 11.09 193 7
2901603 여자들도 디시를 함? [10] 류도그담당(58.239) 11.09 141 0
2901601 악감정은 없는데 이걸로 ㅆㅇㅆ 수익을 유추할 수 있음. [4] ㅇㅇ(124.48) 11.09 179 5
2901600 나님은 남에게 관심이 없어도 남들은 냥덩이에게 관심이 많다는걸 ♥KiTTY냥덩♥갤로그로 이동합니다. 11.09 61 0
2901599 아 저 정병유동 누군지 알겠네. 저 뚱녀 조현병 [8] ㅆㅇㅆ찡갤로그로 이동합니다. 11.09 269 6
2901598 더닝 크루거 < 이 말 [2] 류도그담당(58.239) 11.09 105 0
2901595 방금 키오스크에서 윈도우 정품인증 워터마크를 봤다. [3] 프갤러(58.227) 11.09 129 0
2901594 ㅆㅇㅆ 정신병심하노 프갤러(106.101) 11.09 130 6
2901592 "한국이 독도 불법 점거" 日시마네현 "다케시마의 날 각료 참석 요청" 발명도둑잡기(118.216) 11.09 72 0
2901591 저새끼 더닝크루거 맞다니까 ㅋㅋ ㅇㅇ(118.235) 11.09 113 3
2901590 아스퍼거 더닝크루거 ㅆㅇㅆ 개쳐맞네 또 ㅋㅋ ㅇㅇ(118.235) 11.09 116 6
2901589 나님 나무위키에 박제된갤만 최소 5곳 이상이네;; [4] ♥KiTTY냥덩♥갤로그로 이동합니다. 11.09 109 2
2901588 열등감에 ㅆㅇㅆ 괴롭히는거지 저 슼통피는 [4] 프갤러(219.250) 11.09 152 0
2901587 박지현은 녹즙 배달, 류호정은 목수…여의도 떠난 청년 정치인들, 지금은 발명도둑잡기(118.216) 11.09 90 0
2901585 난 저 정병 이해가 안가는게 왜 특정마갤에 [5] ㅆㅇㅆ찡갤로그로 이동합니다. 11.09 214 6
2901584 나님 왤캐 순수할깡..? [2] ♥KiTTY냥덩♥갤로그로 이동합니다. 11.09 90 0
2901583 다들 일요일 주말인데 [7] 루도그담당(58.239) 11.09 118 0
2901581 ㅆㅇㅆ 백엔드 갤에서 쳐맞으니까 셀프신고삭함 [1] ㅇㅇ(211.234) 11.09 151 7
2901579 ㅆㅇㅆ야 셀프신고삭 자작극좀 적당히해라 [1] ㅇㅇ(211.234) 11.09 112 5
2901578 다중이 정병은 1년넘게 저지랄이고. [1] ㅆㅇㅆ(124.216) 11.09 145 7
2901577 요새 이야기하면서 느끼는게 그냥 누구랑 이야기하는거보다 [9] ㅆㅇㅆ(124.216) 11.09 234 5
2901576 온라인서 확산된 충격 영상…日 '좀비 담배' 비상 발명도둑잡기(118.216) 11.09 113 0
2901575 아무래도 외주가 기본 베이스다보니 현업이랑 이야기할 경우 많은데 [1] ㅆㅇㅆ(124.216) 11.09 167 6
2901571 헤어디자이너 하다가 전향했는데 [5] 프갤러(211.235) 11.09 130 2
2901569 일이 비싼건 없고 싼것만있노 [2] ㅆㅇㅆ찡갤로그로 이동합니다. 11.09 222 7
2901568 멕시코 정부군 남미 마약 카르텔 아파치 공습 영상 배구공(121.151) 11.09 94 0
2901565 할배는 레딧으로 빤스런하기로 했다 ㅋㅋ [3] 나르시갤로그로 이동합니다. 11.09 116 0
2901564 미소녀 연애 시뮬레이션 게임 만들기 - 개요 [1] 프갤러(121.172) 11.09 70 0
2901563 자바는 스스로 좇같은점들을 고칠 생각이 전혀없음 개좇센이랑팜박이임 [2] 타이밍뒷.통수한방(1.213) 11.09 92 0
2901562 한국애니 연의 편지 예고편 배구공(121.151) 11.09 112 0
2901561 이번에 11번가 젠북 129 탑승했는데 램 24기가 ㄱㅊ?? [6] 프갤러(182.216) 11.09 96 0
2901560 중국애니중에 쩌는게 있었는데 [1] 배구공(121.151) 11.09 96 0
2901559 초파리들을 보며 생명의 신비를 느낀다 chironpractor갤로그로 이동합니다. 11.09 78 0
2901558 천공의 에스카플로네 일본판 오프닝 배구공(121.151) 11.09 77 0
2901555 지금 구글에 카ㅌ 검색하면 프갤러(175.212) 11.09 78 0
2901554 Ufo 소리인줄 알앗는데 전기차소리엿넹 [4] ♥KiTTY냥덩♥갤로그로 이동합니다. 11.09 121 0
2901553 프갤에 제2의 원종이 한명 보인다. ㅎㅎ [3] 나르시갤로그로 이동합니다. 11.09 129 0
2901550 올해를 성공적으로 마무리할 계획을 세웠음 [5] 공기역학갤로그로 이동합니다. 11.09 89 0
2901549 구글 플레이 비공개 테스트 대행 최저가 BETAFLOW갤로그로 이동합니다. 11.09 64 1
2901548 프플 5일 결제했는데 언제쯤옴? ㅁㅁ(112.170) 11.09 80 0
2901546 근데 디씨 데탑 크롬에서 알림 설정한거 윈도에 알림 배너 뜸? [2] chironpractor갤로그로 이동합니다. 11.09 82 0
2901545 나님 커피 때리고 갑자기 의욕이 솟구치심 [3] 헬마스터갤로그로 이동합니다. 11.09 102 0
2901544 [대한민국] 단어및어휘 개요 - 가짜뉴스란? 프갤러(121.172) 11.09 75 0
2901543 한국은 좆망할게 뻔하니까 이제 디시 뿐 아니라 레딧도 해야겠군 [1] 프갤러(211.234) 11.09 108 0
2901542 일단 한국 소프트웨어는 끝임 [6] 프갤러(211.234) 11.09 146 1
2901541 보수진영이 현정권에게 배워야 할 점 chironpractor갤로그로 이동합니다. 11.09 112 1
2901540 윤두창 사형 기원 웹사이트 제작 문의 [1] 프갤러(220.122) 11.09 103 0
2901539 약먹고 자야지.. ㅇㅅㅇ [2] 헤르 미온느갤로그로 이동합니다. 11.09 105 0
2901538 Carrie Fisher in Blues Brothers (1980) 배구공(121.151) 11.09 60 0
2901537 나는 할 거 없으면 프로그래밍 주제로 맨날 제미나이랑 키배뜨는데 [1] ㅆㅇㅆ(124.216) 11.09 299 6
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2