기본 콘텐츠로 건너뛰기

리눅스가상화및Docker사용법

안녕하세요, MJ입니다. 오늘은 리눅스 기반의 가상화 기술과 컨테이너에 대해 알아보겠습니다. 가상화 기술은 물리적 하드웨어 자원을 효율적으로 활용하고, 다양한 운영 체제를 동시에 구동할 수 있게 해줍니다. 특히 Docker와 같은 컨테이너 기술은 애플리케이션의 배포와 관리를 단순화하는 데 큰 도움을 줍니다. 이번 포스팅에서는 Docker 설치 방법과 기본 사용법에 대해 자세히 살펴보겠습니다. 1. 가상화 기술의 이해 가상화 기술은 물리적 서버를 여러 개의 가상 서버로 나누어 사용하는 기술입니다. 이를 통해 자원의 활용도를 높이고, 서버 관리의 유연성을 제공합니다. 리눅스에서 주로 사용되는 가상화 기술에는 KVM, Xen, LXC 등이 있습니다. 각 기술은 서로 다른 접근 방식을 가지고 있으며, 다양한 용도로 활용됩니다. 1.1 KVM (Kernel-based Virtual Machine) KVM은 리눅스 커널에 내장된 가상화 기술로, 리눅스 시스템을 하이퍼바이저로 사용하여 가상 머신을 생성합니다. KVM은 성능이 우수하고, 다양한 운영 체제를 지원하는 장점이 있습니다. 1.2 LXC (Linux Containers) LXC는 리눅스 커널의 cgroups와 네임스페이스 기능을 활용하여 경량화된 가상 환경을 제공합니다. LXC는 가상 머신보다 더 가벼운 리소스 사용으로 빠른 시작과 종료가 가능합니다. 2. Docker란? Docker는 애플리케이션을 컨테이너라는 경량화된 환경에서 실행할 수 있게 해주는 플랫폼입니다. 컨테이너는 애플리케이션과 해당 애플리케이션이 필요로 하는 라이브러리 및 종속성을 포함하여 독립적으로 실행됩니다. 이를 통해 개발자는 애플리케이션을 쉽게 배포하고, 환경에 구애받지 않고 실행할 수 있습니다. 2.1 Docker의 장점 Docker는 여러 가지 장점을 제공합니다: 경량화: 컨테이너는 VM에 비해 훨씬 가벼워...

리눅스보안기초및방화벽설정

안녕하세요, MJ입니다. 오늘은 리눅스 시스템 보안의 기본 개념에 대해 알아보겠습니다. 리눅스는 안정성과 보안성을 갖춘 운영 체제로 알려져 있지만, 보안 위협으로부터 완전히 안전하지는 않습니다. 따라서 방화벽 설정 및 사용자 보안 관리는 필수적입니다. 이번 포스팅에서는 리눅스 보안의 기초 개념과 방화벽 설정, 사용자 보안 관리 방법을 자세히 살펴보겠습니다.

1. 리눅스 보안의 기본 개념

리눅스 보안은 시스템을 보호하기 위한 여러 가지 전략과 방법을 포함합니다. 여기에는 다음과 같은 요소들이 있습니다:

  • 물리적 보안: 서버가 위치한 장소의 안전을 확보합니다.
  • 네트워크 보안: 외부에서의 접근을 차단하고 내부망을 보호합니다.
  • 사용자 관리: 사용자 계정과 권한을 적절히 관리하여 불법적인 접근을 방지합니다.
  • 소프트웨어 업데이트: 시스템과 애플리케이션의 최신 보안 패치를 적용합니다.

2. 방화벽 설정

방화벽은 네트워크 트래픽을 필터링하여 불법적인 접근을 차단하는 데 중요한 역할을 합니다. 리눅스에서는 iptables 또는 firewalld를 사용하여 방화벽을 설정할 수 있습니다.

2.1 iptables 사용법

iptables는 리눅스에서 가장 많이 사용되는 방화벽 관리 도구입니다. 기본적인 사용법은 다음과 같습니다:

iptables -A INPUT -p tcp --dport 22 -j ACCEPT

위 명령어는 SSH 포트(22번 포트)로의 접근을 허용합니다.

2.2 방화벽 규칙 추가 및 삭제

방화벽 규칙을 추가하거나 삭제하려면 다음과 같은 명령어를 사용합니다:

iptables -D INPUT -p tcp --dport 22 -j ACCEPT

이 명령어는 SSH 포트에 대한 접근을 차단합니다.

2.3 방화벽 정책 설정

기본 정책을 설정하여 모든 트래픽을 차단하고, 특정 규칙만 허용할 수 있습니다:

iptables -P INPUT DROP

위 명령어는 모든 입력 트래픽을 차단합니다. 이후 필요한 서비스만 허용하는 규칙을 추가해야 합니다.

3. 사용자 보안 관리

사용자 계정 관리 또한 리눅스 보안에서 중요한 부분입니다. 사용자 계정의 권한을 적절히 설정하고, 불필요한 계정을 삭제하는 것이 필요합니다.

3.1 사용자 계정 생성 및 삭제

사용자 계정을 생성하려면 useradd 명령어를 사용합니다:

sudo useradd -m newuser

위 명령어는 newuser라는 이름의 새로운 사용자를 생성합니다. 사용자 삭제는 다음과 같이 할 수 있습니다:

sudo userdel -r newuser

이 명령어는 사용자의 홈 디렉토리와 함께 계정을 삭제합니다.

3.2 비밀번호 정책 설정

강력한 비밀번호 정책을 설정하는 것은 보안을 강화하는 데 도움이 됩니다. 비밀번호 복잡성 요구사항을 설정하려면 /etc/login.defs 파일을 수정할 수 있습니다.

