fos-blog/study
01 / 홈02 / 카테고리03 / 시리즈
01 / 홈02 / 카테고리03 / 시리즈

카테고리

  • AI 페이지로 이동
    • RAG 페이지로 이동
    • langgraph 페이지로 이동
    • agents.md
    • BMAD Method — AI 에이전트로 애자일 개발하는 방법론
    • Claude Code의 Skill 시스템 - 개발자를 위한 AI 자동화의 새로운 차원
    • Claude Code를 5주 더 쓴 결과 — 스킬·CLAUDE.md를 키워가는 방식
    • Claude Code를 11일 동안 쓴 결과 — 데이터로 본 나의 사용 패턴
    • Claude Code 멀티 에이전트 — Teams
    • AI 에이전트와 디자인의 새 컨벤션 — DESIGN.md, Google Stitch, Claude Design
    • Docling — IBM Research 의 문서 파싱 toolkit 상세 정리
    • 하네스 엔지니어링 실전 — 4인 에이전트 팀으로 코딩 파이프라인 구축하기
    • 하네스 엔지니어링 — 오래 실행되는 AI 에이전트를 위한 설계
    • 멀티모달 LLM (Multimodal Large Language Model)
    • AI 에이전트와 함께 MVP 만들기 — dooray-cli 사례
  • ai 페이지로 이동
    • agent 페이지로 이동
  • algorithm 페이지로 이동
    • live-coding 페이지로 이동
    • 분산 계산을 위한 알고리즘
  • apartment 페이지로 이동
    • 구리 럭키아파트 24평 인테리어 레퍼런스 모음
  • architecture 페이지로 이동
    • [초안] 시니어 백엔드를 위한 API 설계 실전 스터디 팩 — REST · 멱등성 · 페이지네이션 · 버전 전략
    • [초안] API Versioning과 Backward Compatibility: 시니어 백엔드 관점 정리
    • 캐시 설계 전략 총정리
    • [초안] CJ푸드빌 디지털 채널 면접: 슬롯 도메인 경험을 커머스 도메인 설계 능력으로 번역하기
    • [초안] 커머스 Spring 서비스에 Clean/Hexagonal Architecture를 실용적으로 적용하기
    • [초안] 커머스 도메인 모델링: 주문·재고·노출의 세 축을 분리해서 설계하기
    • 커머스 주문 상태와 데이터 정합성 기본기 — CJ푸드빌 면접 대비
    • [초안] 쿠폰/프로모션 동시성과 정합성 기본기 — 선착순·중복 사용 방지·발급/사용/복구
    • [초안] DDD와 도메인 모델링: 시니어 백엔드 관점의 전술/전략 패턴 실전 가이드
    • [초안] Decorator & Chain of Responsibility — 행동을 체인으로 조립하는 두 가지 방식
    • 디자인 패턴
    • [초안] 분산 아키텍처 완전 정복: Java 백엔드 시니어 인터뷰 대비 실전 가이드
    • [초안] 분산 트랜잭션과 Outbox 패턴 — 왜 2PC를 피하고 어떻게 대신할 것인가
    • 분산 트랜잭션
    • [초안] e-Commerce 주문·결제 도메인 모델링: 상태머신, 멱등성, Outbox/Saga 실전 정리
    • [초안] F&B 쿠폰·프로모션·멤버십·포인트 설계
    • [초안] F&B · e-Commerce 디지털 채널 도메인 한 장 정리 — CJ푸드빌 디지털 채널 백엔드 면접 대비
    • [초안] F&B 주문/매장/픽업 상태머신 설계 — CJ푸드빌 디지털 채널 백엔드 관점
    • [초안] F&B 이커머스 결제·환불·정산 운영 가이드
    • [초안] Hexagonal / Clean Architecture를 Spring 백엔드에 적용하기
    • [초안] 대규모 커머스 트래픽 처리 패턴 — 1,600만 고객과 올영세일을 버티는 설계
    • [초안] 레거시 JSP/jQuery 화면과 신규 API가 공존하는 백엔드 운영 전략
    • [초안] MSA 서비스 간 통신: Redis [Cache-Aside](../database/redis/cache-aside.md) × Kafka 이벤트 하이브리드 설계
    • [초안] Observability 입문: 시니어 백엔드가 장애를 탐지하고 대응하는 방식
    • [초안] Outbox / Inbox Pattern 심화 — 분산 메시징의 정합성 문제를 DB 트랜잭션으로 풀어내기
    • [초안] 결제 도메인 멱등성과 트랜잭션 재시도 기본기
    • [초안] 시니어 백엔드를 위한 Resilience 패턴 실전 가이드 — Timeout, Retry, Circuit Breaker, Bulkhead, Backpressure
    • [초안] REST API 버저닝과 모바일 앱 하위 호환성 — CJ푸드빌 디지털 채널 백엔드 관점
    • [초안] Spring Batch vs Event-Driven — 같은 비동기처럼 보이지만 전혀 다른 두 패러다임
    • [초안] Strategy Pattern — 분기문을 없애는 설계, 시니어 백엔드 인터뷰 핵심 패턴
    • [초안] 시니어 백엔드를 위한 시스템 설계 입문 스터디 팩
    • [초안] 템플릿 메서드 패턴 - 백엔드 처리 골격을 강제하는 가장 오래되고 가장 위험한 패턴
    • [초안] 대규모 트래픽 중 무중단 마이그레이션 — Feature Flag + Shadow Mode 실전
  • database 페이지로 이동
    • mysql 페이지로 이동
    • opensearch 페이지로 이동
    • redis 페이지로 이동
    • 김영한의-실전-데이터베이스-설계 페이지로 이동
    • [초안] DB Connection Pool Saturation과 Thread Pool 격리
    • 커넥션 풀 크기는 얼마나 조정해야 할까?
    • 인덱스 - DB 성능 최적화의 핵심
    • [초안] JPA N+1과 커머스 조회 모델: 주문/메뉴/쿠폰 도메인에서 살아남기
    • [초안] MyBatis 기본기 — XML Mapper, resultMap, 동적 SQL, 운영 패턴 정리
    • [초안] MyBatis와 JPA/Hibernate 트레이드오프 — 레거시 백엔드를 다루는 시니어 관점
    • 역정규화 (Denormalization)
    • 데이터 베이스 정규화
  • devops 페이지로 이동
    • docker 페이지로 이동
    • k8s 페이지로 이동
    • k8s-in-action 페이지로 이동
    • observability 페이지로 이동
    • [초안] 커머스/F&B 채널 장애 첫 5분과 관측성 기본기
    • Envoy Proxy
    • [초안] F&B / e-Commerce 운영 장애 대응과 모니터링 — 백엔드 관점 정리
    • Graceful Shutdown
    • [초안] 시니어 백엔드를 위한 SLO와 Error Budget 기반 장애 대응
  • finance 페이지로 이동
    • industry-cycle 페이지로 이동
    • investing 페이지로 이동
  • http 페이지로 이동
    • HTTP Connection Pool
  • interview 페이지로 이동
    • [초안] AI 서비스 팀 경험 기반 시니어 백엔드 면접 질문 뱅크 — Spring Batch RAG / gRPC graceful shutdown / 전략 패턴 / 12일 AI 웹툰 MVP
    • [초안] 커머스/F&B 면접 답변집 — 슬롯 도메인 경험을 주문·결제·쿠폰·매장 설계로 매핑하기
    • [초안] F&B / e-Commerce 운영 모니터링과 장애 대응 인터뷰 정리
    • Observability — 면접 답변 프레임
    • [초안] 시니어 Java 백엔드 면접 마스터 플레이북 — 김병태
    • [초안] NSC 슬롯팀 경험 기반 질문 은행 — 도메인 모델링·동시성·성능·AI 협업
  • java 페이지로 이동
    • concurrency 페이지로 이동
    • jdbc 페이지로 이동
    • opentelemetry 페이지로 이동
    • spring 페이지로 이동
    • spring-batch 페이지로 이동
    • 더_자바_코드를_조작하는_다양한_방법 페이지로 이동
    • [초안] Java 동시성 락 정리 — 커머스 메뉴/프로모션 정책 캐시 갱신 관점
    • [초안] JVM 튜닝 실전: 메모리 구조부터 Virtual Threads, GC 튜닝, 프로파일링까지
    • Java의 로깅 환경
    • MDC (Mapped Diagnostic Context)
    • Java StampedLock — 읽기 폭주에도 쓰기가 밀리지 않는 락
    • Virtual Thread와 Project Loom
  • javascript 페이지로 이동
    • typescript 페이지로 이동
    • AbortController
    • Async Iterator와 제너레이터
    • CommonJS와 ECMAScript Modules
    • 제너레이터(Generator)
    • Http Client
    • Node 백엔드 운영 패턴 — Streams 백프레셔, pipe/pipeline, 멱등성 vs 분산 락
    • Node.js
    • npm vs pnpm — 어떤 기준으로 선택했나
    • `setImmediate()`
  • kafka 페이지로 이동
    • [초안] Kafka 기본 개념 — 토픽, 파티션, 오프셋, 복제
    • Kafka를 사용하여 **데이터 정합성**은 어떻게 유지해야 할까?
    • [초안] Kafka 실전 설계: 파티션 전략, 컨슈머 그룹, 전달 보장, 재시도, 순서 보장 트레이드오프
    • 메시지 전송 신뢰성
  • linux 페이지로 이동
    • fsync — 리눅스 파일 동기화 시스템 콜
    • tmux — Terminal Multiplexer
  • network 페이지로 이동
    • L2(스위치)와 L3(라우터)의 역할 차이
    • L4와 VIP(Virtual IP Address)
    • IP Subnet
  • python 페이지로 이동
    • Python async/await — CompletableFuture·Reactor 와 다른 점, 그리고 blocking I/O 함정
    • Python 의존성 관리 — Java Maven/Gradle 사용자가 만나는 첫 충격
    • FastAPI 기초 — Spring Boot 사용자가 빠르게 익히는 법
    • GPU·CUDA·MPS 기초 — 자바 백엔드 개발자가 처음 만나는 그림
    • Multi-process GPU 워크로드 — 자바 ThreadPool 사용자가 만나는 모델 차이
    • Java 개발자를 위한 Python 심화 — OOP·데코레이터·컨텍스트 매니저
    • PyTorch 기초 — 텐서, 디바이스, 그리고 모델 로딩이 무거운 이유
    • Java 개발자를 위한 Python 문법 핵심
    • ML 서비스 성능 분석 워크플로 — 자바 백엔드 트러블슈팅과 다른 점
    • OCR 동작 원리 — Layout · Text · Post-process 3단계
    • Python 서버의 RSS 가 안 줄어드는 이유 — gc.collect 의 한계와 malloc_trim
  • rabbitmq 페이지로 이동
    • [초안] RabbitMQ Basics — 실전 백엔드 관점에서 정리하는 메시지 브로커 기본기
    • [초안] RabbitMQ vs Kafka — 백엔드 메시징 선택 기준과 실전 운영 관점
  • security 페이지로 이동
    • [초안] 시니어 백엔드를 위한 보안 / 인증 스터디 팩 — Spring Security, JWT, OAuth2, OWASP Top 10
    • [초안] Spring Security 6.x OAuth2 + JWT 상용 인증 설계 — Grant 선택, Resource Server, Refresh Rotation, 로그아웃
  • task 페이지로 이동
    • ai-service-team 페이지로 이동
    • nsc-slot 페이지로 이동
    • sb-dev-team 페이지로 이동
    • the-future-company 페이지로 이동
  • testing 페이지로 이동
    • [초안] 시니어 Java 백엔드를 위한 테스트 전략 완전 정리 — 피라미드부터 TestContainers, 마이크로벤치, Contract까지
  • travel 페이지로 이동
    • 오사카 3박 4일 일정표: 우메다 쇼핑, USJ, 난바·도톤보리, 오사카성
  • web 페이지로 이동
    • [초안] HTTP / Cookie / Session / Token 인증 기본기 — 레거시 JSP와 모바일 API가 공존하는 백엔드 관점
