안녕하세요. 스포카 프로그래머 홍민희입니다.

파이썬 패키징 생태계에서 개발 환경을 구성하기 위해 널리 쓰이는 virtualenv나 pyvenv, virtualenvwrapper 같은 각종 도구가 왜 필요한지 (또는 자신에게는 큰 도움이 안 되는지) 알려면 그 이전의 파이썬 라이브러리 배포 방식에 대한 이해가 많은 도움이 됩니다. 여기서는 필요한 몇 가지 역사적 사실과 파이썬 패키징 개념 중 현재의 생태계 이해에 필요한 것들을 위주로 정리하고, 최종적으로 각자의 필요에 따라 어떤 도구를 활용하면 될지 지침을 제안합니다.

정읍출장맛사지┵예약금없는출장샵⇛정읍응암동 마사지「정읍목포 안마방」✖[정읍감성 마사지]⇀정읍부산마사지╆정읍양평 마사지☞정읍천안안마☆정읍부산 연산동 출장╚정읍남성전용마사지

패키징이고 뭐고 아무것도 없던 90년대 말에는 라이브러리 소스 코드 파일들을 타르볼(tarball)로 압축해서 배포했습니다. 쓰는 사람은 그걸 자신의 애플리케이션 소스 트리 안에 풀어서 사용했습니다.

파이썬에는 지금도 천안출장샵 라는 인터프리터 전역적인 상태가 존재합니다. PATH 환경 변수가 실행 바이너리를 찾을 디렉터리 경로들의 목록인 것과 비슷하게, sys.path서울 오피스텔 마사지대전출장안마출장부르는법 import foo 를 하면 foo.py (또는 foo/__init__.py) 파일을 찾을 디렉터리 경로들의 목록을 담습니다. 그리고 기본 동작으로 그 목록의 맨 처음에는 현재 디렉터리(./)가 들어갑니다. 따라서 라이브러리 타르볼을 애플리케이션 소스 트리에 풀어두면 import 해서 쓸 수 있습니다.

하지만 자신이 작성한 애플리케이션 코드와 남이 작성한 라이브러리 코드를 같은 소스 트리에서 관리하는 것은 여러모로 불편합니다. 따라서 라이브러리는 애플리케이션 소스 트리와는 별도의 디렉터리(예: ../libs/)에 풀어서 관리하고, 애플리케이션 소스 코드 맨 위에 아래와 같이 써두는 패턴이 많았습니다.

import sys
sys.path.append고령양재역 안마방군산출장샵정읍낙성대 마사지정읍출장맛사지대전출장샵출장부르는법정읍출장맛사지구미출장안마정읍여성 전용 아로마 마사지☻정읍성대 마사지⇆〔정읍안마방 초이스.mp4〕정읍음경 마사지✍정읍홈 타이 마사지♗정읍동해 마사지☢정읍지저분한 섹스 나고야 여성 마사지エ목포안마방 핸드폰정읍주안 안마방정읍출장맛사지예약정읍군포 마사지정읍안마방 애널정읍안마방 지명녀↺정읍서울 출장 마사지▥﹝정읍동대문 안마방﹞정읍나무위키 안마방➛정읍안마방 미시☈정읍예약금 없는 출장 샵ウ정읍안마방 움짤▲예약금없는출장샵정읍광교 마사지▒정읍미금역 안마방☌‹정읍출장 안마›정읍안마방 지명녀⇍정읍순천 안마방]정읍야 동 마사지✃정읍천안 출장╓출장부르는법출장부르는법정읍안마방 투샷☵정읍동남아 마사지╈﹛정읍고관절 마사지﹜정읍호치민 리버티 마사지♭정읍엉덩이 마사지▨정읍마사지 출장➳정읍에이미 성인╉정읍눈 마사지 기계천안진주시 안마방('../libs')

또는 sys.path 를 소스 코드를 건드리지 않고 조작하기 위해 담양이반 마사지 를 활용하는 경우가 많았습니다.

세기말, 파이썬 1.5를 쓰던 때의 이야기입니다.

정읍출장맛사지◊24시출장샵㍿정읍응암동 마사지「정읍철구 마사지」╃[정읍영등포 안마방]┷정읍안마방 내상☵정읍단양 안마방┍정읍춘천 모텔 가격λ정읍천호동 마사지➳정읍오피

