디시인사이드 갤러리

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

갤러리 본문 영역

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

ㅆㅇㅆ(124.216) 2025.10.29 01:28:46
조회 255 추천 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
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 영포티룩도 멋지게 소화할 것 같은 40대 스타는? 운영자 25/10/27 - -
AD 저녁 뭐먹지? 오늘의 메뉴 추천! 운영자 25/10/31 - -
공지 프로그래밍 갤러리 이용 안내 [97] 운영자 20.09.28 48394 65
2899946 '19' 젖제로투 추는 BJ.gif 프갤러(121.129) 20:49 1 0
2899945 글삭튀 하는거 걸리면 쪽팔리니까 셀프신고 주작기로 알바삭 ㅋㅋ [1] ㅇㅇ(140.248) 20:39 14 2
2899943 ㅆㅇㅅ 롤갤도하노 프갤러(223.38) 20:19 22 0
2899942 버거킹을 포기하고 집에 일찍 와서 라면 끓이고 있다. [1] 프갤러(110.8) 20:15 12 0
2899941 삼성 반도체 공장 때문에 전국에 발전소를 많이 지어야 한다더라 발명도둑잡기(118.216) 20:12 11 1
2899940 냥덩이랑 메이플 하실분? 파티 구함 [2] ♥KiTTY냥덩♥갤로그로 이동합니다. 20:07 16 0
2899939 자바로 갈아타는 이유 [2] 발명도둑잡기(118.235) 20:03 23 0
2899937 vscode extension 하나 개발햇어 [1] 규규(210.100) 19:56 21 0
2899936 뭔 프로그래밍이냐 ㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋ ㅇㅇ(160.238) 19:53 17 0
2899935 나는 파이썬 빠는 것들은 이해가 안가. [12] 프갤러(211.234) 19:47 49 0
2899934 [애니뉴스] Research 항목 추가 프갤러(121.172) 19:47 60 0
2899933 검색해보니까 파이썬은 장고, FASTAPI, 플라스크 3개인데 [5] 발명도둑잡기(118.216) 19:40 31 0
2899932 내가 관심있는 여성들 잘 지내고 있겠지? 발명도둑잡기(118.216) 19:36 8 0
2899931 웹프레임워크 벤치마크 순위권 라이브러리 낯설다 [2] 발명도둑잡기(118.216) 19:34 17 0
2899930 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ [2] ♥KiTTY냥덩♥갤로그로 이동합니다. 19:30 22 0
2899929 아 버거킹 못먹는다 ㅅㅂ [3] 프갤러(223.56) 19:21 25 0
2899928 중국은 미국이 그리는 AI와 완전히 다른 길을 가고 있다 발명도둑잡기(118.216) 19:18 11 0
2899926 저녁 버거킹 먹어야겠다. 프갤러(223.56) 19:17 12 0
2899924 Zior Park - KEEP OUT! 발명도둑잡기(118.216) 19:09 9 0
2899922 INJI - TEEN ANGST 발명도둑잡기(118.216) 19:07 7 0
2899920 진돗개 · 세종대왕... 전설의 컴퓨터 전당, 세진컴퓨터랜드 발명도둑잡기(118.216) 18:43 10 0
2899918 스테이블코인의 달러 패권 수호론이 낙관적이지 않은 이유 발명도둑잡기(118.216) 18:33 13 0
2899917 약속시간에 늘 늦어서 욕 먹는 사람…‘이런 성격’ 소유자 많다? 발명도둑잡기(118.216) 18:32 15 0
2899916 아하 저격 글 유튜브 신고 사유 증명하면 다들 오실 수 있음 유튜브?12 넥도리아2025(14.35) 18:30 13 0
2899914 파이썬 재단 = DEI 지지하는 PC주의 단체 [1] 프갤러(103.137) 18:17 19 0
2899910 크몽 개발자 출신 좆밥새끼 [1] 프갤러(118.235) 17:54 53 0
2899908 개발자 6년차면 연봉얼마정도되냐? 프갤러(223.38) 17:48 29 0
2899906 요새 ai 답변 많이 발전한듯 ㅇㅇ(110.70) 17:43 30 0
2899905 납땜용 AD210 10인치 현미경 샀다 발명도둑잡기(118.216) 17:43 16 0
2899904 클라라, '80억 시그니엘' 떠났다…의미심장 심경 고백 발명도둑잡기(118.216) 17:42 21 0
2899902 냥덩이가 날씨 좋다고 하니까 비 오네 [1] 발명도둑잡기(118.235) 17:38 34 0
2899894 [대한민국] 정치는 백해무익. 닭이 먼저나 달걀이 먼저냐 프갤러(121.172) 16:26 18 0
2899887 가끔 그런 생각이 든다. 누군가 내 인장을 사칭하여 똥글을 쓴다면? 프갤러(121.130) 15:17 37 0
2899886 저번에 버스 도착 알림 만들면서 웹 푸시는 구현해둠 프갤러(27.167) 14:59 40 0
2899885 가야할 길은 먼데 시간이 너무 없군. 프갤러(27.167) 14:45 38 0
2899884 시작을 ai 개발자로 한건 잘한 선택같다 [2] 프갤러(211.234) 14:40 67 0
2899883 러스트로 메신저 서비스 만들고있다. [6] 프갤러(110.8) 14:24 66 0
2899881 그대는 어떻게 살것인가 [10] 공기역학갤로그로 이동합니다. 14:22 103 0
2899877 <세계의 주인> 영화 있대서 생각나는 몇년 전 글 발명도둑잡기(118.216) 14:18 26 0
2899876 진짜 갤질 좀 해라!!!! [9] 에이도비갤로그로 이동합니다. 14:02 66 0
2899873 오늘 돈까스먹고 만화책보다 집 갈 예정 [7] ㅆㅇㅆ찡갤로그로 이동합니다. 13:53 64 0
2899868 날씨 좋당 ☘+ [1] ♥KiTTY냥덩♥갤로그로 이동합니다. 11:56 54 0
2899865 [박진영의 사회심리학] 지혜는 겸손에서 비롯된다 발명도둑잡기(118.216) 10:41 27 0
2899864 결국 인문학이다 [5] chironpractor갤로그로 이동합니다. 10:35 73 0
2899863 병원 7층에서 바라본 장면 [3] 넥도리아(223.38) 10:03 98 0
2899862 ddia 멧돼지책이 프갤러(211.186) 10:02 27 0
2899861 치즈냥이 친화성 좋은듯 [2] ♥KiTTY냥덩♥갤로그로 이동합니다. 09:57 61 0
2899859 ㅇㄷ [7] 프갤러(211.234) 09:24 71 0
2899858 모두가 냥덩이 한번 만져보겠다고 ㅋㅅㅋ [4] ♥KiTTY냥덩♥갤로그로 이동합니다. 08:51 92 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2