FOS-BLOG · FOOTERall systems normal·v0.1 · 2026.04.27·seoul, kr
Ffos-blog/study

개발 학습 기록을 정리하는 블로그입니다. 공부하면서 기록하고, 기록하면서 다시 배웁니다.

visitors
01site
  • Home↗
  • Posts↗
  • Categories↗
  • About↗
02policy
  • 소개/about
  • 개인정보처리방침/privacy
  • 연락처/contact
03categories
  • AI↗
  • Algorithm↗
  • DB↗
  • DevOps↗
  • Java/Spring↗
  • JS/TS↗
  • React↗
  • Next.js↗
  • System↗
04connect
  • GitHub@jon890↗
  • Source repositoryjon890/fos-study↗
  • RSS feed/rss.xml↗
  • Newsletter매주 1 회 · 한 편의 글→
© 2026 FOS Study. All posts MIT-licensed.
built with·Next.js·Tailwind v4·Geist·Pretendard·oklch
fos-blog/python/Python 의존성 관리 — Java Mav…
system

Python 의존성 관리 — Java Maven/Gradle 사용자가 만나는 첫 충격

자바 백엔드만 다뤄오다가 Python 프로젝트를 처음 받았을 때 가장 황당했던 게 의존성 관리였다. Maven 이면 pom.xml 한 파일, Gradle 이면 build.gradle 한 파일에서 의존성·빌드·플러그인이 다 처리된다. Python 프로젝트는 다음 파일이 섞여 있어 어디서부터 봐야 할지도 모르겠다. - requirements.txt - pypr...

