Ubuntu 18.04의 초기 보안 서버 구성

소개

이 튜토리얼을 통해 Ubuntu 18.04를 실행하는 새로운 Vultr VC2 가상 머신에서 기본 수준의 보안을 구성하는 방법을 배우게됩니다.

전제 조건

사용자 생성 및 수정

가장 먼저 할 일은 VM에 로그인하는 데 사용할 새 사용자를 만드는 것입니다.

adduser porthorian

참고 : 추측하기 어려운 고유 한 사용자 이름을 사용하는 것이 좋습니다. 대부분의 봇은 시도 기본값으로 root, admin, moderator, 및 이와 유사한.

여기에 비밀번호를 묻는 메시지가 나타납니다. 되어 강력하게 당신이 강한 알파 숫자 암호를 사용하는 것이 좋습니다. 그런 다음 화면의 지시를 따르고 정보가 올바른지 묻는 메시지가 나타나면를 누르십시오 Y.

새 사용자가 추가되면 해당 사용자에게 sudo 권한을 부여하여 루트 사용자 대신 사용자의 명령을 실행할 수 있습니다.

usermod -aG sudo porthorian

사용자에게 sudo 권한을 부여하면 새 사용자로 전환하십시오.

su - porthorian

SSH 키 생성 및 구성

SSH 키를 생성하려면 이 문서 를 따르십시오 .

새 SSH 키를 생성했으면 공개 키를 복사하십시오. 다음과 같아야합니다.

ssh-rsa AAAAB3NzaC1yc2EAAAABJQAAAQEAmB3uRWxAAELNJ8oGBCBmZx7S11vnAp0RG8rdKf6CLdvT7NMbKF55F8Wf0hFPewEryplaH54ibdmaTuheJVKy1lUhHnVi0AcBpkhJiiOQdEtvbYKT/eIkQl/Qm92Gz6aL3lJ0UknO4gO0LzgqI2vYX0b9LHMF+ZvApEDahLCna6RKo3/lffnANUKfExE+dVwOcJwATL3Ld5IkSatm7zBqbJAim0wj/JQ5ejzkL+aYd3YawpW3qf+WsY3HGbK2TIJt3LsiZJ3M7giZo/fVIZCJqsIOyO9NUOEx5/+KE8IniGb7gdRYgquAEJr89poDCNz/8CBODi9z3ukiE1+UnVlhfQ== rsa-key-20190408

사용자 디렉토리를 구성하십시오.

아직 사용자 홈 디렉토리로 이동하지 않은 경우 :

cd $HOME

$HOME사용자 홈 디렉토리의 환경 변수입니다. 새 사용자가 생성되면 자동으로 설정됩니다.

우리의 홈 디렉토리에있는 동안 우리는 그 안에 다른 디렉토리를 배치 할 것입니다. 이 디렉토리는 루트 및 디렉토리를 소유 한 사용자를 제외하고 머신의 다른 사용자로부터 숨겨집니다. 다음 명령으로 새 디렉토리를 작성하고 권한을 제한하십시오.

mkdir ~/.ssh
chmod 700 ~/.ssh

이제 .ssh라는 파일을 열 것 authorized_keys입니다. 이것은 OpenSSH가 찾는 범용 파일입니다. /etc/ssh/sshd_config필요한 경우 OpenSSH 구성 내에서이 이름을 변경할 수 있습니다 .

선호하는 편집기를 사용하여 파일을 작성하십시오. 이 튜토리얼은 nano를 사용합니다 :

nano ~/.ssh/authorized_keys

ssh 키를 복사 한 authorized_keys파일에 붙여 넣 습니다. 공개 키가 있으면 CTRL+ 를 눌러 파일을 저장할 수 있습니다 O.

적절한 파일 경로가 나타나는지 확인하십시오.

/home/porthorian/.ssh/authorized_keys

올바른 파일 경로이면을 누르십시오 ENTER. 그렇지 않으면 위의 예와 일치하도록 필요한 사항을 변경하십시오. 그런 다음 CTRL+로 파일을 종료하십시오 X.

이제 파일에 대한 액세스를 제한 할 것입니다.

chmod 600 ~/.ssh/authorized_keys

작성된 사용자를 종료하고 루트 사용자로 돌아가십시오.

exit

비밀번호 인증 비활성화

