SSH는 “원격 접속 프로토콜”로 원격지 컴퓨터에 접속하기 위해 사용되는 인터넷 프로토콜이다.
따라서 이를 이용해 다른 지역의 컴퓨터 또는 서버를 관리할 수 있고 파일 공유도 가능하다.
SSH는 대표적으로 데이터 전송(ex: github), 원격 제어(ex: AWS)에 사용된다.
SSH 말고도 Telent, Rlogin, VNC 등과 같은 다양한 원격 접속 프로토콜들이 존재하지만 그 중 SSH가 가장 보편적이고 보안적으로 안전하다.
SSH key는 연결 상대를 인증하고 안전하게 데이터를 교환할 수 있게 해준다.
SSH key는 공개키와 개인키로 구성되어있다. 공개키는 암호화에 사용되고, 개인키는 복호화에 사용된다. 그리고 이름에서도 알 수 있듯 공개키는 외부에 공개되어도 안전하지만 개인키는 절대 노출되어서 안된다.
SSH에서는 대칭키 방식과 공개키(비대칭키) 방식을 사용하여 인증과 암호화를 하게 되는데 비대칭키를 통해서 서버 인증과 클라이언트 인증을 하고, 대칭키(세션키)를 통해 데이터를 암호화 한다.
SSH key 인증 과정
위와 같은 과정을 통해 원격지의 서버를 관리하고 파일을 공유할 수 있다. 이제 key를 생성하는 방법에 대해 알아보자.
우선 이전에 생성한 공개키가 있는지 확인할 필요가 있다. 생성한 공개키가 없다면 다음 단계로 넘어간다.
cat ~/.ssh/id_rsa.pub
아래의 명령어를 통해 key를 생성한다.
ssh-keygen
key 생성을 하면 비밀번호를 설정하라는 문구가 나올텐데 이때 비밀번호 없이 사용하고 싶다면 enter
키를 누르면 된다.