2026.05.19·7 min read·15 views

자바 백엔드만 다뤄오다가 Python 프로젝트를 처음 받았을 때 가장 황당했던 게 의존성 관리였다. Maven 이면 pom.xml 한 파일, Gradle 이면 build.gradle 한 파일에서 의존성·빌드·플러그인이 다 처리된다. Python 프로젝트는 다음 파일이 섞여 있어 어디서부터 봐야 할지도 모르겠다.

  • requirements.txt
  • pyproject.toml
  • setup.py
  • Pipfile

게다가 pip install 한 줄로 시작하면 전역 환경이 오염되고, venv 가 등장하면서부터 다른 글이 또 필요하다.

이 글은 자바 개발자가 Python 의존성 도구 풍경을 빠르게 따라잡기 위한 노트다. 2026 년 기준으로 정리하면 결론은 uv 하나면 거의 다 된다.

venv 가 왜 필요한가 — Java 와 결정적으로 다른 점

자바는 의존성이 프로젝트 단위로 격리된다. Maven 은 ~/.m2/repository 에 모든 버전을 다 저장하고, 빌드 시점에 pom.xml 이 가리키는 버전만 클래스패스에 올린다. 같은 머신에 프로젝트 A 는 Spring 5, 프로젝트 B 는 Spring 6 가 있어도 충돌이 없다. JVM 이 시작될 때 정확한 jar 만 로딩하기 때문이다.

