-
[홈서버] 윈도우10 OpenSSH Server, authorized_keys 사용하기홈서버 2020. 4. 3. 18:05반응형
증권사 api를 구현할 경우 그 api가 win32에 종속적인 경우가 많다. 그래서 윈도우기반의 서버가 필요하였고 젠킨스에서 자동배포를 위해 ssh, sftp를 키 기반으로 접근하고 싶었다. 물론 젠킨스에 'Publish Over SSH' 플러그인을 사용하면 계정/패스워드로 접근이 가능하다.
그러나 목적은 공개키를 authorized_keys 파일에 등록하여 사용하기다.
진행 순서는 다음과 같다.
1. 윈도우 10 OpenSSH Server 설치
2. sshd 서비스 시작
3. key 생성
4. sshd config 수정
5. sshd 서비스 재시작
1. 윈도우 10 OpenSSH Server 설치
설치를 간단히 끝낸 후 데몬을 실행 하여야 한다.
2. sshd 서비스 시작
PowerShell을 관라자 권한으로 실행 후에 다음 명령어를 이용하여 sshd를 실행한다.
c:\> Start-Service sshd netstat 명령어로 22번 포트가 정상적으로 리슨 상태 인지 확인 한다.
c:\> netstat -an | findstr "22" 3. key 생성
클라이언트 특정 계정의 공개키를 이용해 해당 서버에 접근하기 위해서 키생성 작업과 config 파일 수정이 필요하다.
클라이언트 OS는 우분투이다. 먼저 키 생성 작업을 한다.
$ ssh-keygen -t rsa 계정의 홈디렉토리에서 .ssh 디렉토리로 이동 후 키젠을 이용하여 키를 생성한다. .ssh 디렉토리가 없으면 mkdir로 생성한다.
클라이언트 계정에서 키젠을 사용하면 공개키(id_rsa.pub)와 개인키(id_rsa)가 발급되는데 공개키의 내용을 대상 서버 계정의 .ssh/
authorized_keys 파일에 넣어두어야 한다. 여기선 공개키 내용을 cat 명령어로 확인 후 복붙으로 대상 서버에 넣겠다.
ssh를 이용하여 대상 서버에 접근한다.
$ ssh test@172.30.1.85 접속 후 .ssh 디렉토리와 authorized_keys 파일을 생성해준다.
c:\Users\test> mkdir .ssh&&cd .ssh c:\Users\test> copy con authorized_keys 위의 명령 입력 후 id_rsa.pub 의 내용을 붙여 넣은 후 컨트롤 + z 을 눌러 파일을 저장한다.
4. sshd config 수정
sshd의 기본 참조 파일은 administrators_authorized_keys 이다. 이 설정을 각 계정의 .ssh/authorized_keys 파일을 사용하기 위해선 해당 설정을 주석처리 하여야 한다. 그러나 이 방법은 기본설정에 비해 보안적인 이슈가 있지만, 편리성을 위해 사용하려고 한다.
- 각 계정의 authorized_keys 사용시 이슈
Match Group administrators
AuthorizedKeysFile __PROGRAMDATA__/ssh/administrators_authorized_keys
두 줄 주석처리 후 저장한다.
5. sshd 서비스 재시작
config 파일 적용을 위해 ssh 데몬을 정지 후 다시 시작한다.
이 후 클라이언트 계정에서 ssh로 해당 서버의 계정으로 접근시 더 이상 패스워드를 묻지 않는다.
반응형'홈서버' 카테고리의 다른 글
[홈서버] OS 계정 추가 및 이메일 송수신 (2) 2020.08.26 [홈서버] dovecot pop3 imap 메일 서버 구축 (0) 2020.08.26 [홈서버] postfix smtp 메일 서버 구축 (0) 2020.08.26 [홈서버] letsencrypt 인증서 발급 받기 (4) 2020.08.19 [홈서버구축] 홈네트워크 구성하기 (1) (6) 2020.02.22