디시인사이드 갤러리

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

갤러리 본문 영역

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

ㅆㅇㅆ(124.216) 2025.10.29 01:28:46
조회 283 추천 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 - -
2900913 길건 - Real 발명도둑잡기(118.216) 11.06 32 0
2900912 어떤 사용자가 여러 갤러리에서 공격 받은 이유는 [7] 발명도둑잡기(118.216) 11.06 88 0
2900905 인스타그램 추천 뜬 1호선 풍선껌 할머니 발명도둑잡기(118.216) 11.06 41 0
2900904 <언포게터블 듀엣> 한대서 생각나는 예전 글 발명도둑잡기(118.216) 11.06 40 0
2900903 나도 오늘 여자랑 일하다 문제 생김 [9] 에이도비갤로그로 이동합니다. 11.06 106 0
2900902 나님 그라파나 고수가되.. [2] 따당갤로그로 이동합니다. 11.06 76 0
2900901 여자들이랑 일하면 항상 문제 생기네 [1] 프갤러(121.184) 11.06 87 2
2900900 제가 주로 사용하는 특별한 기술은 배구공(119.202) 11.06 46 1
2900899 에헴.. 나는 세계최초, 국내최초 기술 보유자임 ㅋㅋ [6] 나르시갤로그로 이동합니다. 11.06 78 0
2900898 2026년에 특허 출원 예정 ㅋㅋ [4] 나르시갤로그로 이동합니다. 11.06 88 0
2900897 ㅆㅇㅆ장애인 또 나대네 [1] ㅇㅇ(118.235) 11.06 91 7
2900896 일본은 군대 풀어서 곰 잡는다는데 chironpractor갤로그로 이동합니다. 11.06 49 0
2900895 배경사진 선물받음 ㅇㅅㅇ [2] 따당갤로그로 이동합니다. 11.06 86 0
2900894 삼성청년SW·AI아카데미 SSAFY 15기 모집 (~11/10) 프갤러(14.32) 11.06 152 0
2900893 러스트 진짜 지겹다 ㅅㅂ [6] 프갤러(218.154) 11.06 142 1
2900892 자러감 ㅇㅅㅇ [1] ㅇㅅㅇ(121.157) 11.06 53 0
2900891 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ [2] ♥KiTTY냥덩♥갤로그로 이동합니다. 11.06 72 0
2900890 나도 적당한 시골이 좋더라 [7] 류도그담당(211.184) 11.06 82 0
2900889 우리집도 시골임 [8] 배구공(119.202) 11.06 96 0
2900888 흔한 시골 동네..ㅇㅅㅇ [6] 헤르 미온느갤로그로 이동합니다. 11.06 87 0
2900887 태연 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 11.06 32 0
2900886 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 11.06 56 0
2900885 나님 건강끙야 완⭐+ ♥KiTTY냥덩♥갤로그로 이동합니다. 11.06 54 0
2900884 냥덩헬스⭐+ ♥KiTTY냥덩♥갤로그로 이동합니다. 11.06 66 0
2900883 나님 건강루틴 책으로 내볼강? [1] ♥KiTTY냥덩♥갤로그로 이동합니다. 11.06 68 0
2900882 질 좋은 끙야를 잘하려면 ♥KiTTY냥덩♥갤로그로 이동합니다. 11.06 53 0
2900881 나님 모닝끙야 루틴 ♥KiTTY냥덩♥갤로그로 이동합니다. 11.06 52 0
2900880 날씨 좋당 ☘+ ♥KiTTY냥덩♥갤로그로 이동합니다. 11.06 52 0
2900879 나님 꿀잠비법 하나 찾은듓?!? ♥KiTTY냥덩♥갤로그로 이동합니다. 11.06 53 0
2900878 류류 옵빠~ 달려엇~! ⭐ ♥KiTTY냥덩♥갤로그로 이동합니다. 11.06 52 0
2900877 나님 애널 아침에 일어나자마자 모기봄;; ♥KiTTY냥덩♥갤로그로 이동합니다. 11.06 35 0
2900876 하 씨발 연구 용역으로 들어갈 줄 알았는데 학위때문에 자문으로 격하됐네 [5] ㅆㅇㅆ(124.216) 11.06 103 0
2900875 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ ♥KiTTY냥덩♥갤로그로 이동합니다. 11.06 56 0
2900874 구현 끝 잘 준비해야긋다 ㅆㅇㅆ(124.216) 11.06 53 0
2900873 근데 다중 아이피 점마는 안 지치냐. [1] ㅆㅇㅆ(124.216) 11.06 71 0
2900872 ㅆㅇㅆ 저분은 요즘시대에 보기힘든 네임드라 볼수있을듯 [3] ㅇㅇ(58.233) 11.06 127 3
2900871 현실적으로 말하자면 한국 대학원에서 AI크리에이터는 적다. [1] ㅆㅇㅆ(124.216) 11.06 70 0
2900870 내 주요 매출 중 하나가 석사-박사 처음 진입할때 논문 연구할때 [1] ㅆㅇㅆ(124.216) 11.06 79 0
2900869 대한민국 24년 IT 직군 평균 신규 취업 연령이 26.7세임 ㅆㅇㅆ(124.216) 11.06 96 0
2900865 현실적으로 23살 컴공 공기업 vs 대학원 팩트 부탁드립니다. [14] ㅇㅇ갤로그로 이동합니다. 11.06 172 0
2900854 과학이 밝혀낸 음주 문화의 기원 | #지식채널e 발명도둑잡기(211.246) 11.06 61 0
2900853 점마 아이피 바꾸면서 따라다니는거 좀 이해가 안가는것도 안가는건데 ㅆㅇㅆ(124.216) 11.06 56 0
2900852 "빚투, 나쁘지 않아" 금융위 부위원장 발언 하루 만에…주가 급락 발명도둑잡기(211.246) 11.06 66 0
2900851 진짜 노예로 살면 저렇게 대가리가 돌아버리는구나 [1] ㅆㅇㅆ(124.216) 11.06 74 0
2900849 Z세대·무슬림·사회주의자 뉴욕 시장, 맘다니 당선…'反트럼프' 발명도둑잡기(211.246) 11.06 60 0
2900848 쌀먹도 요건만 따지면 취직때보다 더 버니까 범재 아님? ㅆㅇㅆ(124.216) 11.06 57 0
2900846 "맘다니 승리 요인은 Z세대의 외로움" 발명도둑잡기(211.246) 11.06 48 0
2900845 방금 레전드 좆같은 일 겪음 [3] ㅇㅇ갤로그로 이동합니다. 11.06 94 0
2900844 범재가 취직이면 나 범재 맞네. [23] ㅆㅇㅆ(124.216) 11.06 140 0
2900843 ㅆㅇㅆ가 범재면 취직했겠지 ㅇㅇ(211.36) 11.06 59 1
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2