티스토리 뷰

발생일: 2013.02.17

문제:
PATH 정보를 조회해보니, git과 관련된 bin 디렉토리가 경로의 마지막에 포함되어 있다.

  $ echo $PATH
  ..(중략)..:/usr/local/git/bin

얼마 전 .bash_profile을 정리하면서,
추가적으로 정의하는 PATH 경로는 아래처럼 PATH의 앞 부분에 추가하도록 했었다.
  $ export PATH=새패스:$PATH

어딘가에서 추가되었다면 앞 부분에 있는 게 당연한데,
마지막에 정의되어 있는 것이 이상해 어디서 정의됐는지 파일을 뒤적여봤다.
그리고, /etc/paths.d/git 파일에 정의되어 있는 걸 발견했다.

/etc/paths.d 는 처음 들어 생소한 데다,
/etc/paths 도 자세히 확인해본 적이 없어 잘 모르겠다.

/etc/paths와 /etc/paths.d 의 차이가 뭘까?
PATH는 어떻게 초기화되고 있는 걸까?


해결책:

두 파일 모두 시스템의 초기 PATH를 정의하기 위한 목적으로 사용된다.

/etc/paths 를 조회해보면 각 경로가 아래처럼 라인 단위로 정의되어 있는데,

  /usr/bin
  /bin
  /usr/sbin
  /sbin
  /usr/local/bin

위에서부터 순서대로 각 라인 단위로 PATH 변수에 추가된다.

  /usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin

처럼 말이다.


/etc/paths.d 는 디렉토리다.
여기에 초기화 시 필요한 PATH를 파일 단위로 추가할 수 있고,
각 파일에 정의되어 있는 경로가 마찬가지로 라인 단위로 PATH 변수에 추가된다.

/etc/paths.d 에 여러 파일이 존재한다면,
파일 이름의 오름차순 순으로 추가된다.

PATH 경로에 /usr/local/git/bin 이 추가되어 있었던 이유는,
/etc/paths.d/git 파일 내에 해당 경로가 포함되어 있었기 때문이다.


하지만, 사실 /etc/paths 가 시스템의 초기 PATH 정보를 가지고 있는 건 아니다.
직접 /etc/paths 파일을 삭제해보거나 수정해보면 알 수 있는데,
파일을 삭제하더라도 시스템의 중요 경로는 PATH 변수에 정의되어 있다.
(테스트 해보려면, 어드민 권한으로 paths를 삭제하고 새 터미널을 띄워보면 된다)


PATH가 초기화되는 방식을 여러모로 확인해봤다.
맥 OS X 레오파드부터는, /usr/libexec/path_helper 에서부터 PATH가 설정되는데,
전체적인 프로세스는 아래와 같다. (라고 추측한다)

  1. 로그인 쉘이 시작되면 /etc/profile 을 실행한다.
  2. /etc/profile 에서는 /usr/libexec/path_helper 를 실행한다.
  3. path_helper는 /etc/paths 로부터 초기 PATH를 설정한다.
      한 라인 당 하나씩 순서대로 추가한다.
  4. 다음으로 /etc/paths.d 디렉토리에 있는 각 파일로부터 PATH를 설정한다.
      파일 이름의 오름차순 순으로, 각 파일에 정의된 순서대로 추가한다.
  5. 만약, 시스템에 필요한 중요한 경로가 PATH에 누락되어 있다면 추가한다.
      이 떄, 이미 추가되어 있는 것들을 제외하고 추가한다.
      /usr/bin:/bin:/usr/sbin:/sbin 가 PATH에 추가된다.


5번의 항목은, /etc/paths 를 삭제하거나 수정해보면 테스트해볼 수 있는데,
/etc/paths 에서 중요 경로가 누락된 경우, 아래와 같이 초기화된다.

  /etc/paths에서 설정한 경로:/etc/paths.d에서 설정한 경로:중요 경로 중 누락된 것


따라서, 실제 초기화 시점의 PATH를 변경하고자 한다면,
path_helper가 실행되기 전인 /etc/profile 에서 초기화하는 게 가장 좋은 방법이다.

  



반응형
댓글
공지사항