로그인시 ssh 키가 필요한 방식으로 서버에 대한 비밀번호 인증을 비활성화 할 수 있습니다. 비밀번호 인증을 사용하지 않고 공개 키가 올바르게 설치되지 않은 경우 서버에서 자신을 잠 그게됩니다. 루트 사용자를 로그 아웃하기 전에 키를 먼저 테스트하는 것이 좋습니다.

현재 루트 사용자로 로그인 했으므로 다음을 편집 할 것입니다 sshd_config.

nano /etc/ssh/sshd_config

OpenSSH가 올바르게 구성되었는지 확인하기 위해 3 개의 값을 검색 할 것입니다.

  • PasswordAuthentication
  • PubkeyAuthentication
  • ChallengeResponseAuthentication

CTRL+ 를 누르면 이러한 값을 찾을 수 있습니다 W.

값은 다음과 같이 설정해야합니다.

PasswordAuthentication  no
ChallengeResponseAuthentication  no
PubkeyAuthentication  yes

값이 주석 처리 된 #경우 행의 시작 부분에서를 제거하고 해당 변수의 값이 위와 같은지 확인하십시오. 당신이 그 변수를 변경하면, 저장과, 편집기를 종료 CTRL+ O, ENTER마침내와 CTRL+ X.

이제 sshd다음 명령 으로 다시로드하겠습니다 .

systemctl reload sshd

이제 로그인을 테스트 할 수 있습니다. 아직 루트 세션에서 로그 아웃하지 않았는지 확인하고 새 ssh 창을 열고 연결에 연결된 ssh 키로 연결하십시오.

PuTTY에서 이것은 Connection-> SSH-> 아래에 Auth있습니다.

ssh 키를 작성할 때 저장 했으므로 인증을위한 개인 키를 찾아보십시오.

개인 키를 인증으로 사용하여 서버에 연결하십시오. 이제 Vultr VC2 가상 머신에 로그인됩니다.

참고 : ssh 키를 생성하는 동안 암호를 추가하면 암호를 입력하라는 메시지가 표시됩니다. 이것은 가상 머신의 실제 사용자 비밀번호와는 완전히 다릅니다.

기본 방화벽 설정

UFW 구성

먼저 가상 머신에 UFW가 설치되어 있지 않은 경우 UFW를 설치합니다. 확인하는 좋은 방법은 다음 명령을 사용하는 것입니다.

sudo ufw status

UFW가 설치되어 있으면을 출력 Status:inactive합니다. 설치되어 있지 않으면 설치하라는 메시지가 표시됩니다.

다음 명령으로 설치할 수 있습니다 :

sudo apt-get install ufw -y

이제 22방화벽에서 SSH 포트를 허용 할 것입니다 :

sudo ufw allow 22

또는 OpenSSH를 허용 할 수 있습니다.

sudo ufw allow OpenSSH

위의 명령 중 하나가 작동합니다.

방화벽을 통해 포트를 허용 했으므로 UFW를 활성화 할 수 있습니다.

sudo ufw enable

이 작업을 수행 할 것인지 묻는 메시지가 표시됩니다. 타이핑 한 y다음 ENTER방화벽을 활성화합니다 :

porthorian@MEANStack:~$ sudo ufw enable
Command may disrupt existing ssh connections. Proceed with operation? y

참고 : OpenSSH 또는 포트 22를 허용하지 않으면 가상 머신에서 자신을 잠 그게됩니다. UFW를 활성화하기 전에 이들 중 하나가 허용되는지 확인하십시오.

방화벽이 활성화되면 여전히 인스턴스에 연결됩니다. 이전과 동일한 명령으로 방화벽을 다시 확인하겠습니다.

sudo ufw status

다음과 유사한 결과가 나타납니다.

porthorian@MEANStack:~$ sudo ufw status
Status: active

To                         Action      From
--                         ------      ----
22                         ALLOW       Anywhere
22 (v6)                    ALLOW       Anywhere (v6)

Vultr 방화벽 구성

서버를 더욱 안전하게 보호하기 위해 Vultr Firewall을 사용합니다. 귀하의 계정에 로그인 하십시오 . 로그인하면 화면 상단에 위치한 방화벽 탭으로 이동합니다.

Ubuntu 18.04의 초기 보안 서버 구성

이제 새로운 방화벽 그룹을 추가하겠습니다. 이를 통해 UFW 방화벽에 도달 할 수있는 포트를 지정하여 이중 보안 계층을 제공 할 수 있습니다.

Ubuntu 18.04의 초기 보안 서버 구성