Python 은 다르다. pip install requests 를 그냥 실행하면 시스템 Python 또는 사용자 홈 Python 의 site-packages 에 전역 설치된다. 프로젝트 A 가 requests 2.28 를 쓰고 B 가 2.32 를 쓰면, 나중에 설치한 쪽이 이전 쪽을 덮어쓴다. Maven 으로 치면 ~/.m2 에 같은 패키지의 한 버전만 살아 있는 셈.

이걸 해결하려고 virtual environment 가 들어왔다. 프로젝트마다 별도 디렉터리(.venv/) 를 만들고 그 안에 Python 인터프리터 사본과 의존성을 격리해 둔다. 자바로 치면 프로젝트마다 별도 ~/.m2 를 두는 셈인데, 디스크는 좀 먹지만 격리는 확실하다.

bash
python -m venv .venv         # .venv 생성
source .venv/bin/activate    # 활성화 (PATH 가 바뀜)
pip install requests         # 이제 .venv 안에 설치됨

activate 가 PATH 를 조작해서 python / pip 명령이 .venv/bin/ 의 바이너리를 가리키게 한다. 셸이 닫히거나 deactivate 를 부르면 원래 PATH 로 돌아간다.

pip 와 uv — 자바의 mvn/gradle 같은 명령들

pip 는 Python 의 기본 패키지 인스톨러다. Maven 의 mvn install 자리에 가깝다. 단 pip 는 가상환경 자체를 만들지는 않는다. venv 모듈이 환경을 만들고, pip 는 그 안에 패키지를 설치한다. 둘이 분리되어 있다.

