디시인사이드 갤러리

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

갤러리 본문 영역

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

ㅆㅇㅆ(124.216) 2025.10.29 01:28:46
조회 277 추천 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 - -
2899739 내가 참여중인 사프가 6,000팀중에 30팀안에 들었음 [1] 따당갤로그로 이동합니다. 10.31 98 0
2899736 국민의힘 갤러리 내란 십새가 맨날 30일마다 댓글 쓰지도 않았는데 차단네 [1] 넥도리아2025(14.35) 10.31 71 0
2899735 ㅆㅇㅆ장애인새끼 또 소설 쓰고 있네 ㅇㅇ(118.235) 10.31 84 2
2899734 오늘 이전에 프갤서 연락줬던 학생 연락와서 인사하니 기분좋노 ㅋㅋ [7] ㅆㅇㅆ(124.216) 10.31 120 0
2899733 빡칠땐 산책을 한다 [7] chironpractor갤로그로 이동합니다. 10.31 91 0
2899730 내향적인간이.. 우울증이나 조현병 잘 걸린다고 누가 그러던데..ㅇㅅㅇ [2] 헤르 미온느갤로그로 이동합니다. 10.31 67 0
2899729 최미니 사퇴해. 넥도리아2025(14.35) 10.31 53 0
2899712 옛날 자본금 몇천으로 인력업체세우는게 [15] 배구공(119.202) 10.31 114 0
2899708 나는조현병이야 나는내향적이야 손발이시립디다갤로그로 이동합니다. 10.31 64 0
2899707 si가면 거 자바나 씨샵한다던데 [2] 배구공(119.202) 10.31 102 0
2899705 천재 [2] 배구공(119.202) 10.31 84 1
2899704 뭐지 예전에 자바 공부 좀 했다가 수년간 안써서 [3] 프갤러(125.131) 10.31 94 0
2899701 너가 재능이니 천재 인 척이니 이거 언급하는 이유가 뭐겠냐 [5] ㅆㅇㅆ(124.216) 10.31 106 0
2899700 천재같은거에 집착하지마. 천재 아니라도 러스트 할 수 있어 [3] 프갤러(218.154) 10.31 88 0
2899699 냥덩아 나는 내가 천재라 한적 없는데 너가 자꾸 천재 재능 언급하는게 ㅆㅇㅆ(124.216) 10.31 72 0
2899698 ㅆㅇㅆ는 걍 천재인척하는 범재임 ㅇㅇ(118.235) 10.31 89 3
2899697 리액트 공부 2일차 [2] 꿀통찾는꿀벌갤로그로 이동합니다. 10.31 91 0
2899696 나랑 결혼한지 1년차인 와이프 사진 ㅇㅇ1갤로그로 이동합니다. 10.31 83 0
2899695 누구야? 넥도리아(220.74) 10.31 70 0
2899694 옛날에 디버깅은 일단 디버거 켜서 ㅆㅇㅆ찡갤로그로 이동합니다. 10.31 78 0
2899693 트레이딩뷰는 WebGL이랑 캔버스 프로젝트인데 [7] ㅆㅇㅆ(124.216) 10.31 89 0
2899692 왜 주식 프로그램 말하는 애들은 하나같이 차트를 웹으로 하고싶어할까 [1] ㅆㅇㅆ(124.216) 10.31 82 0
2899691 아무리 생각해도ai는 없는게 낫다 [9] 프갤러(211.234) 10.31 96 0
2899690 코로나 코딩붐때 국비 수료하고 개발자 됐는데 후회한다 [1] ㅇㅇ(106.101) 10.31 122 0
2899688 배 아파서 항외과 넥도리아(223.38) 10.31 60 0
2899687 [애니뉴스] 소설 사이트 개발 [2] 프갤러(121.172) 10.31 72 0
2899686 냥덩이가 나 따라다니는거 다중이로 하는거 그냥 무시해라 ㅆㅇㅆ(124.216) 10.31 70 2
2899683 글카 가격 정상화 되냐? [6] 루도그담당(58.239) 10.31 125 0
2899682 일이 고정이 아니고 취소됐다 안됐다 하니 쩝. 오늘은 나가리네 [2] ㅆㅇㅆ(124.216) 10.31 90 0
2899681 냥덩이는 ㅆㅇㅆ한테 열등감 느끼니 저러는거지 [1] ㅇㅇ(112.163) 10.31 89 2
2899680 국내 최원종 앙성 갤러리 ㅋㅋ ㅇㅇ(118.235) 10.31 66 0
2899679 냥덩이는 왜 다중이로 ㅆㅇㅆ 괴롭히냐 [2] ㅇㅇ(112.163) 10.31 78 2
2899678 이갤은 ㅆㅇㅆ같은 빡통 좆문가가 왜케 많냐 [4] ㅇㅇ(118.235) 10.31 127 4
2899677 [대한민국] 윤석열 대통령 재판 상황 - 곽종근 프갤러(121.172) 10.31 55 0
2899676 이봐봐 러스트 안쓰니까 쓸데없는걸로 싸움질 하다 갤 망했네 프갤러(218.154) 10.31 61 0
2899674 답을 찾았다. 저능아들을 계몽시킬 방법을 [1] 프갤러(218.154) 10.31 77 0
2899673 진짜 개좇센은 전세계 재벌들 좇판 좇집실험장이누 타이밍뒷.통수한방(1.213) 10.31 51 0
2899671 ㅆㅇㅆ쟤는 10년 20년 30년뒤에도 저지랄할까봐 [3] ㅇㅇ(118.235) 10.31 125 4
2899670 무릎 아파. . 넥도리아(223.38) 10.31 51 0
2899669 월말 백업중..ㅇㅅㅇ [3] 헤르 미온느갤로그로 이동합니다. 10.31 82 1
2899668 시들어가는 국화 ㅇㅅㅇ [2] 헤르 미온느갤로그로 이동합니다. 10.31 69 0
2899667 태연 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 10.31 56 0
2899666 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 10.31 89 0
2899665 성당과 시장 [1] ㅇㅇ(49.165) 10.31 72 0
2899661 여기있는거 다 안다 게이야 ㅇㅇ(49.236) 10.31 85 0
2899660 유폐차냐? ㅇㅇ(49.236) 10.31 75 0
2899659 나 지금 매일 개인적으로 하고 있는 목표가 프로그래밍 패턴 용례 정리임 ㅆㅇㅆ(124.216) 10.31 112 0
2899658 머리가 극도로 좋은 애들이야 구현 하면 되는거고 [2] ㅆㅇㅆ(124.216) 10.31 148 0
2899657 GOF 23가지 패턴 말고도 패턴들 거의 정형화되있잖아? 사실 패턴 뼈대 [2] ㅆㅇㅆ(124.216) 10.31 123 0
2899655 나는 개발자 오래 해먹을 수 있다고 생각하는게 지금 문제는 [2] ㅆㅇㅆ(124.216) 10.31 195 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2