본문으로 건너뛰기
피드

서드파티 핵은 쿼크가 아니다 — Old New Thing 댓글에서 벌어진 통합 철학 논쟁

backend 약 3분
vote
0
댓글
북마크

Raymond Chen 블로그 댓글에서 서드파티 프로세스에 원격 스레드를 주입하는 식의 핵을 '쿼크'라 포장하는 관행에 대한 날카로운 비판과, ATM 리부트 루프 같은 실제 사고 사례를 통해 올바른 통합 경계의 중요성을 논함

  • 1

    '핵을 넣든가 고객을 잃든가'는 거짓 이분법 — 지원 가능 동작 정의, 올바른 경계 수정, 망가진 컴포넌트에 변경 요청이 진짜 대안

  • 2

    쿼크 추가는 문제를 숨기고 장기 비용을 높이며 정의되지 않은 동작 에뮬레이션 리스크를 전가함

  • 3

    ATM 리부트 루프로 VISA/MasterCard 다운타임 위약금 배상 사례 등 실제 피해가 발생함

  • Raymond Chen의 Old New Thing 블로그 댓글에서 벌어진 소프트웨어 엔지니어링 철학 논쟁이 꽤 읽을 만함. 핵심은 "서드파티 프로세스에 원격 스레드 주입하는 걸 '쿼크 추가'라고 부르는 순간, 하던 일 멈추고 자기 성찰 좀 하라"는 거임
  • "핵을 넣든가 고객을 잃든가"는 거짓 이분법이라는 주장. 진짜 대안은 지원 가능한 동작을 정의하거나, 올바른 경계에서 통합을 고치거나, 실제로 망가진 컴포넌트 쪽에 변경을 요청하는 것
  • 쿼크를 추가하면 생기는 일: 문제를 숨기고, 장기 비용은 올라가고, 정의되지 않은 동작을 에뮬레이트하는 코드에 리스크가 전가됨. 서드파티 업데이트 한 번에 전부 깨질 수 있음
  • 실제 사례가 살벌함 — "ATM이 리부트 루프에 빠져서 은행이 VISA/MasterCard한테 물린 다운타임 위약금을 배상하라고 요구한 적 있음". 핵의 대가가 이 정도임
  • 반론도 있긴 함: 서드파티가 "관심 없음" 또는 "소스코드 잃어버림"이라고 하면 어쩌냐는 건데, 그에 대한 답변이 냉정함 — "흔하다고 올바른 건 아님"
  • 15년차 경력자 시각: 서드파티 통합 문제의 대부분은 컴포넌트 사용법을 제대로 이해 못 하거나, 이미 존재하는 유료 컴포넌트 라이선스를 안 사려 하거나, 변경 요청 비용을 안 내려는 데서 옴
  • 결국 핵심 질문은 이거임 — "매니저가 다른 개발자가 제안한 엉터리 솔루션을 너한테 위임했을 때, 그냥 쓸 거냐 아니면 '이거 제안한 사람이 직접 짜시죠'라고 말할 전문가적 소신이 있느냐"

서드파티 통합 문제의 근본 원인은 대부분 사용법 미이해, 유료 컴포넌트 라이선스 회피, 변경 요청 비용 회피에서 비롯되며 핵으로 우회하면 결국 더 큰 비용으로 돌아옴

댓글

댓글

댓글을 불러오는 중...

backend

Go에서 Rust로 옮길 때 진짜로 바뀌는 것들

이 글은 Go 백엔드 서비스를 Rust로 옮길 때 속도보다 컴파일 타임 보장, 런타임 트레이드오프, 개발자 경험이 더 중요하다고 설명한다. nil 패닉, 데이터 레이스, 에러 처리, 제네릭, 비동기 모델, 마이그레이션 전략까지 실무 관점에서 Go와 Rust를 길게 비교한다.

backend

Python 3.15에서 헤드라인은 못 탔지만 꽤 쓸만한 기능들

Python 3.15에는 lazy imports나 Tachyon profiler 같은 큰 기능 말고도 실무에서 바로 체감될 만한 작은 개선들이 들어가. TaskGroup 취소, 컨텍스트 매니저 데코레이터 개선, 스레드 안전 이터레이터처럼 평소 애매하게 불편했던 지점들이 꽤 깔끔해졌어.

backend

심평원, DUR부터 의료영상 심사까지 클라우드로 갈아엎는다

심평원이 정보시스템 클라우드 전환과 함께 병·의원 업무에 직접 닿는 DUR, 의료영상 AI 심사, 요양급여내역 조회 시스템을 고도화한다. 핵심은 설치형 프로그램 중심이던 연계를 웹과 API 기반으로 넓히고, 진료·청구 과정에서 실시간 확인과 자동 판독을 강화하는 쪽이다.

backend

윈도우 에러 코드 7번 ‘ERROR_ARENA_TRASHED’는 어디서 왔을까

ERROR_ARENA_TRASHED는 Win32에서 실제로 쓰이는 현대적 에러라기보다 MS-DOS 시절 메모리 관리 구조에서 넘어온 잔재야. MS-DOS가 메모리 블록 앞의 arena 시그니처를 훑다가 예상한 값이 아니면 ‘arena가 망가졌다’고 보고 이 에러를 냈다는 이야기야.

backend

C/C++ 컴파일러의 느슨한 메모리 동시성 버그를 자동으로 잡는 박사논문

C와 C++ 컴파일러에서 relaxed memory 동시성 버그를 찾는 자동 테스트 프레임워크를 다룬 박사논문이 공개됐어. Téléchat, Atomic-mixer 같은 도구로 소스 수준 동작과 컴파일된 프로그램 동작을 비교하고, LLVM과 GCC 툴체인에서 실제 버그를 찾아낸 내용이 핵심이야.