bash
python -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt

이게 전통적 패턴이다. 단 느리다. 우리가 분석한 프로젝트의 requirements.txt 는 torch 2.7.1, paddleocr, docling 같은 수 GB짜리 패키지를 끌어와서 pip 로 받으면 첫 설치만 5-10분이 걸리기도 한다.

여기 등장한 것이 uv 다. Rust 로 작성된 의존성 매니저로, Python 패키지 매니저 진영의 게임을 바꿔놓았다. pip 대비 10-100배 빠르고, 캐시·병렬 다운로드·러스트 기반 의존성 해결자를 갖췄다. 자바에서 Maven → Gradle 로 넘어갔을 때의 속도 향상보다 더 극적이다.

uv 의 진짜 강점은 하나의 도구가 여러 역할을 흡수한다는 점이다.

자바Python 전통Python with uv
sdkman (JDK 버전 관리)pyenv, asdfuv python install 3.11
mvn/gradle (의존성)pipuv pip install
(없음, JVM 자체 격리)python -m venvuv venv
pom.xml/build.gradle (메타데이터)pyproject.tomluv 가 직접 해석
pom.xml lock (Maven 4)pip freeze > requirements.txtuv.lock 자동 생성
mvnw/gradlew (래퍼)(관례 없음)uvx 가 일회성 실행

pyenv + venv + pip + pip-tools 네 도구가 하던 일을 uv 한 명령이 한다. 자바 개발자가 Maven 하나로 의존성·빌드·라이프사이클을 처리하던 감각과 비슷해진다.

requirements.txt vs pyproject.toml — pom.xml 의 자리

자바에서 pom.xml 은 두 역할을 한 파일에서 한다. 의존성 선언과 프로젝트 메타데이터. Python 은 둘이 분리되어 왔다.

requirements.txt 는 단순한 패키지 목록이다. pip freeze 결과를 그대로 받는 형태가 많다.

text
torch==2.7.1
torchvision==0.22.1
fastapi==0.115.9
docling==2.52.0
paddleocr==3.3.2

장점: 단순함. CI/CD 에서 pip install -r requirements.txt 한 줄. 한계: Python 버전 제약을 명시할 곳이 없고, dev/prod 분리하려면 requirements-dev.txt, requirements-test.txt 파일을 추가로 만들어야 한다. 의존성 트리도 안 보인다.

pyproject.toml 은 자바 pom.xml 의 Python 버전이다. 표준 (PEP 621) 으로 정의되어 의존성·메타데이터·툴 설정 (black, ruff, pytest 등) 이 한 파일에 모인다.

toml
[project]
name = "doc-parser"
version = "2.2.0"
requires-python = ">=3.11"
dependencies = [
    "torch>=2.7,<2.8",
    "fastapi>=0.115",
    "docling>=2.52",
]
 
[project.optional-dependencies]
dev = ["pytest", "ruff", "mypy"]
 
[tool.uv]
lockfile = "uv.lock"

자바 Maven 의 <dependencies> + <properties> + <build><plugins> 가 한 파일에 들어가는 그림. dev 의존성은 optional-dependencies 로 분리해 uv sync --extra dev 처럼 선택 설치.

lock 파일 — Maven dependency:resolve 의 자동화

Maven 은 빌드할 때마다 의존성 트리를 다시 푼다 (resolve). 그래서 같은 코드라도 빌드 시점에 따라 transitive dependency 가 살짝 달라질 수 있다. Maven 4 에서 lockfile 이 정식 도입되어 이 문제를 해결하기 시작했지만, Gradle 도 dependency-locking 을 명시적으로 켜야 동작한다.

Python 의 pip freeze 는 사실상 수동 lock 이다. 개발자가 환경을 다 세팅한 뒤 pip freeze > requirements.txt 로 현재 버전을 박제하는 방식. 까먹으면 다른 사람과 환경이 어긋난다.

uv 는 uv.lock 을 자동 생성·갱신한다. uv add fastapi 한 줄이면 pyproject.toml 에 fastapi 를 추가하고 uv.lock 에 transitive 까지 박힌다. Gradle 의 --write-locks 가 자동으로 켜져 있는 셈.