Vultr는 이제 "설명"필드를 사용하여 방화벽의 이름을 지정할 것입니다. 향후 관리를 쉽게하기 위해이 방화벽 그룹의 서버가 수행 할 작업을 설명해야합니다. 이 튜토리얼을 위해 이름을하겠습니다 test. 원하는 경우 언제든지 설명을 변경할 수 있습니다.

먼저 IP 주소를 얻어야합니다. 우리가 직접하는 이유는 IP 주소가 고정적이지 않고 지속적으로 변경되는 경우 Vultr 계정에 로그인하여 IP 주소를 변경하기 때문입니다.

UFW 방화벽에서 IP 주소가 필요하지 않은 이유이기도합니다. 또한 가상 머신의 방화벽 사용이 다른 모든 포트를 필터링하는 것을 제한하고 Vultr 방화벽이이를 처리하도록합니다. 이는 인스턴스에서 전체 트래픽 필터링의 부담을 제한합니다.

Vultr의 네트워크 유리 를 사용 하여 IP 주소를 찾으십시오.

이제 IP 주소를 얻었으므로 새로 만든 방화벽에 IPV4 규칙을 추가합니다.

Ubuntu 18.04의 초기 보안 서버 구성

IP 주소를 입력했으면 +기호를 클릭 하여 IP 주소를 방화벽에 추가하십시오.

방화벽 그룹은 다음과 같습니다.

Ubuntu 18.04의 초기 보안 서버 구성

방화벽 그룹에 IP가 올바르게 바인딩되었으므로 Vultr 인스턴스를 연결해야합니다. 왼쪽에는 "링크 된 인스턴스"라는 탭이 있습니다.

Ubuntu 18.04의 초기 보안 서버 구성

페이지에 들어가면 서버 인스턴스 목록이있는 드롭 다운이 표시됩니다.

Ubuntu 18.04의 초기 보안 서버 구성

드롭 다운을 클릭하고 인스턴스를 선택하십시오. 그런 다음 방화벽 그룹에 인스턴스를 추가 할 준비가되면 +기호를 클릭하십시오 .

축하합니다. Vultr VC2 가상 머신을 성공적으로 보호했습니다. 이를 통해 누군가가 인스턴스를 무차별 대입하려고 할 염려없이 매우 기본적인 보안 계층에 대한 좋은 기초를 제공합니다.



Leave a Comment

Ubuntu 16.04에 LiteCart 쇼핑 카트 플랫폼을 설치하는 방법

Ubuntu 16.04에 LiteCart 쇼핑 카트 플랫폼을 설치하는 방법

LiteCart는 PHP, jQuery 및 HTML 5로 작성된 무료 오픈 소스 쇼핑 카트 플랫폼입니다. 단순하고 가벼우 며 사용하기 쉬운 전자 상거래 softwar입니다

데비안에서 NFS 공유 설정

데비안에서 NFS 공유 설정

NFS는 컴퓨터가 컴퓨터 네트워크를 통해 파일에 액세스 할 수 있도록하는 네트워크 기반 파일 시스템입니다. 이 가이드는 NF를 통해 폴더를 노출하는 방법을 설명합니다

Fedora 28에 Matomo Analytics를 설치하는 방법

Fedora 28에 Matomo Analytics를 설치하는 방법

다른 시스템을 사용하십니까? Matomo (이전 Piwik)는 Google 애널리틱스의 대안 인 오픈 소스 분석 플랫폼입니다. Matomo 소스가 호스팅됩니다

Linux에서 TeamTalk 서버 설정

Linux에서 TeamTalk 서버 설정

TeamTalk는 사용자가 고품질 오디오 / 비디오 대화, 문자 채팅, 파일 전송 및 화면 공유를 할 수있는 회의 시스템입니다. 내가

CentOS 7 서버에 CyberPanel을 설치하고 구성하는 방법

CentOS 7 서버에 CyberPanel을 설치하고 구성하는 방법

다른 시스템을 사용하십니까? 소개 CyberPanel은 오픈 소스이며 OpenLiteSpeed를 사용하는 최초의 제어판 중 하나입니다. 무슨 티

Ubuntu 17.04에서 Rbenv, Rails, MariaDB, Nginx, SSL 및 승객으로 Ruby를 설치 및 구성하는 방법

Ubuntu 17.04에서 Rbenv, Rails, MariaDB, Nginx, SSL 및 승객으로 Ruby를 설치 및 구성하는 방법

Ruby on Rails는 프로그래머의 생산성을 높이기 위해 개발 된 Ruby의 대중적인 웹 프레임 워크입니다. 그러나 다양한 보석과 의존성 확보

