반응형

하이퍼바이저(Hypervisor)란?

하이퍼바이저, 또는 가상 머신 모니터(VMM)라고도 불리는 이 소프트웨어 플랫폼은

단일 호스트 컴퓨터에서 여러 개의 게스트 운영체제(OS)를 동시에 실행할 수 있게 해주는 가상화 기술의 핵심 요소입니다.

하이퍼바이저는 물리적 하드웨어 자원을 가상화하여 각 가상 머신에 할당하고,

이를 통해 다양한 운영체제가 마치 독립된 컴퓨터에서 실행되는 것처럼 작동할 수 있도록 합니다.

 

상상해 보세요.

공항에는 한정된 수의 게이트가 있으며, 여러 항공사가 이 게이트를 통해 동시에 여러 비행기를 운항해야 합니다.

공항의 관리 시스템은 각 항공사에 필요한 게이트를 할당하고,

각 항공사가 자신의 비행 스케줄에 맞춰 효율적으로 게이트를 사용할 수 있도록 조정합니다.

 

이와 마찬가지로,

윈도우 운영 체제에서 하이퍼바이저는 컴퓨터의 하드웨어 자원(게이트와 같은)을 관리합니다.

여러 가상 머신(항공사의 비행기)이 동시에 이 자원을 공유하며 사용할 수 있도록 합니다.

예를 들어, 하이퍼바이저를 활용하면 한 컴퓨터에서

윈도우, 리눅스, 맥 OS와 같은 여러 운영체제를 동시에 실행할 수 있는

가상 머신들을 만들고 관리할 수 있습니다.

각 가상 머신은 마치 공항의 게이트를 할당받은 항공사처럼,

컴퓨터의 CPU, 메모리, 저장 공간 등의 자원을 할당받아 사용합니다.

하이퍼바이저는 이 모든 가상 머신들이 필요한 자원을 공정하게 받고,

서로 간섭 없이 효율적으로 작동하도록 돕습니다.

다시 돌아와서 하이퍼바이저는

내 컴퓨터에 가상 머신(vmware)을 이용하여

리눅스나 맥 다른 운영체제를 다운로드해 실행할 때

해당 OS (운영체제)에 필요한 리소스를 내 컴퓨터

하드웨어에서 할당받아 제공해 줍니다.

서로 다른 여러 개의 운영체제를 나란히 구동할 수 있으며,

VM을 모니터링하는 중간 관리

VMM(Virtual Machine Monitor)라고도 불립니다.

쉽게 설명하자면,

하이퍼바이저 (Hypervisor)는

가상 머신 속 OS들에게 자원을 나눠주며 조율하고

OS들의 커널을 번역해서 본 컴퓨터 하드웨어에게

알려주는 역할을 합니다.

 

커널이란?

https://jdcyber.tistory.com/67

 

커널(Kernel)이란 무엇일까? (개념, 이중 모드, 쉘의 역할)

커널(Kernel)은 컴퓨터 운영체제의 핵심 부분으로, 하드웨어 자원을 관리하고 응용 프로그램과 하드웨어 사이의 인터페이스 역할을 수행합니다. 이는 응용 프로그램이 시스템 호출을 통해 하드웨

jdcyber.tistory.com


하이퍼바이저의 주요 기능과 유형

  1. 전체 가상화(Full Virtualization)
    전체 가상화에서는 하이퍼바이저가 모든 하드웨어 호출을 포착하고 중재하여, 게스트 운영체제가 자신이 물리적 하드웨어 위에서 직접 실행되고 있는 것처럼 착각하게 만듭니다. 이 방식은 하드웨어 자원을 완전히 가상화하며, 게스트 OS는 하이퍼바이저를 통해서만 하드웨어 자원을 요청할 수 있습니다. 다시 말해, CPU 차원의 가상화는 하드웨어를 완전히 가상화하는 방식이므로 반드시 하이퍼바이저가 중간에서 중재하게 됩니다. 조금 더 세부적으로 살펴본다면, DOM0이 그 역할을 하게 되는데 각 가상머신은 DOM0에게 명령을 전달하고, DOM0에서 이를 해석하여 하이퍼바이저에게 알려주게 됩니다. (Vmware, ESX server, Hyper V, KVM)
  2. 반가상화(Paravirtualization)
    반가상화는 게스트 OS가 하이퍼바이저 존재를 인식하고, 하이퍼바이저와 직접 상호작용하는 것을 특징으로 합니다. 이 모델에서는 DOM0(도메인 제로)가 하이퍼바이저와 게스트 OS 사이의 중개자 역할을 하지 않고, 게스트 OS는 하이퍼 콜(Hyper-Call)이라는 특수한 API를 통해 하이퍼바이저에 직접 요청을 보냅니다. 이는 전체 가상화에 비해 성능 향상을 제공할 수 있습니다.

DOM0 이 무엇인지 알고 싶으신 분들은 아래 글을 참고해 주세요!