PASS_MIN_LEN 12
PASS_MAX_DAYS 90

위 설정은 최소 비밀번호 길이를 12자로 설정하고, 비밀번호를 90일마다 변경하도록 요구합니다.

4. 로그 모니터링

시스템 로그를 모니터링하면 보안 위협을 조기에 발견할 수 있습니다. logwatch 또는 fail2ban과 같은 도구를 사용하여 로그를 분석하고, 의심스러운 활동을 차단할 수 있습니다.

5. 결론

리눅스 시스템 보안은 여러 가지 요소로 구성되며, 방화벽 설정과 사용자 보안 관리가 그 중 중요한 부분입니다. 위에서 설명한 방법을 통해 리눅스 시스템을 보다 안전하게 유지할 수 있습니다. 보안은 단순히 설정하는 것이 아니라 지속적인 관리와 모니터링이 필요합니다.

읽어주셔서 감사합니다. 다음 포스팅에서 만나요!

댓글

가장 많이 본 글

MJ.제라의 요일 공식 스크립트(bash, batch, powershell)

안녕하세요, MJ 입니다. 년-월-일 의 정보로 요일을 확인할 수 있는 방법 입니다. 1582년10월 15일부터는 그레고리 력으로 우리가 사용하는 서기에 적용되는 윤년/평년 확인방법입니다. 다음 3가지를 확인하여 윤년과, 평년을 미리 알 수 있습니다. 년수 4로 나누었을 때 나머지가 없는 해를 윤년으로 함. 위의 윤년중에서 100으로 나누었을 때 나머지가 없을때는 평년으로 함. 다시 400으로 나누었을 때 나머지가 없는 해는 윤년으로 함 3가지 조건 이지만 의외로 복잡합니다.   아뭏든 날짜를 넣으면 요일이 출력이 된다는 것입니다. 아래 스크립트는 단순히 입력 받은 날짜가 무슨 요일인지 영어로 토해내도록 작성되었습니다. 다른 스크립트 또는 프로그램에서 특정일자의 요일을 확인해야 하는 로직이 존재하는 경우, OS 스크립트를 수행하여 결과를 받도록 하면, 추가로 작성해야 하는 코드의 양을 줄일 수 있어 활용하기에 따라 경제적으로 이득을 취할 수 있습니다.  * 활용 예시 * 로또 API 를 이용해서 모든 회차의 당첨번호를 가져올 수 있지만, API 요청으로 얻어지는 정보는 무제한으로 제공되지 않고 대부분 하루동안 N회 가져올 수 있습니다. 그래서 최초에 한번 가져온 데이터를 별도 파일이나 DB에 저장을 하고, 당첨번호 목록을 조회 할 때에 내가 저장해둔 파일 또는 DB에서 검색해서 확인하게 됩니다. (무제한 접근가능하다고 하여도 속도가 훨씬 빠릅니다.) 하지만 조회를 시도하는 시점에서 오늘이 토요일이라면, 그리고 당첨번호 발표 시간이 지났고 동행복권 사이트에 당첨번호 정보가 등록이 되었다면 이 새로운 회차의 당첨번호는 API요청을 해서 가져와야 나의 저장된 데이터가 업데이트 될 수 있을 것 입니다. 저는 이 요일을 확인하도록 해서 이 스크립트를 수행하여 오늘이 토요일이 아닌지 매번 확인을 하도록 하고, 발표시간이 지났다면 API 한번 찔러보는 방법으로 하루동안 아무리 많이 찔러도 10번도 안찌르는것 같습니다.저는 파이썬에서 OS의 명령어...

5. 버추얼박스:설정 (+네트워크의 종류 설명)

안녕하세요 , MJ 입니다 .   우리가 실습을 하는데에 필요한 버추얼박스의 설정에 대해 설명을 합니다 .     버추얼 박스의 설정에는 종류별로 메뉴가 구분되어있습니다 . 1-1. 환경설정 1-2. 네트워크 설정 1-3. 미디어 설정       다른 설정도 존재하지만 , 필요한 일이 없을것이 예상되고 , 위 3 가지 설정에 대해서만 알고 계신다면 버추얼 박스로 실습을 하는데에 아무런 지장이 없고 또 취업을 하신 뒤에 실무에 가셔서도 문제가 될 것이 없습니다 .   환경설정 부터 확인하겠습니다 . 1-1. 환경설정 : 우리가 알아야 편한 내용은 2 가지가 있는데 VM 의 기본 저장경로 설정 " 파일 (F)" 의 환경설정 (P) … [ 단축키 : Ctrl+G] 을 누르면 환경설정 창이 보이고 , 제일먼저 확인되는 기본 머신 폴더 (M) 입니다 . VM 을 저장 할 경로를 지정하는 것인데 VM 은 가상 머신으로 디스크의 용량과는 상관없이 , 가상 컴퓨터의 정보가 저장되는 것으로 , 텍스트 파일형태로 저장되어있고 , 그 내용에는 CPU 를 몇개 사용하도록 되어있는지 , 메모리는 얼마만큼을 할당하도록 되어있는지 , 네트워크 인터페이스는 몇 개가 어떻게 설정되어있는지 ... 등 가상의 컴퓨터를 정의하는 내용의 파일이 저장되는 경로가 되고 ,   디스크 파일은 별도 미디어 설정에서 관리가 되지만 VM 을 생성하는 과정에서 만든 디스크는 VM 저장경로에 함께 생성 되어있어 사용자가 파일탐색기로 경로를 찾아가보면 파일의 사이즈로 아 이것이 디스크 파일인가보구나 하고 알 수 있습니다 .( 용량이 크고 ...