bash
uv add fastapi              # pyproject.toml + uv.lock 동시 갱신
uv sync                     # 락 그대로 .venv 에 설치
uv sync --frozen            # 락 변경 안 됨 보장 (CI 권장)

자바 Gradle 의 ./gradlew dependencies --update-locks 처럼 명시적 명령이 필요하지 않다.

실제로 셋업하면서 마주친 함정들

Mac 에서 이 프로젝트의 로컬 개발 환경을 세팅하면서 부딪힌 것들을 그대로 기록한다.

asdf 또는 pyenv 로 만든 venv 의 깨진 심볼릭 링크

.venv/bin/python 은 보통 시스템에 설치된 Python 인터프리터로 향하는 심볼릭 링크다. 내가 받은 프로젝트는 과거에 asdf 로 설치한 Python 3.13.9 로 .venv 를 만들었는데, 그 사이 asdf 를 정리하면서 ~/.asdf/installs/python/3.13.9/bin/python 이 사라져 링크가 깨졌다. .venv/bin/python --version 이 "no such file or directory" 로 죽는다.

해결책은 .venv 통째로 다시 만드는 것.

bash
uv venv .venv --clear --python 3.11

--clear 는 기존 디렉터리를 지우고 새로 만든다. --python 3.11 은 uv 가 Python 3.11 을 알아서 다운로드해 박아준다 (없으면 uv python install 3.11 먼저).

uv venv 에는 pip 가 들어 있지 않다

전통적 python -m venv .venv 는 venv 안에 pip 를 같이 깔아준다. 그런데 uv venv 는 기본적으로 pip 를 포함하지 않는다. 빠르게 만들기 위해서다.

bash
.venv/bin/pip install -r requirements.txt
# zsh: no such file or directory: .venv/bin/pip

이 메시지 처음 봤을 때 한참 헤맸다. uv 가 권장하는 방식은 그냥 uv pip install ... 또는 uv add ... 다. uv 자체가 pip 와 동등한 명령을 직접 제공한다.

bash
VIRTUAL_ENV=$(pwd)/.venv uv pip install -r requirements.txt

또는 source .venv/bin/activate 후 uv pip install -r requirements.txt. uv 는 활성화된 venv 를 자동 인식한다.

Apple Silicon 에서 CUDA 패키지

이 프로젝트의 운영 환경은 NVIDIA T4 GPU. Mac M-series 는 CUDA 를 지원하지 않는다. requirements.txt 가 torch==2.7.1 만 박혀 있으면 Mac 에서는 자동으로 MPS (Metal Performance Shaders) 빌드를 받는다. pynvml 같은 NVIDIA 전용 라이브러리는 import 자체는 되지만 런타임에 사용할 일이 없다 (워닝만 뜬다).

paddlepaddle 도 Mac M-series 용 빌드가 한정적이라 Dockerfile 에서는 별도 인덱스로 paddlepaddle-gpu 를 설치하고 Mac 에서는 paddlepaddle (CPU) 만 받는다. 운영과 로컬의 의존성 분리 지점.

자바 개발자 입장에서 "JVM 은 어디서든 똑같이 도는데" 와 비교되는 부분. Python ML 라이브러리는 OS·아키텍처·GPU 종류에 따라 휠 (wheel) 이 달라진다.

권장 워크플로

자바 백엔드에서 Python 으로 넘어올 때 처음부터 익히면 좋은 명령은 다섯 개다.

bash
# 1. Python 버전 설치
uv python install 3.11
 
# 2. 프로젝트 venv 만들기
uv venv .venv --python 3.11
 
# 3. pyproject.toml 의존성 설치
uv sync
 
# 4. 패키지 추가
uv add fastapi
 
# 5. CI 에서 락 고정한 채 설치
uv sync --frozen

pip install 을 직접 칠 일이 거의 없다. 자바에서 mvn install 만 알면 90% 의 케이스가 처리되는 것과 비슷.

기존 requirements.txt 만 있는 프로젝트라도 uv 가 그대로 읽어준다.

bash
uv pip install -r requirements.txt