새 천 년이 밝았고 파이썬 2.0이 나왔습니다. 표준적인 라이브러리 배포 방식 및 설치 방식이 제안되었고, 표준 라이브러리에 동두천기획 마사지 도 들어왔습니다. (지금도 setuptools distutils 에 의존하고, pip는 setuptools

  • 정읍출장맛사지
  • 정읍안마방 내부
  • 정읍출장맛사지
  • 예약금없는출장샵
  • 에 의존합니다.) 제안된 방식은 이랬습니다.

    애플리케이션 코드가 아닌 라이브러리 소스 코드는 모두 /usr/local/lib/python X.Y /site-packages/ 디렉터리 안에 둡니다. X.Y 는 파이썬 인터프리터 버전이고, 경로는 인터프리터를 빌드할 때 ( ./configure ) 정합니다. 데비안 계열은 site-packages 대신 dist-packages라는 이름으로 바꿔서 빌드하는 등, 파이썬 인터프리터의 설치 방식에 따라 달라집니다. 어떻게 정하든 이를 site-packages 디렉터리라고 부릅니다. 파이썬 인터프리터를 빌드할 때 경로가 결정되므로, 파이썬 인터프리터 별로 각자의 site-packages 디렉터리를 갖게 됩니다. (한 시스템에서 여러 파이썬 버전을 설치했을 때 pip 역시 pip2.7 , pip3.6 등과 같이 버전 별로 명령어가 생기는 것도 같은 이유입니다.)

    기본적으로 sys.path 목록에는 맨 앞에 현재 위치(./), 뒤쪽에는 site-packages 경로가 들어있습니다. import 를 하면 현재 위치에서 찾고, 없으면 site-packages를 찾아본다는 뜻입니다.

    정읍출장맛사지⇚예약금없는출장샵┆정읍응암동 마사지「정읍건전한 마사지」╡[정읍서울 마사지 홈 서비스]✖정읍호텔 출장★정읍부산대 안마방⇪정읍서정리 안마방オ정읍출장서비스♜정읍로미 마사지

    표준 라이브러리의 distutils.core.setup() 함수는 라이브러리 파일들을 시스템의 site-packages 디렉터리에 복사해주는 함수입니다. 라이브러리 타르볼 파일 맨 바깥에는 이 함수를 이용해 라이브러리를 시스템 site-packages에 설치해주는 스크립트를 setup.py라는 파일명으로 포함하는 관례가 있었습니다. pip 같은 게 없던 때에는 라이브러리 타르볼을 받아서 푼 다음 원주출장샵 을 실행하는 것이 일반적인 라이브러리 설치법이었습니다. 지금도 pip 는 *.whl 파일이 아닌 *.tar.gz/*.zip 파일인 패키지를 설치할 때 내부적으로 python setup.py install 스크립트를 실행합니다.

    참고로 이때 정립된 파이썬 패키징 표준은 리눅스에서 쓰이는 장수상암동 안마방순창천안 마사지 ㅁㅁㄹ 같은 일반적인 패키징 방식을 의식하며 만들어졌습니다. 서울 광명 안마방 당시는 도커는 커녕 가상화 자체가 보편적이지 않던 때로, 한 시스템에 여러 애플리케이션을 함께 설치해서 쓰는 대전출장안마 이 일반적이었기 때문입니다.

    정읍출장맛사지➥예약금없는출장샵↼정읍응암동 마사지「정읍셀룰라이트 마사지」○[정읍연신내 마사지]♖정읍모유수유 마사지▽정읍장한평 안마방☞정읍송탄 안마방★정읍ace anma▨정읍카메라 마사지창원출장샵정읍안마방 avi↥정읍전효성 마사지▪【정읍출장서비스】정읍화명동 마사지﹄정읍서울대입구 마사지♬정읍쿠알라룸푸르 마사지✓정읍삼산동 출장⊙qdomain.xyzbitsnoop.xyz24시출장샵24시출장샵단양교대 안마방정읍출장맛사지예약정읍출장여대생 정읍안마방 핸드폰✖〔정읍관평동 마사지〕정읍타이 마사지 후기⇥정읍여성 마사지 후기➵정읍신사역 안마방♚정읍천안 출장┗바카라사이트문경안마방 조루전주출장안마고령아로마마사지 팁정읍출장맛사지정읍출장맛사지정읍출장맛사지정읍평택 모텔 가격┚정읍나고야 여성전용 마사지↟【정읍실제 일본 안마방】정읍마사지 포르노┣정읍안마방 김치남”정읍안마방 짜파게티♫정읍삿포로 안마방⇇김제용산 마사지정읍호텔 출장정읍출장맛사지예약정읍출장맛사지대전출장안마온라인카지노정읍출장맛사지정읍콧대 높이는 마사지♠정읍역삼 안마방↿「정읍인계동 마사지」정읍상암동 안마방└정읍광안리 안마방フ정읍대만 마사지♗정읍안마방 후기♡

    정읍출장맛사지┗24시출장샵├정읍응암동 마사지「정읍대전 모텔 가격」╚[정읍합정 마사지]‿정읍감성마사지 뜻➺정읍울산 삼산동 안마방▨정읍ace anma┏정읍마산 모텔 추천◊정읍안마방 초이스 torrent

    파이썬으로 작성한 애플리케이션 여럿이 한 시스템에 설치되면 공통으로 의존하는 라이브러리의 버전을 결정하는 게 문제가 됩니다. A 애플리케이션은 foo >= 1.0.0, < 2.0.0 에 의존하고 B 애플리케이션은 foo >= 1.5.0 에 의존하면 시스템에 설치할 수 있는 foo의 버전은 >= 1.5.0, < 2.0.0 으로 한정됩니다. 만약 C 애플리케이션을 설치하려는데 foo > 2.0.0 에 의존한다면, A나 C 중 하나는 포기해야 합니다.

    시스템에 파이썬 애플리케이션을 단 하나만 설치한다 해도, 설치하는데 시스템 관리자 권한이 필요하다는 것도 문제였습니다. 일반적으로 site-packages 디렉터리는 시스템 관리자만 수정할 수 있고 나머지는 읽기만 가능한 /usr 아래 어딘가로 정해졌기 때문입니다. 이를 우회하려고 사용자가 시스템에 설치된 파이썬 인터프리터를 쓰지 않고 직접 파이썬 인터프리터를 빌드해서 사용하는 편법도 쓰였습니다.

    이런 문제를 해결하기 위해, 애플리케이션·프로젝트마다 별도의 site-packages 디렉터리를 두는 방식이 제안됐습니다. 나중에 virtualenv을 만들게 되는 전주출장샵 이 그 전신인 파주출장여대생 를 만들어 이 아이디어를 실현했습니다. 현재의 virtualenv 사용 방식은 workingenv에서 만들어진 것입니다.

    workingenv가 만들어주는 활성화 스크립트는 PATH 와 <정읍콜걸추천> 환경 변수를 재정의하여 시스템에 설치된 파이썬 인터프리터의 실행 바이너리 디렉터리 및 site-packages 디렉터리를 가리키는 대신, “환경” 내의 bin/ 및 site-packages 디렉터리를 바라보도록 해줍니다. 이안 비킹은 이렇게 분리된 실행 파일들(bin/)과 site-packages 등을 묶어서 “환경”이라고 명명했는데, workingenv 이후로 파이썬 패키징 및 배포 분야에서 이 용어가 정착됩니다.

    최근에 만들어진 신생 언어의 패키지 관리자는 대부분 파이썬과 달리 애플리케이션·프로젝트마다 별도의 환경을 두고 설치되는 경우가 많습니다. 예를 들어 npm 대전출장샵 을 일부러 켜지 않는 한 현재 디렉터리를 기준으로 ./node_modules 디렉터리에 라이브러리를 설치하게 되어 있고, 별도의 “활성화” 없이도 노드 인터프리터가 해당 경로에서 라이브러리를 찾습니다. 하지만 파이썬의 패키징 표준은 앞서 언급한 것처럼 멀티테넌시 환경이 일반적이었던 시대에 만들어졌고, 또 많은 라이브러리가 실행 파일도 함께 제공하기 때문에 인천일본 보빨 PYTHONPATH 뿐만 아니라 PATH정읍안마방 아영이 토렌트완주마사지 레전드정읍출장맛사지예약금없는출장샵정읍갑상선 마사지정읍제주도 안마방85me.xyz정읍출장맛사지정읍출장맛사지출장부르는법카지노사이트바카라사이트정읍마사지 사이트의왕논산 안마방부여안마방 숙박무주여성 전용 마사지정읍베이징 안마방정읍부평 에이스 안마방정읍문산 안마방정읍예약금 없는 출장ロ정읍중국전통마사지オ「정읍안마방 초이스 torrent」정읍가산 마사지큐정읍대전 안마방 추천♀정읍대구 서구 안마방┷정읍대만 마사지♐예약금없는출장샵정읍기흥구청 마사지▪정읍상대보호구역◑[정읍전립선 마사지]정읍마사지 발기↮정읍강남역 마사지μ정읍안마방 짜파게티유정읍수유역 마사지♨예약진해광주 안마방 추천정읍출장맛사지정읍대구 모텔 촌카지노사이트군산출장안마군산출장안마동인천강서 안마방예약정읍출장맛사지 환경 변수도 재정의해야 해서 activate 과정이 필요합니다.

    예약

  • 정읍강남 안마방 추천╓정읍제주시청 마사지↺[정읍모텔 걸]정읍서울샵▨정읍잇몸 마사지╠ 정읍정준하 마사지♜정읍화곡 마사지╌
  • 정읍마사지 토렌
  • 24시출장샵
  • 정읍일본 av 마사지⇥정읍마사지 단속 시간↶[정읍김포 타이 마사지]정읍대구 모텔 가격ⓔ정읍아주대 안마방⊙정읍대학동 마사지╯정읍마사지 종류⇢정읍출장맛사지
  • 출장부르는법
  • 무엇보다 workingenv는 프로그래머가 여러 프로젝트를 동시에 작업하는 경우 골치 아팠던 라이브러리 버전 충돌 문제를 우회했기 때문에, 배포 도구보다는 개발 도구로 정착되는 면이 컸습니다.

    정읍출장맛사지╩24시출장샵✙정읍응암동 마사지「정읍코 마사지 효과」◑[정읍와이프 마사지]█정읍출장연애인급⇁정읍최음제 마사지☰정읍안마방 무한♗정읍오산 타이 마사지☃정읍노량진 안마방

    이안 비킹은 PYTHONPATH 를 조작하여 별도의 site-packages 공간을 두는 workingenv의 방식이 복잡하게 패키징된 기존 라이브러리 및 프로젝트에서 호환되지 않는 문제로 골머리를 썩이다, 아예 PYTHONPATH 를 이용하지 않는 방식으로 새 도구를 만듭니다.

    새로운 방식은 아예 파이썬 인터프리터 실행 바이너리를 복사한 뒤, sys.path 기본값에 박힌 시스템 site-packages 경로를 환경 내 site-packages 경로로 바꿔버리는 것이었습니다. 이러한 동작 원리의 차이는 이용자 입장에서 크게 중요한 것은 아닙니다.

    하여튼 이안 비킹은 군산출장안마 라는 이름으로 새 도구를 만들었고, workingenv를 빠르게 대체했습니다.

    정읍출장맛사지η출장부르는법☈정읍응암동 마사지「정읍부산 안마방 가격」∴[정읍출장 오피]➷정읍모텔 전화☂정읍포승 마사지ヌ정읍건대 마사지✡정읍대전 안마방┏정읍정준하 마사지

    앞서 언급한 것처럼, workingenv와 그 후계자인 virtualenv는 저자의 의도와 무관하게 애플리케이션 배포보다는 개발 용도로 더 널리 쓰입니다. 파이썬 프로그래머가 새로운 프로젝트를 시작할 때는 항상 “환경”도 생성합니다. 또 개발을 시작할 때마다 “활성화” 과정도 거칩니다. 너무나 반복적이기 때문에 당연히 이를 자동화하는 도구도 만들어졌습니다. 마산구미 여관 는 바로 그런 목적으로 만들어진 bash/zsh/fish 스크립트 모음입니다.

    여러 단축 명령을 제공하지만, 핵심 기능은 다음의 두 가지입니다.

    • A라는 프로젝트 작업을 시작할 때마다 cd ~/projects/a; . .venv/bin/activate 라고 쳐줘야 했던 것을 workon a창원마사지 사진정읍불광 여관☌정읍신림동 마사지◤【정읍출장 모텔】정읍서혜부 마사지 란♩정읍안마방 터치♥정읍인천 안마방ホ정읍범계 마사지☭24시출장샵정읍봉담 마사지チ정읍이동국 안마방╔﹛정읍광주 여관﹜정읍kcm 안마방↕정읍실제 안마방α정읍트랜스젠더 안마방✣정읍부산 모텔☊강진테니스공 마사지 명령으로 줄여줍니다.

    • 프로젝트 디렉터리마다 .venv/ 또는 .env/ 등의 이름으로 환경 디렉터리를 생성해두고 버전 관리 시스템에서는 제외되도록 .gitignore 목록에 해당 디렉터리를 넣었어야 했습니다. 예를 들어 ~/projects/a/.venv/, ~/projects/b/.venv/ 같은 식이었습니다.

      virtualenvwrapper를 쓰면 환경 디렉터리들을 일정한 위치로 모아줍니다. 위치는 기본값이 없으며 virtualenvwrapper 설치할 때 WORKON_HOME 환경 변수를 통해 입맛대로 정할 수 있습니다. 예를 들어 WORKON_HOME 을 ~/.virtualenvs/ 디렉터리로 정했다면, 프로젝트별 환경은 ~/.virtualenvs/a/, ~/.virtualenvs/b/ 같은 식으로 저장됩니다.

    정읍출장맛사지♠예약➽정읍응암동 마사지「정읍야동 마사지」▤[정읍스웨디시 마사지]♪정읍부산 안마방 추천◄정읍구글 재펜☂정읍안마방 대화┫정읍최음제 마사지〓정읍오일 마사지 av

    통영연동 안마방 환경을 만드는 명령어는 virtualenv 가 아닌 pyvenv 로 좀 다르지만, 그 이후의 과정은 같습니다. 파이썬 3만 사용한다면 이제 virtualenv를 따로 설치할 필요가 없어진 것입니다.

    참고로 아래에서 설명할 pyenv와는 다른 도구입니다. 철자의 “v”에 주의해주세요.

    정읍출장맛사지☭출장부르는법☀정읍응암동 마사지「정읍일본 안마방」╝[정읍지저분한 색스 나고야 여성 전용 마사지]♔정읍체코 마사지 fc2∷정읍가산 안마방♦정읍사타구니 마사지♪정읍마사지 하드☼정읍천안 출장

    애플리케이션을 개발할 때는 하나의 파이썬 버전을 정하면 되지만, 라이브러리는 여러 파이썬 버전과 호환되어야 합니다. 그러다 보니 라이브러리 개발자는 여러 버전의 파이썬을 시스템에 동시에 설치할 필요가 있습니다. 함양광주 안마방 후기김포콜걸샵 같은 것을 이용해서 설치할 수도 있지만, 보통은 카지노사이트 를 많이 씁니다.

    pyenv는 동시에 여러 버전의 파이썬을 시스템에 설치해주며, 이렇게 설치된 파이썬은 시스템의 패키지 시스템(데비안·우분투의 APT 나 맥OS의 홈브루 등)을 통해 설치되는 것이 아니라, pyenv가 다운로드와 빌드 및 설치를 직접 하여 별도로 관리합니다. 설치된 파이썬들은 정읍성대 마사지 에 따라 일정한 형식으로 이름지어진 명령어(예: python2.7 , python3.6 )로 실행할 수 있게 됩니다.

    또한, 여러 파이썬 버전 중에 하나의 시스템 기본 파이썬 버전도 선택 가능하며, 특정 프로젝트 디렉터리 안에서만 기본 파이썬의 버전이 달라지게 할 수도 있습니다.

    정읍출장맛사지⊕예약금없는출장샵↺정읍응암동 마사지「정읍영통 마사지 ㅁㅁㄹ」⊙[정읍안마방 무료야동]☼정읍칠곡 마사지⇛정읍안동 안마방♘정읍목포 마사지유정읍범일동 마사지ネ정읍천안 만남

    pyenv가 여러 파이썬 버전을 동시에 설치해주기는 하지만, 그렇다고 자동으로 site-packages가 프로젝트마다 격리되는 것은 아닙니다. 예를 들어 pyenv로 파이썬 3.6을 설치한 뒤, 파이썬 3.6으로 두 프로젝트를 한 시스템에서 개발할 경우 두 프로젝트는 시스템 site-packages를 함께 쓰게 됩니다.

    따라서 pyenv를 쓰더라도 virtualenv는 따로 써야 하는데, 따로 사용할 수도 있지만 원주출장샵 를 쓰면 pyenv virtualenv 명령으로 프로젝트에 쓸 파이썬 버전 지정과 가상 환경 생성을 한 번에 할 수 있게 됩니다.

    비슷하게 pyenv와 virtualenvwrapper를 통합해주는 대전출장샵 같은 도구도 있습니다.

    정읍출장맛사지↤예약↼정읍응암동 마사지「정읍미약 마사지」❤[정읍출장 보증금]↸정읍시엠립 밤문화 마사지✲정읍국산 안마방 몰카▌정읍[한국]새로운 안마방 아가씨.wmv.torrent➷정읍태국 출장 마사지░정읍공유 마사지

    평창부평 에이스 안마방

  • 원주거제 안마방 추천
  • 예약금없는출장샵옥천별내 마사지
  • 인천여수 안마방
  • 정읍아로마마사지 팁♯정읍평촌 마사지ヒ[bracketl18]정읍군산 마사지[bracketr18]정읍인계동 마사지™정읍태국 마사지 썰▥정읍서울 출장샵╍정읍울산 안마방┳
  • 정읍출장맛사지
  • 정읍타이 마사지┷정읍강남 왁싱샵☁「정읍호치민 호텔 마사지」정읍콧대 높이는 마사지┡정읍출장소이스█정읍정선 사북 마사지╄정읍마사지 출장↜
  • 정읍출장맛사지
  • 정읍출장맛사지
    1. 파이썬으로 만든 애플리케이션을 distutils

    2. 대구출장샵
    3. 정읍출장맛사지
    4. 정읍출장맛사지
    5. 24시출장샵
    6. 를 통해 패키징한 뒤, RPM 기반의 리눅스 배포본 용으로 장수아중리 안마방 을 통해 *.rpm 파일을 제공하기도 했습니다. 이를 통해 애플리케이션을 설치할 경우, 각 파일들은 리눅스 카지노사이트 표준과 해당 시스템 설정에 따라 흩어지게 됩니다. 거창장전동 마사지

    7. 예를 들어 파이썬에서 가장 많이 쓰이는 국제화 라이브러리인 동두천강서 마사지 pybabel 명령어를, 구문 강조 라이브러리인 수원안마방 시간제 pygmentize 명령어를, 안동안마방 스킬 django-admin 명령어를 제공합니다. 서귀포호치민 리버티 마사지

    8. 저는 2017년 4월에 한 번 써보았으나, 아직은 실무에서 쓰기에는 이르다는 결론을 내렸습니다. 이에 관한 그때의 제 감상은 별도의 글 로 다루었습니다. 청양안마방 서울

    정읍서양 마사지◐정읍안마방 못쌈♣【정읍출장소이스홍성】정읍유흥 마사지◆정읍스포츠 마사지 자격증囍정읍연산동 마사지➡정읍천안역 근처 모텔☼전주출장샵정읍출장맛사지정읍양구 안마방구례노모 마사지정읍출장맛사지구례수지 안마방진도창원 출장 마사지전주출장안마정읍마사지 영어로┰정읍강서구청 안마방▫﹛정읍고현 안마방﹜정읍타이 마사지 썰✑정읍손목 마사지➴정읍얼굴 경락 마사지☠정읍마산 안마방☪임실안마방 가는법정읍익산 안마방➴정읍미시 마사지▥[정읍소프 마사지]정읍부평 안마방ナ정읍육덕 마사지§정읍칠곡3지구 마사지⇩정읍신흥 안마방♞고양용산 안마방정읍출장맛사지정읍출장맛사지 웹 프론트엔드에 관심을 가지고 공부하는 디자이너, 뛰어난 서버 개발자 등 각자의 분야에서 전문적인 사람들이 능력있는 분들과 함께 일하기를 기대하고 있습니다. 상주조건 카톡 페이지를 확인해주세요!

    jnice09-ipp30-wq-zq-0459