Vultr VPS에 액세스하는 방법

Vultr VPS에 액세스하는 방법

Vultr은 VPS에 액세스하여 구성, 설치 및 사용하는 여러 가지 방법을 제공합니다. 액세스 자격 증명 VPS ar의 기본 액세스 자격 증명

Ubuntu 16.04 LTS에 OpenNMS를 설치하는 방법

Ubuntu 16.04 LTS에 OpenNMS를 설치하는 방법

다른 시스템을 사용하십니까? OpenNMS는 엔터프라이즈 급 오픈 소스 네트워크 관리 플랫폼으로 여러 장치를 모니터링하고 관리하는 데 사용할 수 있습니다

Fedora 26 LAMP VPS에 Omeka Classic 2.4 CMS를 설치하는 방법

Fedora 26 LAMP VPS에 Omeka Classic 2.4 CMS를 설치하는 방법

다른 시스템을 사용하십니까? Omeka Classic 2.4 CMS는 디지털 공유를위한 무료 오픈 소스 디지털 출판 플랫폼 및 CMS (콘텐츠 관리 시스템)입니다

Ubuntu 16.04 LTS에 DokuWiki를 설치하는 방법

Ubuntu 16.04 LTS에 DokuWiki를 설치하는 방법

다른 시스템을 사용하십니까? DokuWiki는 데이터베이스가 필요없는 PHP로 작성된 오픈 소스 위키 프로그램입니다. 텍스트 파일에 데이터를 저장합니다. 도쿠 위크

코골이가있는 앞마당 2 설정

코골이가있는 앞마당 2 설정

Barnyard2는 Snort의 바이너리 출력을 MySQL 데이터베이스에 저장하고 처리하는 방법입니다. 시작하기 전에 코골이가 없으면

데비안에서 Chroot 설정

데비안에서 Chroot 설정

이 기사는 데비안에서 chroot jail을 설정하는 방법을 알려줍니다. 데비안 7.x를 사용한다고 가정합니다. 데비안 6 또는 8을 실행하고 있다면 작동 할 수 있습니다.

데비안에 PiVPN을 설치하는 방법

데비안에 PiVPN을 설치하는 방법

소개 데비안에서 VPN 서버를 설정하는 쉬운 방법은 PiVPN을 사용하는 것입니다. PiVPN은 OpenVPN 용 설치 프로그램 및 래퍼입니다. 그것은 당신을 위해 간단한 명령을 만듭니다

Ubuntu 18.04 LTS에서 CyberPanel을 설치하고 구성하는 방법

Ubuntu 18.04 LTS에서 CyberPanel을 설치하고 구성하는 방법

다른 시스템을 사용하십니까? 소개 CyberPanel은 오픈 소스이며 OpenLiteSpeed를 사용하는 최초의 제어판 중 하나입니다. 무슨 티

Fedora 25에서 Ghost v0.11 LTS를 배포하는 방법

Fedora 25에서 Ghost v0.11 LTS를 배포하는 방법

다른 시스템을 사용하십니까? Ghost는 201 년 이후 개발자와 일반 사용자 사이에서 인기를 얻고있는 오픈 소스 블로그 플랫폼입니다.

CentOS 7에 채팅 서버를 배포하는 방법

CentOS 7에 채팅 서버를 배포하는 방법

Lets Chat은 소규모 팀을위한 자체 호스팅 메시징 서비스를 제공하도록 설계된 오픈 소스 채팅 응용 프로그램입니다. 채팅이 NodeJS 및 MongoDB를 기반으로 함

CentOS 7에 예약 스케줄러를 설치하는 방법

CentOS 7에 예약 스케줄러를 설치하는 방법

다른 시스템을 사용하십니까? 전제 조건 Vultr CentOS 7 서버 인스턴스. sudo 사용자 1 단계 : 시스템 업데이트 먼저 시스템 서버를 업데이트하십시오.

데비안 9의 소스에서 Brotli를 빌드하는 방법

데비안 9의 소스에서 Brotli를 빌드하는 방법

다른 시스템을 사용하십니까? Brotli는 Gzip보다 압축률이 더 좋은 새로운 압축 방법입니다. 소스 코드는 Github에서 공개적으로 호스팅됩니다. 티

Plesk 서버에서 HTTP / 2를 활성화하는 방법

Plesk 서버에서 HTTP / 2를 활성화하는 방법