(작성 중)

 

Hyper-Cell이 무엇인지 알고 싶으신 분들은 아래 글을 참고해 주세요!

(작성 중)

하이퍼바이저의 구분

하이퍼바이저는 크게 두 가지 유형으로 나뉩니다

  1. Type 1 하이퍼바이저(Native or Bare-Metal Hypervisors): 이 유형의 하이퍼바이저는 직접 하드웨어 위에 설치되며, 하드웨어와 가상 머신을 관리하는 데 필요한 모든 기능을 갖추고 있습니다. 운영체제 없이 처음부터 하이퍼바이저를 설치해야 하며, 이는 보다 높은 성능과 보안을 제공합니다.
  2. Type 2 하이퍼바이저(Hosted Hypervisors): 호스트 운영체제 위에 설치되는 이 하이퍼바이저는 일반적인 소프트웨어 응용 프로그램처럼 작동합니다. 게스트 운영체제는 호스트 OS를 통해 간접적으로 하드웨어 자원을 접근하며, 이는 설치 및 관리가 상대적으로 쉽지만, Type 1 하이퍼바이저에 비해 성능 면에서 뒤떨어질 수 있습니다.

하이퍼바이저 기술은 현대 IT 인프라에서 중추적인 역할을 수행하며,

다양한 가상 환경을 가능하게 합니다.

기업들은 하이퍼바이저를 사용하여 하드웨어 비용을 절감하고,

시스템의 유연성을 높이며,

IT 자원을 보다 효과적으로 관리할 수 있습니다.

특히 클라우드 컴퓨팅, 대규모 데이터 센터,

개발 및 테스트 환경 구축에 있어서 가상화는 필수적인 기술로 자리 잡고 있습니다.

하이퍼바이저를 통한 가상화는

물리적 제약을 넘어서는 새로운 가능성을 제공하며,

기술의 발전과 함께 그 적용 범위와 효율성이 계속해서 개선되고 있습니다.

 

앞으로도 기술 발전에 따라 더욱 향상된 성능과 보안을 갖춘

하이퍼바이저 솔루션이 등장할 것으로 기대됩니다.

이처럼 하이퍼바이저는 비단 복잡한 기술 환경뿐만 아니라

일상적인 비즈니스 운영에도 중요한 역할을 하고 있으며,

그 중요성은 점점 더 커질 것입니다.


궁금하신 사항은 댓글에 남겨주세요

댓글에 남겨주신 내용

추후 정리해서 올려드리겠습니다

구독 신청하시면 업로드 시 알려드릴게요!

-

조금이라도 도움이 되셨다면

공감&댓글 부탁드리겠습니다

감사합니다!

반응형
반응형

오늘은 최적의 프로그래밍 언어를 선택하는
가이드 글을 작성해 보겠습니다.

현대 IT 산업에서 프로그래밍 언어의 역할은 중요하며,
다양한 언어가 각자의 특성과 용도로 활용됩니다.
개발자가 되려는 초보자든, 경력을 확장하고자 하는 전문가든,
적절한 프로그래밍 언어 선택은 경력의 방향을 결정짓는 핵심 요소입니다.
이 글에서는 주요 프로그래밍 언어의 특성과 각 언어가 어울리는 사용 환경에 대해 자세히 탐구하고,
독자의 필요와 목표에 맞는 언어를 선택할 수 있는 방법을 제공하겠습니다.


  1. 프로그래밍 언어의 역할과 중요성
    • 프로그래밍 언어는 소프트웨어 개발의 기반입니다.
      각 언어는 특정 도메인이나 작업에 적합한 독특한 특성과 기능을 가지고 있습니다.
      예를 들어, 웹 개발, 시스템 프로그래밍, 모바일 애플리케이션 개발 등 각 분야에서 선호되는 언어가 다릅니다.
  2. 주요 프로그래밍 언어의 특징 및 적용 분야
    • Python: 직관적인 문법과 높은 가독성으로 초보자에게 추천됩니다. 데이터 과학, 웹 개발, 자동화 등 다양한 분야에서 널리 사용됩니다.
    • Java: 플랫폼 독립적이며, 대규모 시스템 개발에 적합합니다. 안드로이드 앱 개발과 엔터프라이즈 급 애플리케이션에 주로 사용됩니다.
    • JavaScript: 웹 프론트엔드 개발에 필수적이며, Node.js를 통해 백엔드에서도 활용됩니다.
    • C 언어: 시스템 프로그래밍과 임베디드 시스템 개발에 이상적입니다. 고성능이 요구되는 어플리케이션에 주로 사용됩니다.
    • C++: C의 직접적인 확장으로, 게임 개발, 실시간 시스템, 고성능 서버 등에서 사용됩니다.
    • C#: 주로 마이크로소프트의 .NET 프레임워크에서 사용되며, 게임 개발(Unity 엔진 사용)에도 인기가 있습니다.
    • PHP: 서버 측 웹 개발에 강력하며, WordPress와 같은 CMS 개발에 자주 사용됩니다.
    • HTML/CSS: 웹 페이지의 구조와 스타일을 정의하는 데 필수적입니다.
    • Swift: iOS 및 macOS 애플리케이션 개발에 사용되며, Apple 생태계에서 매우 중요합니다.
    • Kotlin: Android 개발에 최적화된 언어로, Java의 대안으로 빠르게 자리잡고 있습니다.
  3. 언어 선택 시 고려해야 할 요소
    • 목적 및 프로젝트 요구 사항: 개발하고자 하는 애플리케이션의 유형에 따라 적합한 언어를 선택해야 합니다.
    • 학습 곡선: 언어의 복잡성과 학습 자원의 가용성을 고려하세요.
    • 커뮤니티 및 지원: 강력한 개발자 커뮤니티와 충분한 학습 자료가 있는 언어는 시작하기에 좋습니다.
    • 경력 전망 및 시장 수요: 직업 시장에서의 수요와 경력 전망도 중요한 선택 요소입니다.

