InfoGrab Docs

Visual Studio Code

요약

이 가이드는 Teleport와 Visual Studio Code의 원격 SSH 확장을 사용하는 방법을 설명합니다. Visual Studio Code Remote - SSH 확장은 로컬 SSH 클라이언트를 사용하여 원격 서버에 접근합니다.

이 가이드는 Teleport와 Visual Studio Code의 원격 SSH 확장을 사용하는 방법을 설명합니다.

작동 방식#

Visual Studio Code Remote - SSH 확장은 로컬 SSH 클라이언트를 사용하여 원격 서버에 접근합니다. Teleport를 사용하여 로컬 SSH 클라이언트에 대한 설정을 생성할 수 있으며, 이 설정은 Teleport가 발급한 OpenSSH 인증서를 사용하여 Teleport로 보호된 Linux 서버에 연결하도록 클라이언트에게 지시합니다.

사전 요구 사항#

  • A running Teleport cluster. If you want to get started with Teleport, sign up for a free trial or set up a demo environment.

  • The `tsh` client.

    Installing \`tsh\` client
    1. Determine the version of your Teleport cluster. The `tsh` client must be at most one major version behind your Teleport cluster version. Send a GET request to the Proxy Service at /v1/webapi/find and use a JSON query tool to obtain your cluster version. Replace with the web address of your Teleport Proxy Service:

      $ TELEPORT_DOMAIN=
      $ TELEPORT_VERSION="$(curl -s https://$TELEPORT_DOMAIN/v1/webapi/find | jq -r '.server_version')"
      
    2. Follow the instructions for your platform to install `tsh` client:

  • OpenSSH 클라이언트.
  • Remote - SSH 확장을 위한 Remote - SSH 확장이 설치된 Visual Studio Code.
  • 하나 이상의 Teleport SSH Service를 실행하는 Teleport Agent. 아직 설정하지 않은 경우, 시작하기 가이드를 읽어 설정 방법을 알아보세요.
Note

Linux 및 macOS 클라이언트는 운영 체제에서 제공하는 OpenSSH 패키지를 사용해야 합니다. Windows 10 클라이언트는 Microsoft의 OpenSSH 가이드를 참조하세요. 구버전 클라이언트는 Git for Windows 또는 Microsoft의 Win32-OpenSSH 프로젝트에서 ssh.exe를 사용할 수 있습니다.

1/3단계. 최초 설정#

Teleport 노드에 접근하도록 로컬 SSH 클라이언트를 설정하세요. 를 Teleport Proxy Service 주소로 바꾸고(Teleport Cloud 사용자의 경우 예: mytenant.teleport.sh), 를 Teleport 사용자로 바꾸세요.

# 프록시에 로그인:
$ tsh login --proxy  --user 

# 프록시에 대한 OpenSSH 설정 생성:
$ tsh config --proxy 

결과로 나온 설정 스니펫을 아래 경로에 있는 SSH 설정 파일에 추가하세요:

$HOME/.ssh/config

%UserProfile%\.ssh\config

Warning

Windows에서 PowerShell을 사용하여 SSH 설정을 작성하는 경우, 일반적인 셸 리디렉션이 잘못된 인코딩으로 파일을 작성할 수 있습니다. 올바르게 작성하려면 다음을 시도하세요:

$ tsh.exe config | out-file .ssh\config -encoding utf8 -append

를 노드에서 사용하려는 사용자명으로 바꾸고 를 노드 이름으로 바꾸어 다음 명령으로 원하는 노드에 연결할 수 있어야 합니다:

$ ssh @.
Teleport Cloud 앞서 생성한 SSH 설정은 SSH 클라이언트가 Teleport 클러스터의 노드에 접근하기 위해 `tsh proxy ssh`를 실행하도록 지시합니다. 그러나 `yourtenant.teleport.sh`의 Teleport Proxy Service에 대해 `ssh` 명령을 실행하면 오류가 발생합니다.
Note

Teleport의 인증서는 상당히 빨리 만료되며, 만료되면 SSH 시도가 다음과 같은 오류로 실패합니다:

alice@proxy.foo.example.com: Permission denied (publickey).
ERROR: exit status 255

kex_exchange_identification: Connection closed by remote host

이 오류가 표시되면 tsh login을 다시 실행하여 로컬 인증서를 갱신하세요.

2/3단계. Visual Studio Code 설정#

로컬 VS Code 인스턴스에 Remote - SSH 확장을 설치하세요. VS Code 창 왼쪽 하단에 새로운 "Window Indicator"(두 개의 화살표 아이콘)가 나타납니다.

VS Code 왼쪽 하단 모서리의 Window Indicator

호스트에 연결하기 전에 확장 설정에서 Remote.SSH: Use Local Server 설정을 false로 설정하세요. 플러그인별 설정을 찾으려면 @ext:ms-vscode-remote.remote-ssh 를 검색할 수 있습니다.

Remote SSH 확장 VS Code 설정

연결하려면 두 개의 화살표 아이콘을 클릭하고 "Connect to Host..."를 선택하세요. "+ Add New SSH Host..."를 선택하세요.

원격으로 개발하려는 각 호스트에 대해 다음과 같은 항목을 추가하세요:

alice@node000.foo.example.com

새 노드 추가 입력 상자

업데이트할 SSH 설정 파일을 선택하라는 메시지가 표시되면 1단계에서 생성한 파일을 선택하세요.

이렇게 하면 SSH 설정 파일에 새 노드가 작성됩니다. 이 파일에서 모든 노드를 편집하고 관리할 수 있습니다.

3/3단계. 원격 개발 세션 시작#

다음 방법 중 하나로 원격 개발 세션을 시작하세요:

  1. 새 호스트를 추가한 후 열리는 알림에서 "Connect"를 클릭하세요.

"Host added" 알림에 connect 버튼

  1. Window Indicator를 다시 클릭하고 "Connect to Host"를 선택하세요. 드롭다운에서 방금 추가한 호스트와 설정 파일의 다른 호스트들을 볼 수 있습니다.

VS Code에서 Teleport 호스트에 연결

처음 연결 시 원격 OS를 설정하라는 메시지가 표시됩니다. 적절한 플랫폼을 선택하면 VS Code가 서버측 컴포넌트를 설치합니다. 완료되면 작동하는 편집기가 표시됩니다:

Teleport 노드에 연결된 VS Code

왼쪽 하단의 Window Indicator는 현재 연결된 원격 호스트를 강조 표시합니다.

다음 단계#

OpenSSH 호스트에 연결#

호스트 OS가 VS Code에서 지원되는 한 Teleport 클러스터에 연결된 모든 OpenSSH 호스트에서 원격으로 개발할 수 있습니다. OpenSSH 가이드를 참조하여 Teleport 인증서를 통해 원격 호스트가 인증하도록 설정하세요. 그 후 위에 설명된 절차를 사용하여 VS Code에서 호스트에 연결할 수 있습니다.

OpenSSH 클라이언트 사용#

이 가이드는 tsh config를 사용합니다. 추가 정보는 전용 가이드를 참조하세요.

추가 읽기 자료#

Visual Studio Code

원문 보기
요약

이 가이드는 Teleport와 Visual Studio Code의 원격 SSH 확장을 사용하는 방법을 설명합니다. Visual Studio Code Remote - SSH 확장은 로컬 SSH 클라이언트를 사용하여 원격 서버에 접근합니다.

이 가이드는 Teleport와 Visual Studio Code의 원격 SSH 확장을 사용하는 방법을 설명합니다.

작동 방식#

Visual Studio Code Remote - SSH 확장은 로컬 SSH 클라이언트를 사용하여 원격 서버에 접근합니다. Teleport를 사용하여 로컬 SSH 클라이언트에 대한 설정을 생성할 수 있으며, 이 설정은 Teleport가 발급한 OpenSSH 인증서를 사용하여 Teleport로 보호된 Linux 서버에 연결하도록 클라이언트에게 지시합니다.

사전 요구 사항#

  • A running Teleport cluster. If you want to get started with Teleport, sign up for a free trial or set up a demo environment.

  • The `tsh` client.

    Installing \`tsh\` client
    1. Determine the version of your Teleport cluster. The `tsh` client must be at most one major version behind your Teleport cluster version. Send a GET request to the Proxy Service at /v1/webapi/find and use a JSON query tool to obtain your cluster version. Replace with the web address of your Teleport Proxy Service:

      $ TELEPORT_DOMAIN=
      $ TELEPORT_VERSION="$(curl -s https://$TELEPORT_DOMAIN/v1/webapi/find | jq -r '.server_version')"
      
    2. Follow the instructions for your platform to install `tsh` client:

  • OpenSSH 클라이언트.
  • Remote - SSH 확장을 위한 Remote - SSH 확장이 설치된 Visual Studio Code.
  • 하나 이상의 Teleport SSH Service를 실행하는 Teleport Agent. 아직 설정하지 않은 경우, 시작하기 가이드를 읽어 설정 방법을 알아보세요.
Note

Linux 및 macOS 클라이언트는 운영 체제에서 제공하는 OpenSSH 패키지를 사용해야 합니다. Windows 10 클라이언트는 Microsoft의 OpenSSH 가이드를 참조하세요. 구버전 클라이언트는 Git for Windows 또는 Microsoft의 Win32-OpenSSH 프로젝트에서 ssh.exe를 사용할 수 있습니다.

1/3단계. 최초 설정#

Teleport 노드에 접근하도록 로컬 SSH 클라이언트를 설정하세요. 를 Teleport Proxy Service 주소로 바꾸고(Teleport Cloud 사용자의 경우 예: mytenant.teleport.sh), 를 Teleport 사용자로 바꾸세요.

# 프록시에 로그인:
$ tsh login --proxy  --user 

# 프록시에 대한 OpenSSH 설정 생성:
$ tsh config --proxy 

결과로 나온 설정 스니펫을 아래 경로에 있는 SSH 설정 파일에 추가하세요:

$HOME/.ssh/config

%UserProfile%\.ssh\config

Warning

Windows에서 PowerShell을 사용하여 SSH 설정을 작성하는 경우, 일반적인 셸 리디렉션이 잘못된 인코딩으로 파일을 작성할 수 있습니다. 올바르게 작성하려면 다음을 시도하세요:

$ tsh.exe config | out-file .ssh\config -encoding utf8 -append

를 노드에서 사용하려는 사용자명으로 바꾸고 를 노드 이름으로 바꾸어 다음 명령으로 원하는 노드에 연결할 수 있어야 합니다:

$ ssh @.
Teleport Cloud 앞서 생성한 SSH 설정은 SSH 클라이언트가 Teleport 클러스터의 노드에 접근하기 위해 `tsh proxy ssh`를 실행하도록 지시합니다. 그러나 `yourtenant.teleport.sh`의 Teleport Proxy Service에 대해 `ssh` 명령을 실행하면 오류가 발생합니다.
Note

Teleport의 인증서는 상당히 빨리 만료되며, 만료되면 SSH 시도가 다음과 같은 오류로 실패합니다:

alice@proxy.foo.example.com: Permission denied (publickey).
ERROR: exit status 255

kex_exchange_identification: Connection closed by remote host

이 오류가 표시되면 tsh login을 다시 실행하여 로컬 인증서를 갱신하세요.

2/3단계. Visual Studio Code 설정#

로컬 VS Code 인스턴스에 Remote - SSH 확장을 설치하세요. VS Code 창 왼쪽 하단에 새로운 "Window Indicator"(두 개의 화살표 아이콘)가 나타납니다.

VS Code 왼쪽 하단 모서리의 Window Indicator

호스트에 연결하기 전에 확장 설정에서 Remote.SSH: Use Local Server 설정을 false로 설정하세요. 플러그인별 설정을 찾으려면 @ext:ms-vscode-remote.remote-ssh 를 검색할 수 있습니다.

Remote SSH 확장 VS Code 설정

연결하려면 두 개의 화살표 아이콘을 클릭하고 "Connect to Host..."를 선택하세요. "+ Add New SSH Host..."를 선택하세요.

원격으로 개발하려는 각 호스트에 대해 다음과 같은 항목을 추가하세요:

alice@node000.foo.example.com

새 노드 추가 입력 상자

업데이트할 SSH 설정 파일을 선택하라는 메시지가 표시되면 1단계에서 생성한 파일을 선택하세요.

이렇게 하면 SSH 설정 파일에 새 노드가 작성됩니다. 이 파일에서 모든 노드를 편집하고 관리할 수 있습니다.

3/3단계. 원격 개발 세션 시작#

다음 방법 중 하나로 원격 개발 세션을 시작하세요:

  1. 새 호스트를 추가한 후 열리는 알림에서 "Connect"를 클릭하세요.

"Host added" 알림에 connect 버튼

  1. Window Indicator를 다시 클릭하고 "Connect to Host"를 선택하세요. 드롭다운에서 방금 추가한 호스트와 설정 파일의 다른 호스트들을 볼 수 있습니다.

VS Code에서 Teleport 호스트에 연결

처음 연결 시 원격 OS를 설정하라는 메시지가 표시됩니다. 적절한 플랫폼을 선택하면 VS Code가 서버측 컴포넌트를 설치합니다. 완료되면 작동하는 편집기가 표시됩니다:

Teleport 노드에 연결된 VS Code

왼쪽 하단의 Window Indicator는 현재 연결된 원격 호스트를 강조 표시합니다.

다음 단계#

OpenSSH 호스트에 연결#

호스트 OS가 VS Code에서 지원되는 한 Teleport 클러스터에 연결된 모든 OpenSSH 호스트에서 원격으로 개발할 수 있습니다. OpenSSH 가이드를 참조하여 Teleport 인증서를 통해 원격 호스트가 인증하도록 설정하세요. 그 후 위에 설명된 절차를 사용하여 VS Code에서 호스트에 연결할 수 있습니다.

OpenSSH 클라이언트 사용#

이 가이드는 tsh config를 사용합니다. 추가 정보는 전용 가이드를 참조하세요.

추가 읽기 자료#