이 형태는 점진적 이전 경로다. 새 프로젝트는 처음부터 pyproject.toml 로 시작하는 것을 권장한다.

다음 글로 넘기는 것

이 글은 의존성 도구만 다뤘다. 본격적으로 Python ML 서비스를 다루려면 GPU·CUDA·PyTorch 모델 로딩 비용 같은 인프라 개념이 필요한데, 그건 다음 글에서 정리한다.

자바와 비교했을 때 가장 큰 차이는 다음 한 줄로 요약된다.

자바는 JVM 이 의존성 격리를 책임지고, Python 은 가상환경 + 락파일이 사람의 협업으로 격리를 책임진다.

uv 가 등장하면서 그 사람의 부담이 크게 줄었다. 2026 년 시점이면 새 Python 프로젝트는 uv 부터 깔고 시작해도 후회 없다.

참고

  • uv 공식 문서
  • PEP 621 — Storing project metadata in pyproject.toml
  • Real Python — uv vs pip: Managing Python Packages and Dependencies
  • pydevtools — Why pyproject.toml over requirements.txt
  • DataCamp — Python UV Complete Guide
on this page
  • 01venv 가 왜 필요한가 — Java 와 결정적으로 다른 점
  • 02pip 와 uv — 자바의 mvn/gradle 같은 명령들
  • 03requirements.txt vs pyproject.toml — pom.xml 의 자리
  • 04lock 파일 — Maven `dependency:resolve` 의 자동화
  • 05실제로 셋업하면서 마주친 함정들
  • asdf 또는 pyenv 로 만든 venv 의 깨진 심볼릭 링크
  • uv venv 에는 pip 가 들어 있지 않다
  • Apple Silicon 에서 CUDA 패키지
  • 06권장 워크플로
  • 07다음 글로 넘기는 것
  • 08참고

이런 글도

  • Python 서버의 RSS 가 안 줄어드는 이유 — gc.collect 의 한계와 malloc_trim
    Python 으로 long-running 서버 (FastAPI / Flask / Celery / uWSGI 등) 를 운영하다 보면 한 번쯤 마주치는 증상이 있다. - 워커 프로세스의 RSS 가 시간이 지날수록 단조 증가한다 - 큰 객체를 del 하고 gc.collect() 를 불러도 RSS 가 줄지 않는다 - 결국 max-requests / workerma...
    📁 system
    system
    2026.05.22
  • ML 서비스 성능 분석 워크플로 — 자바 백엔드 트러블슈팅과 다른 점
    이 시리즈의 마무리 글이다. 앞선 글들에서 다음 주제를 자바 백엔드 비교 관점으로 정리했다. - Python 문법 - 의존성 관리 - FastAPI - async/await - GPU·CUDA·MPS - PyTorch - multi-process worker pool - OCR 파이프라인 마지막은 이 모든 개념을 적용해 실제 ML 서비스의 성능을 분석하는...
    📁 system
    system
    2026.05.19
  • OCR 동작 원리 — Layout · Text · Post-process 3단계
    자바 백엔드만 다뤄오다가 OCR (Optical Character Recognition) 서비스를 분석할 일이 생겼다. "이미지에서 글자를 뽑는다" 라는 한 줄 요약은 알았지만, 실제 코드를 열어보면 모델이 둘이상이고, 여러 단계가 직렬·병렬로 엮여 있고, "왜 이 단계가 따로 있지" 같은 의문이 계속 생긴다. 이 글은 OCR 파이프라인의 표준 구조를 정리...
    📁 system
    system
    2026.05.19
  • Multi-process GPU 워크로드 — 자바 ThreadPool 사용자가 만나는 모델 차이
    자바 백엔드에서 ThreadPoolExecutor 는 거의 만능이었다. CPU bound 든 I/O bound 든 스레드 풀 크기만 잘 잡으면 동시성을 챙길 수 있었다. JVM 안에서 메모리를 공유하니 작업 간 데이터 전달도 가볍다. Python ML 서비스는 그림이 다르다. ThreadPoolExecutor 가 있지만 CPU/GPU 작업에서는 거의 안 쓰...
    📁 system
    system
    2026.05.19

댓글 (0)