Github Push 순위 (22년 1분기)

Github에서 Push는 자신이 작업한 내용을 깃허브 서버에 올리는 기능입니다. 
2022년 1분기 Push 기능에서 자주 사용된 개발 언어 순위 1~10위는 아래와 같습니다.

1
Python
2
Java
3
JavaScript
4
C++
5
PHP
6
TypeScript
7
C
8
Go
9
Shell
10
Ruby

Tiobe 프로그래밍 언어 순위 (22년)

TIOBE는 소프트웨어 사용성과 소스 코드의 품질을 검사하고 관리하는 회사로
TIOBE Index를 통해 개발 언어의 인기 순위를 알려줍니다.
프로그래밍 언어 순위는 한 달에 한 번씩 업데이트되며
산정 기준은 구글, Bing, 야후, 위키피디아, 아마존, 유튜브와 같은
인기 검색 엔진 검색 빈도수에 더해 소프트웨어의 프로그래밍 언어 사용량을 기반으로 합니다.
2022년 9월 Tiobe index 프로그래밍 언어 순위는 아래와 같습니다.

1
Python
2
C
3
Java
4
C++
5
C#
6
Visual Basic
7
JavaScript
8
Assembly language
9
SQL
10
PHP

파이썬과 자바가 항상 높은 순위에 있네요!


그렇다면 나는 어떤 언어를 공부해야 할까요?

어느 한 곳에서 완벽한 프로그래밍 언어는 없습니다. 
특정 분야에서 강점을 가지면, 다른 분야에서 약점을 가지기 마련입니다. 
 
C나 C++ 같은 언어는 속도가 빠르지만, 배우기 어렵고 개발하는데 시간이 다른 언어들에 비해 오래 걸립니다. 
Python 같은 언어는 개발 속도가 빠르고 가독성이 높다는 장점은 있지만 실행 속도가 다른 언어들에 비해 느립니다.  
이와 같이 목적과 하고자 하는 일의 특성에 따라 선호되는 언어가 다릅니다. 
그래서 우리는 하고자 하는 일을 명확히 파악하고 가중치를 두어 언어를 선택해야 합니다. 
 
여러분은 프로세스와 관련된 서버(server-side)와 데이터베이스를 관리해 주는 백엔드를 하고 싶으신가요? 
사용자와 직접 만나 부딪히는 레이아웃을 고민하고 짜는 프론트앤드를 하고 싶으신가요?
데이터를 분석하고 솔루션을 내주는 데이터 분석가가 되고 싶으신가요?


프로그래밍 언어를 선택하는 것은 당신의 경력 목표, 관심 있는 기술 영역,
그리고 학습할 준비가 되어 있는 어려움의 수준에 따라 달라집니다.
여기서는 프론트엔드와 백엔드 개발에 필요한 주요 프로그래밍 언어와
그 사용 목적을 명확하게 구분하여 표로 정리해 보겠습니다.
아래 표는 각 언어가 어떻게 활용되는지,
어떤 분야에 적합한지에 대한 간략한 가이드를 제공해 보겠습니다.


프론트엔드 개발

언어/기술목적추가 공부 추천
HTML웹 페이지의 구조 설계-
CSS웹 페이지의 스타일링과 레이아웃 디자인-
JavaScript동적인 웹 페이지 기능 구현AngularJS, ReactJS, Bootstrap

프론트엔드 개발자는 사용자 인터페이스를 생성하고 개선하는 역할을 담당합니다.
이를 위해 웹 표준 기술인 HTML과 CSS를 통해 웹의 구조와 스타일을 정의하고,
JavaScript로 웹 페이지에 상호작용을 추가합니다.
또한, AngularJS나 ReactJS 같은 모던 자바스크립트 프레임워크를 학습하여
더 복잡하고 동적인 웹 애플리케이션을 구축할 수 있습니다.


백엔드 개발

언어목적추가 정보
PHP웹 서버 스크립트 및 콘텐츠 관리 시스템 개발-
Node.js서버 사이드 스크립트 구현JavaScript 기반
C++고성능 백엔드 서비스 개발-
Java대규모 엔터프라이즈 시스템 및 안드로이드 앱-
Python데이터 처리 및 백엔드 로직 개발빅 데이터, 인공지능 분야 선호

백엔드 개발자는 클라이언트(사용자)가 볼 수 없는 서버, 애플리케이션, 데이터베이스 관리 등을 담당합니다.
이들은 사용자 요청을 처리하고 적절한 출력을 제공하는 로직을 구현합니다.
PHP, Node.js, Java, Python 등 다양한 언어가 백엔드 개발에 활용되며,
선택은 프로젝트 요구 사항과 개인의 기술 선호도에 따라 달라질 수 있습니다.


개발 분야별 언어 추천

관심 분야추천 언어
웹 개발HTML, CSS, JavaScript, PHP, Ruby
안드로이드 앱 개발Kotlin
iOS 앱 개발Swift
데이터 분석Python
시스템 프로그래밍C, C++
범용 프로그래밍Java, C

 
어떤 언어를 선택하여 공부하기로 마음먹는 계획보다 가장 중요한 것은
오늘부터 시작하세요
언어를 선택하여 시작했지만 굉장히 지루할 수도 재미있을 수 도 있습니다.
각자의 성향은 다양하니까요
그래서 우선 시작하고 맞지 않는 것 같다면 과감하게 다른 언어로 다시 시도해 보는
경험이 굉장히 중요할 것 같습니다.
계획을 잡고 어떻게 공부해야 하는지 어려움이 있으시다면 아래 글을 참고해 보세요!

https://jdcyber.tistory.com/15

