티스토리 뷰
- bash shell입니다.
- Ubuntu 환경에서 테스트하였습니다.
이론
- 대칭키/비대칭키 암호화 방식 중, 비대칭키 암호화 방식 ( 공개키 )
- 로컬서버의 공개키를 원격서버로 공유하여 접근
사용 가능 범위
- SSH / SCP / RSYNC 등 SSH 프로토콜을 이용한 모든 일련의 과정
설정 방법
local_server1 = 10.20.30.5
remote_server2 = 10.20.30.27
로컬 서버 실행 터미널
local_server1$ ssh-copy-id -i ~/.ssh/id_rsa.pub root@10.20.30.27
The authenticity of host '10.20.30.27 (10.20.30.27)' can't be established.
RSA key fingerprint is 23:d8:15:1f:07:af:ac:7b:a8:19:a9:f5:d7:35:a2:22.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added '10.20.30.27' (RSA) to the list of known hosts.
root@10.20.30.27's password:
로컬 서버에서 최초 접근 이후에 원격 서버로 id_rsa.pub라는 자신의 공개키를 원격서버의 ~/.ssh/authorized_keys 파일에 저장합니다.
두 번째 접근부터는 공개키를 이용하여 패스워드 접속 없이 접근이 가능하게 됩니다.
공개키 암호화 방식이기 때문에 id_rsa 라는 사설키(개인키)는 절대로 유출하면 안됩니다.
원격 서버 ~/.ssh/authorized_keys 파일 내용
ssh-rsa AAAAB3NaOJ1yc2EAAAABIwABAQEAplB5P0233jrTsQ5zjHHlaFATAVeOJ+(이하생략)== root@10.20.30.27
- 공개키 암호화 방식입니다. ( 따라서, 원격 서버의 authorized_keys 파일에 등록된 키 값을 지우고, 원격서버로 접속시에는 다시 패스워드를 질의하게 됩니다.)
- 사설키는 절대로 유출하면 안됩니다.
- 최초 접근 이후에 두 번째 접속부터는 패스워드 없이 접속이 가능합니다.
- 각종 스크립트에 활용하기 좋습니다.
man page
NAME
ssh-copy-id - install your public key in a remote machine’s authorized_keys
SYNOPSIS
ssh-copy-id [-i [identity_file]] [user@]machine
DESCRIPTION
ssh-copy-id is a script that uses ssh to log into a remote machine (presumably using a login password, so password authentication should be enabled, unless you’ve done some clever use of multiple identities) It also changes the permissions of the remote user’s home, ~/.ssh, and ~/.ssh/authorized_keys to remove group writability (which would otherwise prevent you from logging in, if the remote sshd has StrictModes set in its configuration). If the -i option is given then the identity file (defaults to ~/.ssh/id_rsa.pub) is used, regardless of whether there are any keys in your ssh-agent. Otherwise, if this: ssh-add -L provides any output, it uses that in preference to the identity file. If the -i option is used, or the ssh add produced no output, then it uses the contents of the identity file. Once it has one or more fingerprints (by whatever means) it uses ssh to append them to ~/.ssh/authorized_keys on the remote machine (creating the file, and directory, if necessary)
SEE ALSO
ssh(1), ssh-agent(1), sshd(8)
'Linux' 카테고리의 다른 글
grep에 color 입히기 (0) | 2020.03.24 |
---|---|
history에 명령어 시간 표시하기 (0) | 2019.04.20 |
- Total
- Today
- Yesterday
- vtep
- head end replication
- iso8601
- data plane
- 802.3ad
- date 시간 지정
- bash
- dns 동작 방식
- ssh
- docker logs
- link aggregation
- 윈도우
- multiple ping
- VXLAN
- HTTP/1.1
- date 과거
- date 미래
- ping
- http/0.9
- HTTP
- Switch
- Windows
- vni
- date 시간 변경
- tag
- 802.1ax
- http/1.0
- ping multi
- vlan
- dns 동작
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |