디시인사이드 갤러리

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

갤러리 본문 영역

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

ㅆㅇㅆ(124.216) 2025.10.29 01:28:46
조회 364 추천 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/12/08 - -
이슈 [디시人터뷰] 솔직함을 리뷰하는 유튜버, 흑백리뷰 운영자 25/12/09 - -
AD 루틴 ON! 운동 찐템! 지금 할인 중 운영자 25/11/27 - -
2899610 미래의 어느 역사학자들의 대화라는데 (요약편) 프갤러(211.210) 10.30 98 0
2899609 미래의 어느 역사학자들의 대화라는데 프갤러(211.210) 10.30 127 0
2899608 핑계고에서 미미가 요즘 원숭이 귀가 유행이라고 프갤러(211.210) 10.30 152 0
2899607 아이폰이 롤리팝을 이긴 것처럼 프갤러(211.210) 10.30 112 1
2899606 화교의 속마음 [1] 프갤러(211.210) 10.30 141 0
2899604 청룡영화제 뭐 이런 단어 프갤러(211.210) 10.30 157 0
2899603 요즘 좌파 화교 특 프갤러(211.210) 10.30 133 0
2899602 기안84 수상한 건 [1] 프갤러(211.210) 10.30 193 0
2899601 알고보니 어렸을 때 치파오 입고 있었고 프갤러(211.210) 10.30 98 0
2899600 문화에 힘을 왜 쓰냐 다 구란데 [1] 프갤러(211.210) 10.30 134 0
2899599 김창욱 김제동 오은영 같은 프갤러(211.210) 10.30 112 0
2899598 부천역 bj들 내쫒는 분위기네 프갤러(211.210) 10.30 145 0
2899597 개쳐맞는것도 소통이긴함 ㅇㅇ(118.235) 10.30 102 3
2899596 ㅆㅇㅆ 지금 삶의 의지가 잔뜩 꺽였음 ㅋㅋㅋ [1] ㅇㅇ(106.101) 10.30 218 3
2899594 나는 AI 발전이 현재 트랜스포머 구조때문에라도 개발자가 더 비싸질거라 [3] ㅆㅇㅆ(124.216) 10.30 167 0
2899593 타로 사이트도 고졸이 하루이틀이면 만드는걸 [2] ㅇㅇ(118.235) 10.30 183 1
2899591 잘짠다해도 반드시 사고가 터짐. 왜냐하면 코드가 몇만줄 넘으니까 [3] ㅆㅇㅆ(124.216) 10.30 179 0
2899590 ㅆㅇㅆ가 실력 없다는건 잘 알겠다 ㅇㅇ ㅇㅇ(118.235) 10.30 125 6
2899589 취미로 코딩하는 애들이 AI 시대 승자다 [33] 박민준갤로그로 이동합니다. 10.30 253 0
2899588 러스트하능사람들 러스트장점알려줭 [1] 무토낑(119.202) 10.30 140 0
2899587 비전공이 개발 덤벼드는거 참 이해가 안된다 ㅇㅇ(106.101) 10.30 208 0
2899586 한국 프로그래머는 노가다라기 보다는 음... 똥퍼입니다. [3] 프갤러(110.8) 10.30 118 0
2899585 러스트가 C보다 빠를숭없징? [6] 무토낑(119.202) 10.30 150 0
2899584 실력이라는게 결국은 일종의 허상이라고 생각은 함. [3] ㅆㅇㅆ(124.216) 10.30 169 0
2899583 한국it에서는 현업자가 더 병신입니다. [1] 프갤러(110.8) 10.30 165 0
2899582 내가 쿠팡 안쓰고 배민 쓰는 이유는 딱 하나임 [1] 야옹아저씨갤로그로 이동합니다. 10.30 152 0
2899581 현업자들의 실력은 어떠냐면 [6] 박민준갤로그로 이동합니다. 10.30 192 0
2899580 ㅆㅇㅆ야 이걸 보고도 너가 성공할 수 있을거라 생각할까? [2] ㅇㅇ(51.158) 10.30 164 4
2899578 엔비디아 회장이 왜 깐부치킨갔는지 생각해봤는데 ㅆㅇㅆ(124.216) 10.30 160 0
2899576 ㄹㅇㅆㅇㅆ 이새끼 반박할때는 쿨한척 운좋은척 다하다가 [1] ㅇㅇ(118.235) 10.30 162 5
2899574 요즘들어 실패의 관점이 바뀜 프갤러(114.205) 10.30 131 0
2899572 초 고수 [3] 배구공(119.202) 10.30 127 0
2899570 ㅆㅇㅆ 얘는 무슨 자신감으로 이렇게 사냐 [1] ㅇㅇ(106.101) 10.30 157 4
2899569 ㅆㅇㅆ야 니 인생 계획은 뭐냐? ㅇㅇ(51.159) 10.30 121 3
2899567 이제 ㅆㅇㅆ 욕하는것도 노잼이네 [1] ㅇㅇ(106.101) 10.30 166 3
2899566 내가 프갤서 느끼는건 자칭 보수 우파라는 애들은 선동과 날조가 패시브임 ㅆㅇㅆ(124.216) 10.30 125 1
2899564 내가 프론트엔드 공부하는데 [2] 호호(121.130) 10.30 198 0
2899562 자바스크립트 어렵다 [1] 호호(121.130) 10.30 140 0
2899561 같이 취미코딩 하실분 Mosaic갤로그로 이동합니다. 10.30 111 0
2899555 '19'갤꼬라지봐라시발.gif [1] 박민준갤로그로 이동합니다. 10.30 137 0
2899544 엔비디아에서 깐부치킨 광고하길래 시킬려는데 [1] 헬마스터갤로그로 이동합니다. 10.30 144 0
2899542 안녕 30 고졸 노베이스 비전공자 컴공 취준생이다 [7] 30고졸노베(125.191) 10.30 297 0
2899539 AI 바이브 코딩 인생 40 년 갈아 넣었습니다. [1] 프갤러(59.16) 10.30 191 0
2899537 리액트 루프에서 index를 키로 쓰지말라는 질문 근데 진짜 날카롭네 [2] ㅆㅇㅆ(124.216) 10.30 157 0
2899536 중국쪽 머기업 프론트 엔드 개발자 면접 질문들 정리한거 봤는 [2] ㅆㅇㅆ(124.216) 10.30 203 0
2899535 요즘 책 종종 읽는데 [2] 루도그담당(58.239) 10.30 163 0
2899534 프로그램 최고 장점이 프로그램은 인터넷에 읽을게 많아 [2] ㅆㅇㅆ(124.216) 10.30 144 0
2899533 몸이 아프질 말아야.. 모든게 의미가 있는거지 [9] 나르시갤로그로 이동합니다. 10.30 171 0
2899531 나 현역때는 기억에 의존하는 개발하기 싫어했는데 [8] chironpractor갤로그로 이동합니다. 10.30 183 0
2899529 너네 근데 깃 명령어 같은거 다 외우냐 [4] ㅆㅇㅆ(124.216) 10.30 178 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2