디시인사이드 갤러리

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

갤러리 본문 영역

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

ㅆㅇㅆ(124.216) 2025.10.29 01:28:46
조회 276 추천 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 - -
2900130 지듣노 루도그담당(58.239) 11.02 51 0
2900129 탈갤하겠다고 해놓고 지 욕하는지 눈팅하면서 글올라오면 신고삭 ㅇㅇ(175.223) 11.02 77 0
2900126 [대한민국] 간신배와 연애인의 관계 프갤러(121.172) 11.02 47 0
2900125 개인어플사업 무서운 가상시나리오 [11] 슈퍼막코더(126.233) 11.02 130 1
2900124 그레셤의 법칙이 더닝크루거에 선행한다 [3] chironpractor갤로그로 이동합니다. 11.02 81 0
2900122 내가 10년전부터 말한게 전세계사람들이 공감하기시작함 [1] 타이밍뒷.통수한방(1.213) 11.02 73 0
2900121 프갤에 새싹이 있긴 한가? [6] ㅇㅇ갤로그로 이동합니다. 11.02 102 0
2900117 병원 ㅈㄱㄱㄴㅈ [2] 넥도리아(118.235) 11.02 59 0
2900116 디비 사용법도 익혔고 이제 회원가입 만들어야겠다. [1] 프갤러(223.56) 11.02 72 0
2900113 소나무도 가을이면 잎을 떨구는군..ㅇㅅㅇ [2] 헤르 미온느갤로그로 이동합니다. 11.02 74 0
2900112 태연 ㅇㅅㅇ [1] 헤르 미온느갤로그로 이동합니다. 11.02 57 0
2900111 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 11.02 47 0
2900110 쓸데없는거 가지고 싸울 시간에 러스트나 배워라 프갤러(110.8) 11.02 65 0
2900080 ocr 왜씀? [10] ㅇㅇ(49.165) 11.02 129 0
2900055 더이상의 싸움은 무의미하다 [1] 헬마스터갤로그로 이동합니다. 11.02 90 1
2900053 아 그런데 갈땐 가더라도 이 말만은 꼭 하고싶다 [49] ㅇㅇ(124.48) 11.02 189 4
2900047 애들아 싸우지말고 자자 [6] 루도그담당(58.239) 11.02 93 0
2900045 오늘부터 나도 ai엔지니어 할란다 [89] ㅇㅇ(124.48) 11.02 223 0
2900043 yolo << 솔직히 개편하긴 함 [2] 루도그담당(58.239) 11.02 101 0
2900038 근데 가끔 학생들 가르치다 보면 [4] 루도그담당(58.239) 11.02 100 0
2900036 아니 근데 이럴땐 줘패고 싶음 [3] 루도그담당(58.239) 11.02 88 0
2900035 내가 모기년에게 제일 실망했던 건 이거임 [133] 에이도비갤로그로 이동합니다. 11.02 227 0
2900033 저새낀 걍 이제부터 내가 무시해야겠다 [2] ㅇㅇ(124.48) 11.02 107 0
2900030 백남준 이새끼 좇나 씹거품인 개좇쓰레기새끼임 타이밍뒷.통수한방(1.213) 11.02 74 0
2900025 이런게 존나 개빡친다는거야 [4] ㅇㅇ(124.48) 11.02 194 5
2900013 재능이 없어서 문제다 [2] ㅇㅇ(122.199) 11.01 104 0
2900011 러스트 좀 빡세네 [2] 프갤러(110.8) 11.01 99 0
2900009 취업실패하고 공장갑니다.. [3] ㅇㅇ(1.241) 11.01 150 0
2900008 승자가 결국 역사를 쓴다는 점 때문에 [2] chironpractor갤로그로 이동합니다. 11.01 92 0
2900005 피에로공 아직도 여기있음메? [3] 카드캡터체리갤로그로 이동합니다. 11.01 78 0
2900002 아이큐 높은 사람보면 부럽긴 함 [2] 루도그담당(58.239) 11.01 118 0
2900001 미국은 내정간섭은 피하려 한다는 느낌은 듦 chironpractor갤로그로 이동합니다. 11.01 78 1
2899996 지듣노 [4] 루도그담당(58.239) 11.01 91 0
2899992 내가 봤을땐 걍 저 친구가 [15] 루도그담당(58.239) 11.01 158 0
2899991 중국에 대한 인식은 홍콩에서도 드러나는데 [5] chironpractor갤로그로 이동합니다. 11.01 88 0
2899988 Mac 스크린 타임 앱 만들어봄 [17] 프갤러(115.138) 11.01 413 20
2899985 걍 싸우지들 마라 [1] 루도그담당(58.239) 11.01 107 0
2899981 [대한민국] 캄보디아 사건에 대한 짧은 글 프갤러(121.172) 11.01 49 0
2899975 124.48 얘 다중이 맞잖아 [1] 루도그담당(58.239) 11.01 88 0
2899974 [대한민국] 노상원 재판 중계 간략 프갤러(121.172) 11.01 51 0
2899971 크몽 ㄹㅇ 좆병신 플랫폼임 [4] 프갤러(175.116) 11.01 108 0
2899945 글삭튀 하는거 걸리면 쪽팔리니까 셀프신고 주작기로 알바삭 ㅋㅋ [1] ㅇㅇ(140.248) 11.01 91 3
2899943 ㅆㅇㅅ 롤갤도하노 [1] 프갤러(223.38) 11.01 81 0
2899942 버거킹을 포기하고 집에 일찍 와서 라면 끓이고 있다. [1] 프갤러(110.8) 11.01 77 0
2899937 vscode extension 하나 개발햇어 [1] 규규(210.100) 11.01 78 0
2899936 뭔 프로그래밍이냐 ㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋ ㅇㅇ(160.238) 11.01 69 0
2899935 나는 파이썬 빠는 것들은 이해가 안가. [12] 프갤러(211.234) 11.01 138 0
2899934 [애니뉴스] Research 항목 추가 프갤러(121.172) 11.01 109 0
2899929 아 버거킹 못먹는다 ㅅㅂ [3] 프갤러(223.56) 11.01 75 0
2899926 저녁 버거킹 먹어야겠다. 프갤러(223.56) 11.01 55 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2