Plesk는 기본 HTTP / 2를 지원합니다. Plesk에서 HTTP / 2를 롤아웃하는 것이 다른 방법에 비해 훨씬 쉽지만 배치 프로세스에는 신중한 계획이 필요합니다.

FreeBSD 12에서 osTicket을 설치하는 방법

FreeBSD 12에서 osTicket을 설치하는 방법

다른 시스템을 사용하십니까? osTicket은 오픈 소스 고객 지원 티켓팅 시스템입니다. osTicket 소스 코드는 Github에서 공개적으로 호스팅됩니다. 이 튜토리얼에서

NTLite를 사용하여 업데이트로 Windows 사용자 지정 ISO를 만드는 방법

NTLite를 사용하여 업데이트로 Windows 사용자 지정 ISO를 만드는 방법

NTLite를 사용하여 Vultr 시스템과 호환되는 Windows 사용자 지정 ISO를 만드는 방법을 단계별로 설명합니다. 최신 드라이버와 업데이트 통합을 포함한 완벽 가이드.

Vultr에서 BGP 구성

Vultr에서 BGP 구성

Vultr BGP 설정을 위한 단계별 튜토리얼. ASN 할당부터 IP 라우팅 구성, BIRD 데몬 설정, FreeBSD 특이사항 및 실전 문제 해결 팁 7가지 포함한 최종 가이드

WsgiDAV를 사용하여 Debian 10에 WebDAV 배포

WsgiDAV를 사용하여 Debian 10에 WebDAV 배포

WebDAV (Web Distributed Authoring and Versioning)를 이용한 원격 파일 작성을 위한 프레임워크로, WsgiDAV 설치 및 구성 방법을 안내합니다.

데비안 7에 Mailcow 설치

데비안 7에 Mailcow 설치

Mailcow는 DoveCot, Postfix 및 기타 여러 오픈 소스 패키지를 기반으로 하는 경량 메일 서버입니다. 데비안에서 Mailcow 설치 방법을 안내합니다.

AI가 랜섬웨어 공격의 증가와 싸울 수 있습니까?

AI가 랜섬웨어 공격의 증가와 싸울 수 있습니까?

랜섬웨어 공격이 증가하고 있지만 AI가 최신 컴퓨터 바이러스를 처리하는 데 도움이 될 수 있습니까? AI가 답인가? AI boone 또는 bane인지 여기에서 읽으십시오.

ReactOS: 이것이 Windows의 미래입니까?

ReactOS: 이것이 Windows의 미래입니까?

오픈 소스이자 무료 운영 체제인 ReactOS가 최신 버전과 함께 제공됩니다. 현대 Windows 사용자의 요구 사항을 충족하고 Microsoft를 무너뜨릴 수 있습니까? 이 구식이지만 더 새로운 OS 환경에 대해 자세히 알아보겠습니다.

WhatsApp 데스크톱 앱 24*7을 통해 연결 유지

WhatsApp 데스크톱 앱 24*7을 통해 연결 유지

Whatsapp은 마침내 Mac 및 Windows 사용자용 데스크톱 앱을 출시했습니다. 이제 Windows 또는 Mac에서 Whatsapp에 쉽게 액세스할 수 있습니다. Windows 8 이상 및 Mac OS 10.9 이상에서 사용 가능

AI는 어떻게 프로세스 자동화를 다음 단계로 끌어올릴 수 있습니까?

AI는 어떻게 프로세스 자동화를 다음 단계로 끌어올릴 수 있습니까?

인공 지능이 소규모 회사에서 어떻게 인기를 얻고 있으며 어떻게 인공 지능이 성장할 가능성을 높이고 경쟁자가 우위를 점할 수 있는지 알아보려면 이 기사를 읽으십시오.

macOS Catalina 10.15.4 추가 업데이트로 인해 해결보다 더 많은 문제가 발생함

macOS Catalina 10.15.4 추가 업데이트로 인해 해결보다 더 많은 문제가 발생함

최근 Apple은 문제를 해결하기 위해 macOS Catalina 10.15.4 추가 업데이트를 출시했지만 이 업데이트로 인해 Mac 컴퓨터의 브릭킹으로 이어지는 더 많은 문제가 발생하는 것 같습니다. 자세히 알아보려면 이 기사를 읽어보세요.

빅데이터의 13가지 상용 데이터 추출 도구

빅데이터의 13가지 상용 데이터 추출 도구

빅데이터의 13가지 상용 데이터 추출 도구