디시인사이드 갤러리

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

갤러리 본문 영역

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

ㅆㅇㅆ(124.216) 2025.10.29 01:28:46
조회 252 추천 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 48387 65
2899865 [박진영의 사회심리학] 지혜는 겸손에서 비롯된다 발명도둑잡기(118.216) 10:41 6 0
2899864 결국 인문학이다 chironpractor갤로그로 이동합니다. 10:35 12 0
2899863 병원 7층에서 바라본 장면 [3] 넥도리아(223.38) 10:03 31 0
2899862 ddia 멧돼지책이 프갤러(211.186) 10:02 14 0
2899861 치즈냥이 친화성 좋은듯 ♥KiTTY냥덩♥갤로그로 이동합니다. 09:57 15 0
2899859 ㅇㄷ [7] 프갤러(211.234) 09:24 47 0
2899858 모두가 냥덩이 한번 만져보겠다고 ㅋㅅㅋ [4] ♥KiTTY냥덩♥갤로그로 이동합니다. 08:51 43 0
2899857 스벅와서 커피 가져가는 중 chironpractor갤로그로 이동합니다. 08:42 29 0
2899856 아침 먹었으니 약먹고 자야지..ㅇㅅㅇ [2] 헤르 미온느갤로그로 이동합니다. 08:02 28 0
2899855 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ [2] ♥KiTTY냥덩♥갤로그로 이동합니다. 07:17 38 0
2899854 한 방에 인생 역전같은거 바라다간..ㅇㅅㅇ [2] 헤르 미온느갤로그로 이동합니다. 07:00 28 0
2899853 거대한 화분 ㅇㅅㅇ [6] 헤르 미온느갤로그로 이동합니다. 06:36 39 0
2899852 태연 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 06:32 23 0
2899851 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 06:28 32 0
2899850 나는조현병이야 나는내향적이야 손발이시립디다갤로그로 이동합니다. 06:21 31 0
2899846 ㅂㅅ들 인생 역전할 수 있는 유일한 방법은 코인이디 ㅇㅇ(222.108) 03:04 32 0
2899833 “아빠 친구가 내 자취방에”… 섬뜩한 ‘AI 몰카’ 장난 발명도둑잡기(118.216) 01:54 36 0
2899832 에이도비햄 gitee 안하나. 중국애들은 대부분 gitee임 [8] ㅆㅇㅆ(124.216) 01:50 95 1
2899831 음기 충전 발명도둑잡기(118.216) 01:40 49 0
2899828 섹스뽕냄새 ㅆㅇㅆ(14.32) 01:24 48 1
2899826 출장후기) 개빡셋다 ㅅㅂ [19] 에이도비갤로그로 이동합니다. 01:21 140 3
2899825 아이피 비슷한거 우연인가? [1] ㅇㅇ(124.48) 01:15 69 1
2899824 저새낀 코딩이 재밌네 공부가 재밌네 ㅇㅈㄹ 싸면서 [4] ㅇㅇ(124.48) 01:12 86 4
2899822 ㅆㅇㅆ 장애인은 하루라도 안쳐맞는날이 없구나 ㅇㅇ(118.235) 00:47 55 5
2899821 레디스 카프카 이건 진짜 확실히 익혀둬야긋다 [3] ㅆㅇㅆ(124.216) 00:42 66 0
2899820 오늘 ㅆㅇㅆ 긁힘 포힌트 [5] ㅇㅇ(106.101) 00:08 109 1
2899819 기술적인 글도 진영간 대립으로 번져가는 모양새는 좀 서글픈데 [4] chironpractor갤로그로 이동합니다. 10.31 52 0
2899818 애널의 수면영상 ♥KiTTY냥덩♥갤로그로 이동합니다. 10.31 56 0
2899817 블로그에 쓰는 개발에 관련된 내용도 한국 블로그는 대체로 축약이 많고 chironpractor갤로그로 이동합니다. 10.31 30 0
2899816 이건희에서 용산 전자상가까지‥"피시방 덕분에 엔비디아가 성장" 발명도둑잡기(118.216) 10.31 32 0
2899815 ㅈㄴ 웃기네 십 ㅋㅋ [5] 박민준갤로그로 이동합니다. 10.31 66 0
2899814 [특종] 나님 내일 멍유의 역겨운 여자문제 하나 폭로하갰습니당 [4] ♥KiTTY냥덩♥갤로그로 이동합니다. 10.31 53 0
2899813 내가 살면서 느끼는데 사실 깃에서 템플릿 떼와가지고 [2] ㅆㅇㅆ(124.216) 10.31 47 0
2899812 여기 뭐하는 갤인가요 [6] 개멍청한유라갤로그로 이동합니다. 10.31 67 0
2899811 프로그래밍할때 한국어 문서 볼거 있음?? [3] 프갤러(1.213) 10.31 42 1
2899810 애플 모바일기기 가장 큰 단점이 ♥KiTTY냥덩♥갤로그로 이동합니다. 10.31 24 0
2899809 그래도 언어유희는 한국어가 모국어라 그런지 ♥KiTTY냥덩♥갤로그로 이동합니다. 10.31 54 0
2899808 K-Art-청년창작자-지원-사업-신청-방법과-자격-연-900만원 [1] 발명도둑잡기(118.216) 10.31 29 0
2899807 언어를 여러개 쓰면 쓸수록 한국어는 의미전달력이 떨어지는 [2] ♥KiTTY냥덩♥갤로그로 이동합니다. 10.31 61 0
2899806 DIY printer and linear drives 발명도둑잡기(118.216) 10.31 20 0
2899805 ㅋㅅㅋ [4] ♥KiTTY냥덩♥갤로그로 이동합니다. 10.31 70 0
2899804 106.101 124.48 118.235 <-병먹금 합시다 [4] 발명도둑잡기(118.216) 10.31 51 0
2899803 제조업이란 무엇인가? AI도 대신할 수 없는 제조업만의 가치 발명도둑잡기(118.216) 10.31 20 0
2899802 ㅆㅇㅆ야 대체 왜 맨날 욕만 처먹는데도 꾸역꾸역 처 들어와? ㅇㅇ(124.48) 10.31 50 0
2899801 "흰머리, 암 예방한 흔적이다?" 줄기세포 생존 반응 '주목' / KNN 발명도둑잡기(118.216) 10.31 19 0
2899800 런던베이글 신화의 비국.. 사모펀드 또 사회적 물의 발명도둑잡기(118.216) 10.31 18 0
2899799 김종대 “핵추진 잠수함, 강대국의 환상…과잉 전력이자 지정학적 족쇄” 발명도둑잡기(118.216) 10.31 24 0
2899798 눈 앞의 불 끄려다 큰 걸 놓쳐버린 '핵잠수함 소동' 발명도둑잡기(118.216) 10.31 16 0
2899797 ‘100만 유튜버’ 수탉, 납치→무차별 폭행당해…얼굴 피해 심각 발명도둑잡기(118.216) 10.31 78 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2