프로그래밍 언어 어떤 걸 먼저 배워야할까? (쉬운 설명, 특징, 목적, 파이썬, 자바, 자바 스크립트

수많은 프로그래밍 언어 도대체 뭘 먼저 배워야 해? 개발을 처음 배우거나 보안을 배우거나 iT업계로 들어올 때 수많은 컴퓨터 언어를 보고 멘붕이 오실 겁니다. 저걸 다 해야 하나..? 어떤 언어

jdcyber.tistory.com

https://jdcyber.tistory.com/13

개발자 입문부터 풀스택까지 로드맵 (공부 순서를 어떻게 해야 하나요?)

앞서 2가지 프로그래밍 언어를 소개하는 글을 통해서 어떤 프로그래밍 언어를 배워야 하는지 그 프로그래밍 언어는 어떤 것에 특화가 되어있고 목표로 잡은 것이 어떤 것이냐에 따라 달라진다

jdcyber.tistory.com


 
궁금하신 사항은 댓글에 남겨주세요
댓글에 남겨주신 내용
추후 정리해서 올려드리겠습니다
구독 신청하시면 업로드 시 알려드릴게요!
-
조금이라도 도움이 되셨다면
공감&댓글 부탁드리겠습니다
감사합니다!

반응형
반응형

ISP (Internet service provider)

 

인터넷 서비스 제공자(ISP)는 우리가 일상에서 무심코 사용하는 인터넷을 가능하게 하는 핵심 업체입니다.

이 글에서는 ISP가 무엇인지, 그들이 어떤 일을 하는지,

그리고 우리에게 어떤 영향을 미치는지에 대해 알아봅니다.

또한, ISP의 중요 기능인 DHCP와 DNS에 대해서도 간략하게 설명합니다.

 

ISP란?

ISP(Internet Service Provider)는 인터넷 서비스 공급자를 의미하며,

개인이나 기업에 인터넷 접속 서비스를 제공하는 업체입니다.

ISP는 데이터 전송, 인터넷 연결, 도메인 이름 시스템(DNS) 관리,

동적 호스트 구성 프로토콜(DHCP) 서비스 등을 통해 인터넷 사용자와 웹사이트를 연결합니다.

ISP의 역할

  1. 인터넷 연결 제공: ISP는 광케이블, DSL, 위성 연결 등 다양한 방식을 통해 사용자에게 인터넷 접속을 제공합니다.
  2. IP 주소 할당: DHCP(Dynamic Host Configuration Protocol) 서버를 사용하여 장치에 동적으로 IP 주소를 할당합니다.
    이를 통해 장치가 인터넷에 연결될 때마다 새로운 IP 주소를 받거나 기존 주소를 재사용할 수 있습니다.
  3. 도메인 이름 관리: DNS(Domain Name System) 서버를 통해 사람이 읽을 수 있는 도메인 이름(예: www.example.com)을 숫자로 된 IP 주소로 변환합니다. 이 과정은 인터넷 브라우징을 용이하게 합니다.

2020년, 많은 사람들이 재택근무를 시작함에 따라 전 세계적으로 인터넷 사용량이 크게 증가했습니다.

이로 인해 인터넷 서비스 제공업체(ISP)는 전례 없는 데이터 트래픽 증가에 직면하게 되었습니다.

특히, KT, SK브로드밴드, LG유플러스와 같은 국내 대표 ISP 업체들은

사용자들에게 안정적이고 빠른 인터넷 서비스를 지속적으로 제공하기 위해

몇 가지 주요 기술적 조치를 취했습니다.

네트워크 용량 확장

이 업체들은 기존의 인프라를 업그레이드하고 추가적인 네트워크 용량을 확보하기 위해 대규모 투자를 단행했습니다.

이는 광섬유 네트워크를 확장하고,

데이터 센터의 서버 용량을 증가시키는 등의 작업을 포함했습니다.

광섬유 네트워크는 데이터 전송 속도가 매우 빠르며,

많은 양의 데이터를 처리할 수 있어 인터넷 사용량이 급증하는 상황에 매우 적합합니다.

트래픽 분산 기술 적용

ISP는 네트워크 트래픽을 효율적으로 관리하고 분산시키기 위해 여러 기술을 도입했습니다.

예를 들어,

CDN(Content Delivery Network)과 같은 기술을 사용하여 사용자에게 더 가까운 위치에서 콘텐츠를 제공함으로써

트래픽을 분산시키고, 웹사이트 로딩 속도를 개선했습니다.

CDN은 전 세계에 분산된 서버 네트워크를 통해 사용자의 요청에 가장 가까운 서버에서 콘텐츠를 제공함으로써,

데이터 전송 거리를 줄이고 속도를 향상시킵니다.

네트워크 최적화

데이터 트래픽의 증가에 대응하기 위해,

ISP는 네트워크 최적화 기술을 적극적으로 활용했습니다.

이는 네트워크의 효율성을 높이고,

오버로드를 방지하기 위한 조치로,

QoS(Quality of Service) 설정을 조정하여 긴급한 데이터 트래픽이 우선적으로 처리될 수 있도록 했습니다.

예를 들어,

영상회의와 같은 실시간 통신은 웹 브라우징보다 높은 우선순위를 받아,

트래픽이 많은 상황에서도 안정적인 서비스를 제공할 수 있습니다.

 

이러한 조치를 통해, KT, SK브로드밴드, LG유플러스와 같은 ISP 업체들은

재택근무와 온라인 학습이 대폭 증가한 상황에서도

사용자들이 중단 없이 고품질의 인터넷 서비스를 경험할 수 있도록 지원했습니다.

이는 우리가 디지털 환경에서 더 연결되고 생산적으로 일하고

생활할 수 있게 하는 중요한 기반이 되었습니다.

우리나라의 대표 ISP 업체

KT, SK브로드밴드, LG유플러스

이 업체들은 국내 인터넷 서비스 시장에서 중요한 역할을 하며,

개인과 기업에 다양한 인터넷 관련 서비스를 제공합니다.

DHCP, DNS의 중요성

DHCP는 네트워크에 연결된 장치에 자동으로 IP 주소를 할당하는 프로토콜입니다.

이는 네트워크 관리자가 수동으로 각 장치에 IP 주소를 할당하는 번거로움을 줄여줍니다.

 

DHCP에 대해 아직 모르신다면 아래 글을 참고해 주세요

(작성 중)

 

DNS는 인터넷의 전화번호부와 같은 역할을 합니다.

사용자가 웹사이트의 도메인 이름을 브라우저에 입력할 때,

DNS 서버가 해당 이름을 IP 주소로 변환하여 실제 웹사이트의 위치를 찾아줍니다.

이는 웹 검색과 브라우징을 매우 편리하게 만듭니다.

 

DNS에 대해 아직 모르신다면 아래 자세하고 쉬운 설명 글 한번 참고해 주세요

https://jdcyber.tistory.com/63

 

DNS란 무엇일까? (쉬운 설명, 개념)

DNS (Domain Name System) DNS는 이름만 어렵지 개념은 쉽습니다. DNS (Domain Name System)는 인터넷에서 도메인 이름을 IP 주소로 변환하는 시스템입니다. 이 시스템은 인터넷의 전화번호부와 같아서 사용자

jdcyber.tistory.com


인터넷 서비스 제공업체(ISP)는 우리가 온라인상에서 활동할 수 있게 하는 것 이상의 역할을 수행합니다.

그들은 단순히 웹 접속을 넘어서 우리의 디지털 생활 방식을 지원하고 풍부하게 만드는 필수적인 역할을 합니다.

DHCP와 DNS와 같은 중요 기술을 통해,

ISP들은 사용의 용이성과 인터넷의 효율성을 대폭 향상시켜왔습니다.

이러한 기술은 웹 페이지 접속부터 온라인 게임, 스트리밍 서비스까지,

우리가 인터넷을 통해 하는 거의 모든 활동의 기반이 됩니다.

또한, ISP는 사이버 보안, 데이터 프라이버시 보호,

그리고 끊임없이 변화하는 기술 트렌드에 대응하기 위한 연구와 혁신을 지속적으로 추진하고 있습니다.

현대 사회의 디지털 변혁에 있어 ISP의 역할은 점점 더 중요해지고 있습니다.

5G, 사물인터넷(IoT), 인공지능(AI)과 같은 신기술의 보급과

활용을 촉진하는 데 있어 중심축 역할을 하고 있습니다.

이러한 기술들은 인터넷의 속도와 연결성을 향상시키는 동시에,

우리의 일상생활을 더욱 편리하고 서로 연결된 세상으로 변화시키고 있습니다.

이들의 발전은 우리가 디지털 세계에서 경험하는 모든 것을 더욱 풍부하고 접근하기 쉽게 만들 것입니다.

인터넷의 속도가 빨라지고, 연결성이 개선되며, 새로운 기술이 우리 삶에 통합됨에 따라,

ISP의 역할은 더욱 중요해질 것입니다.

결국, ISP는 단순한 기술 서비스 제공자를 넘어서,

현대 사회에서 디지털 연결성과 정보 접근성을 가능하게 하는 기반이 됩니다.

이러한 연결성은 우리의 일, 학습, 오락, 그리고 사회적 상호작용의 방식을 근본적으로 변화시키고 있으며,

이 모든 것의 중심에는 ISP가 있습니다.

우리의 디지털 미래는 ISP의 혁신적인 발전과 그들이 제공하는 서비스의 질에 크게 의존하게 될 것입니다.


궁금하신 사항은 댓글에 남겨주세요

댓글에 남겨주신 내용

추후 정리해서 올려드리겠습니다

이웃 신청하시면 업로드 시 알려드릴게요!

-

조금이라도 도움이 되셨다면

공감&댓글 부탁드리겠습니다

감사합니다!

반응형
반응형

DNS (Domain Name System)

DNS는 이름만 어렵지 개념은 쉽습니다.

DNS (Domain Name System)는 인터넷에서 도메인 이름을 IP 주소로 변환하는 시스템입니다.

이 시스템은 인터넷의 전화번호부와 같아서

사용자가 쉽게 기억할 수 있는 도메인 이름(예: www.google.com)으로

웹 사이트에 접속할 수 있게 해 줍니다.

컴퓨터나 인터넷에 연결된 모든 장치는 고유한 IP 주소를 가지고 있으며,

DNS 서버는 이 주소를 사용하여 데이터를 올바른 목적지로 전달합니다.

 

컴퓨터는 모두 자신의 이름과 같은

iP 주소를 갖고 있다고 말씀드렸습니다.

iP가 뭔지 모르신다면 아래 글을 확인해 주세요

https://jdcyber.tistory.com/27

 

iP 주소란 무엇일까? (쉬운 설명, 개념, 정의, 호스트 아이디, 네트워크 아이디, 서브넷 마스크)

iP 주소란 무엇인가요? 정답은 컴퓨터마다 가지고 있는 주소 즉 이름입니다. 192.168.123.132 위와 같은 형태의 아이피 주소를 많이 보셨을겁니다. 위와 같이 A컴퓨터 너의 이름은 오늘부터 192.168.123.1

jdcyber.tistory.com

 

iP 주소는 네트워크상에서 컴퓨터나 장치를 식별하는 데 사용되는 숫자로 이루어진 주소입니다.

이 주소는 일반적으로 네트워크 ID, 호스트 ID, 서브넷 마스크 등으로 구성되며,

각각의 장치는 고유한 IP 주소를 할당받습니다.

우리가 흔히 접속하는 네이버, 구글 같은 웹사이트부터

스마트폰 노트북 그리고 서버에 이르기까지

인터넷상의 모든 컴퓨터는 숫자를 이용하여

서로 소통하고 통신합니다.

인터넷 사이트 주소

원래는 긴 숫자 형태로 이루어져 있는데요

이 숫자를 매번 외워서 칠 수 없으니

우리는 쉽게 www.example.com의 형태

접속하여 편리하게 이용하고 있습니다.

그렇다면 긴 숫자로 이루어진 원래 주소 형태가

어떻게 www.example.com으로 매칭이 되는 걸까요?

이것이 바로 DNS 서버가 하는 일입니다.


사용자가 웹사이트에 접속하려고 할 때,

예를 들어 "www.example.com"을 브라우저에 입력하면,

사용자의 장치는 먼저 DNS 서버에 해당 도메인 이름에 대응하는 IP 주소를 요청합니다.

DNS 서버는 도메인 이름과 매칭되는 IP 주소를 찾아

사용자의 요청을 해당 IP 주소로 리디렉션하여 사용자가 웹사이트에 접속할 수 있게 합니다.

이 과정은 사용자에게는 보이지 않고 매우 빠르게 이루어집니다.

다시 한번 설명해보겠습니다.

예를 들어 유저가 브라우저에서

testsite.com을 검색했다면,

먼저 DNS 서버로 testsite.com이라는

도메인 주소가 전달이 됩니다.

(도메인 주소는 12.12 3.123.123이라고 가정합시다.)

그리고 서버 내부에서 도메인 주소를 토대로

testsite.com = 12.12 3.123.123이라는항목을 찾아내고

다시 브라우저에게 12.123.123.123의 IP 주소를 갖고 있는

호스팅 서버 (해당 웹사이트 데이터가 저장된 곳)으로 가라고 지시합니다.

그러면 브라우저가 IP 주소로 접속해서 웹사이트가 보이게 됩니다.

브라우저가 잠깐 사이에 이런 과정을 처리하는 것이죠.

 

이 요청을 쿼리라고 부릅니다.

쿼리 요청이란?

(작성 중)

그렇다면 DNS 서버는 누가 가지고 있을까요?

바로 ISP 업체입니다.

DNS 서버는 일반적으로 인터넷 서비스 제공업체(ISP)에 의해 관리됩니다.

KT, LG U+, SKT와 같은 대형 ISP는 자체 DNS 서버를 운영하며,

사용자는 이러한 서버를 통해 인터넷에 접속합니다.

또한, Google DNS와 같은 공개 DNS 서비스를 사용하는 것도 가능하며,

이는 때로 더 빠른 인터넷 속도나 우회 접속 등의 목적으로 사용됩니다.

 

ISP에 대해 모르신다면 아래 글을 참고해 주세요

(작성 중)

 

위 ISP 업체들이 갖고 있는 DNS 서버의 주소는 아래와 같습니다.

SKT
기본 DNS 서버 : 219.250.36.130
보조 DNS 서버 : 210.220.163.82
KT
기본 DNS 서버 : 168.126.63.1
보조 DNS 서버 : 168.126.63.2
LG
기본 DNS 서버 : 164.124.101.2
보조 DNS 서버 : 203.248.252.2
Google
기본 DNS 서버 : 8.8.8.8
보조 DNS 서버 : 8.8.4.4

이 시스템의 중요성은 인터넷 사용의 편리함을 크게 향상합니다.

복잡한 숫자로 이루어진 IP 주소를 기억할 필요 없이,

사용자는 도메인 이름을 통해 웹사이트에 쉽게 접근할 수 있습니다.

DNS는 따라서 인터넷의 기본적인 인프라로서,

모든 온라인 활동의 백본 역할을 합니다.


오늘은 DNS에 대해 알아봤는데요

알고 보면 쉬운데 대부분 개념을 잘 못 잡고

바로 공부에 들어가서

DNS 서버 설정부터 해버리니

어려우실 수밖에 없을 것 같습니다.

다음 글은 좀 더 쉽게 써보도록 노력하겠습니다.


궁금하신 사항은 댓글에 남겨주세요

댓글에 남겨주신 내용

추후 정리해서 올려드리겠습니다

이웃 신청하시면 업로드 시 알려드릴게요!

-

조금이라도 도움이 되셨다면

공감&댓글 부탁드리겠습니다

감사합니다!

반응형
반응형

최근 소프트웨어 개발 도구의 보안에 대한 관심이 증가하고 있습니다.

특히, 오픈소스 컴포넌트를 사용하는 도구들이 많아지면서

이러한 컴포넌트들에서 발견되는 취약점에 대한 우려도 함께 커지고 있습니다.

 

이 글은 유명한 코드 에디터의 오픈소스 컴포넌트에서 발견된 취약점에 대해 이야기합니다.

이 코드 에디터는 전 세계 개발자들 사이에서 널리 사용되고 있으며,

특히 그중 하나의 컴포넌트가 포함하고 있는 오래된 브라우저의 버전에서 발견된

여러 보안 취약점이 아직까지 해결되지 않은 채 업데이트되고 있습니다.

러한 취약점들은 실제 공격에서 이미 이용된 바 있으며,

이를 통해 원격 코드 실행, 정보 유출, 서비스 거부 등 다양한 보안 위협이 가능해집니다.

이는 사용자의 시스템 보안을 심각하게 위협할 수 있습니다.

 

처음 확인이 된 (글쓴이는 해당 버전에서 처음 식별했습니다.) 1.85.2 버전부터

2024년 4월 4일 현재 사이트에서 배포 중인 1.87.2 버전에 이르기까지,

exten****. js 파일에 포함된 Fire*** 71.0 오픈소스 컴포넌트에서

5 가지 치명적인 오픈소스 취약점이 여전히 해결되지 않은 채 업데이트되고 있습니다.

 

5가지의 취약점 코드와 내용은 아래와 같으며,

CISA가 관리하는 알려진 이용된 취약점(KEV) 카탈로그에서 발췌하였습니다.

 

KEV는 미국 CiSA가 실제 공격에서 이용된 취약점들을 나열한 권위 있는 자료입니다.

이 카탈로그는 조직들이 취약점 관리를 우선순위에 두고 사이버 보안 조치를 강화하는 데 중요한 입력 정보를 제공합니다.

자세한 정보는 CISA 공식 웹사이트에서 확인할 수 있습니다​ (CISA)​.

https://www.cisa.gov/known-exploited-vulnerabilities-catalog

 

Known Exploited Vulnerabilities Catalog | CISA

For the benefit of the cybersecurity community and network defenders—and to help every organization better manage vulnerabilities and keep pace with threat activity—CISA maintains the authoritative source of vulnerabilities that have been exploited in

www.cisa.gov

CVE-2022-26486 2022년 3월 7일 웹GPU IPC 프레임워크에서 예기치 않은 메시지로 인해 발생하는 사용 후 해제(use-after-free) 취약점. 원격 공격자가 샌드박스 탈출을 시도할 수 있음.
CVE-2022-26485 2022년 3월 7일 웹GPU IPC 프레임워크에서 비정상적인 메시지 처리로 인한 사용 후 해제(use-after-free) 취약점. 원격 코드 실행 가능성을 내포함.
CVE-2020-6820 - 메모리 안전성 문제로 인해 발생할 수 있는 취약점. 악의적인 웹 페이지를 통해 사용자 시스템에서 임의 코드 실행을 시도할 수 있음.
CVE-20206819 - CVE-2020-6819는 특정 조건 하에서 nsDocShell destructor 실행 중 경쟁 상태로 인해 사용 후 해제(use-after-free)가 발생할 수 있는 취약점입니다. 이는 Thunderbird, Firefox, 및 Firefox ESR의 특정 버전에 영향을 미칩니다. 이 취약점은 실제 공격에서 이용되었습니다.
CVE-2019-17026 - IonMonkey JIT 컴파일러의 타입 혼동 취약점. 악의적인 JavaScript 실행을 통한 임의 코드 실행이 가능.

 

자세한 취약점에 대한 정보는 아래 링크를 통해 확인해 주세요

https://nvd.nist.gov/vuln

 

NVD - Vulnerabilities

All vulnerabilities in the NVD have been assigned a CVE identifier and thus, abide by the definition below. CVE defines a vulnerability as: "A weakness in the computational logic (e.g., code) found in software and hardware components that, when exploited,

nvd.nist.gov

 

해당 취약점 5가지는 코드 에디터에 포함된 exten****. js 파일에

오픈소스 컴포넌트인 Fire*** 71.0에 포함되어 있으며,

이미 해커에게 공격당하여 빠르게 패치를 하라고 권고한 취약점입니다.

 

아래는 exten****. js 파일이 해당 코드 에디터에서 어떤 역할을 하는지 인공지능 챗 지피티에게 문의해 봤습니다.

 

추가적으로 ChatGPT는 해당 이슈에 대해 이렇게 이야기하고 있습니다.

해당 컴포넌트에서 발견된 취약점을 통해 공격자는 원격 코드 실행, 정보 유출, 서비스 거부(DoS) 공격 등 다양한 위협을 가할 수 있습니다. 이는 사용자 시스템의 보안을 심각하게 위협하며, 공격자에게 시스템 제어권을 부여할 수도 있습니다.

 

현재 제 주변에 있는 모든 개발자가 해당 소프트웨어를 사용 중에 있습니다.

이는 엄청난 취약점이며, 고쳐져야 하는 사안으로

제 지인에게는 다른 개발 도구를 추천드리고 있습니다.

 

소프트웨어의 보안은 그 어느 때보다 중요하며,

특히 오픈소스 컴포넌트의 취약점은 개발자와 사용자 모두에게 심각한 위협이 될 수 있습니다.

오픈소스 컴포넌트의 취약점을 주의 깊게 관리하는 것은 소프트웨어 개발의 중요한 부분입니다.

주변 친구들이 해당 소프트웨어를 사용 중이라면 해당 내용을 공유해 주시길 바랍니다.

사용 중인 도구들이 최신 상태로 유지되고 보안 위협으로부터 보호되도록,

적극적으로 패치 적용과 보안 권장 사항을 따르는 것이 필수적입니다.

이런 실천을 통해 우리는 더 안전한 디지털 환경을 조성할 수 있습니다.

 

해당 이슈에 대해서는 고객센터 팀에게 위와 같이 메일을 보내 놓은 상태입니다.


궁금하신 사항은 댓글에 남겨주세요

댓글에 남겨주신 내용

추후 정리해서 올려드리겠습니다

구독 신청하시면 업로드 시 알려드릴게요!

-

조금이라도 도움이 되셨다면

공감&댓글 부탁드리겠습니다

감사합니다!

 

반응형

+ Recent posts