JVM(Java Virtual Machine)

JVM(Java Virtual Machine)이란 자바 프로그램이 실행되는 가상 머신입니다. 자바 언어는 특정한 OS(리눅스윈도우 등)에 종속되지 않고 여러 플랫폼에서 실행될 수 있도록 고안되었는데 이것을 가능하게 해주는 핵심적인 요소가 JVM입니다.

Java Virtual Machine은 자바 애플리케이션을 실행하기 위한 환경을 제공하며, 자바 소스 코드를 컴파일하여 바이트 코드로 변환하고 이를 실행합니다. 이렇게 변환된 바이트 코드는 JVM에서 실행되며, JVM은 해당 플랫폼에 맞게 이를 해석하고 실행합니다.

기본적으로 자바 가상 머신(JVM)은 다른 프로그램을 실행하는 것이 목적인 프로그램입니다.

바이트 코드란?

바이트코드(Bytecode, portable code, p-code)는 특정 하드웨어가 아닌 가상 컴퓨터에서 돌아가는 실행 프로그램을 위한 이진 표현법이다. 하드웨어가 아닌 소프트웨어에 의해 처리되기 때문에, 보통 기계어보다 더 추상적이다.

역사적으로 바이트코드는 대부분의 명령 집합이 0개 이상의 매개 변수를 갖는 1바이트 크기의 명령 코드(opcode)였기 때문에 바이트코드라 불리게 되었다. 바이트코드는 특정 하드웨어에 대한 의존성을 줄이고, 인터프리팅도 쉬운 결과물을 생성하고자 하는 프로그래밍 언어에 의해, 출력 코드의 한 형태로 사용된다.

출처: 위키피디아 바이트코드
서버실 배경의 JVM 이미지

✅ JVM의 4가지 기본 기능

크게 2가지 기본 기능을 생각할 수 있습니다.

  • 바이트 코드 실행
  • 자바 컴파일러에 의해 생성된 바이트 코드(.class 파일)를 실행하는 역할을 합니다. 이러한 바이트 코드는 JVM에서 실행되며, JVM은 해당 플랫폼에 맞게 해석하고 실행합니다.
  • 메모리 관리
  • 메모리 할당 및 해제, 가비지 컬렉션(Garbage Collection)을 통한 메모리 관리를 담당합니다. 이를 통해 자바 프로그램에서 사용되는 메모리를 효율적으로 관리하고 최적화 할 수 있습니다.
  • 예외 처리
  • 자바 프로그램에서 발생하는 예외 상황을 처리하고 관리합니다. 이는 프로그램이 예기치 않은 상황에 대처할 수 있도록 도와줍니다.
  • 스레드 관리
  • 다중 스레드를 관리하고 스레드 스케줄링을 수행하여 자바 프로그램에서의 병렬 처리를 지원합니다.

✅ 가비지 컬렉션(Garbage collection)

가비지 컬렉션(Garbage Collection)은 프로그래밍 언어에서 동적으로 할당된 메모리 중에서 더 이상 사용되지 않는 메모리를 자동으로 식별하고 해제하는 프로세스를 말합니다. 주로 메모리 누수(memory leak)를 방지하고 프로그램의 메모리 관리를 지원하기 위해 사용됩니다.

프로그래밍 언어에서는 메모리를 할당하고 사용한 뒤 해제하는데, 때로는 사용하지 않는 메모리를 명시적으로 해제하지 않을 수 있습니다. 이 때 사용하지 않는 메모리 영역이 계속해서 쌓이면 메모리 누수가 발생할 수 있습니다. 가비지 컬렉션은 이러한 문제를 방지하기 위해 사용되며, 자동으로 더 이상 필요하지 않은 메모리를 확인하고 회수합니다.

자바의 JVM은 프로그램의 메모리 관리를 담당합니다. 프로그램 실행 중에 메모리 할당과 해제, 효율적인 자원 사용을 위한 가비지 컬렉션 등을 수행합니다. 프로그래머는 일반적으로 실행 중인 Java Virtual Machine과 상호 작용하여 메모리 사용량을 확인하고 Java Virtual Machine의 메모리 설정을 조정하여 성능을 최적화 합니다.

이전에는 C++과 같은 언어에서 프로그래머가 메모리 관리를 직접 처리해야 했지만, 자바에서는 Java Virtual Machine이 이를 대신합니다.Java Virtual Machine은 실행 중인 Java Virtual Machine 프로그램에서 사용되지 않는 메모리를 식별하고 가비지 컬렉션을 통해 해당 메모리를 자동으로 회수합니다.

초기에 자바는 성능 면에서 C++에 비해 떨어진다는 비판을 받았는데, 이는 가비지 컬렉션과 메모리 관리 때문이었습니다. 그러나 시간이 지나면서 가비지 컬렉션 알고리즘과 접근 방식이 계속 발전하여 성능이 향상되었습니다.

이러한 발전은 자바 뿐만 아니라 다른 현대 언어에서도 자동 메모리 관리를 통해 소프트웨어 개발을 훨씬 편리하게 만들었습니다. JavaScript나 Python과 같은 다른 언어에서도 자동 메모리 관리가 흔히 사용되고 있습니다.

Java, Desktop

Similar Posts

  • MySQL과 MariaDB 차이점

    MySQL과 MariaDB는 둘 다 오픈 소스 데이터베이스입니다. 데이터베이스에서 행과 열이 있는 테이블(표) 형식으로 데이터를 저장하고 관리할 수 있습니다. 수 많은 웹사이트와 애플리케이션에서 사용하고 있으며, MySQL은 1994년에 개발을 시작해 2010년에 선마이크로시스템에 인수되었으며, 같은 해 선마이크로시스템이 오라클에 인수되면서 오라클의 서비스가 되었습니다. 목차✅ JVM의 4가지 기본 기능✅ 가비지 컬렉션(Garbage collection)MySQL 현재 MySQL은 교육용과 개인에게는 무료(오픈 소스)로…

  • 리눅스 디바이스 드라이버 | 장치 파일(Device File) | /dev 디렉토리

    리눅스는 모든 것을 파일로 관리합니다. 리눅스에는 장치 파일(Device File)은 여러 프로그램에서 시스템에 설치된 하드웨어에 접근할 수 있게 하는 파일입니다. 디바이스를 구동하기 위해 리눅스 디바이스 드라이버가 필수 요구 사항입니다. 리눅스 시스템이 마우스 장치 파일을 참조해서 마우스의 조작을 하게 하거나 프린트의 출력 등을 담당하는 것을 생각할 수 있으며, 주로 스토리지를 마운트 하는데 많이 사용된다고 할…

  • GeoIP 국가 코드표 정리 목록

    아파치 서버에서 사용할 수 있는 GeoIP 국가 코드표 정리 목록입니다. 목차✅ JVM의 4가지 기본 기능✅ 가비지 컬렉션(Garbage collection)GeoIP란? GeoIP는 maxmind에서 제공하는 모듈과 IP 정보 DataBase를 이용해서 웹에 접근하는 IP를 국가 별로 확인할 수 있는 오픈소스솔루션입니다. 필요에 따라 특정 IP 및 국가를 차단 및 허용할 수 있습니다. 보통 루트 디렉토리 내 [.htaccess] 파일에서 제일…

  • df 명령어

    df(Disk Free)는 마운트 된 장치 전체 용량, 사용 용량, 여유 용량을 확인할 수 있습니다. 파일 시스템(Filesystem), 디스크 크기(Size), 사용량(Used), 여유공간(Avail), 사용률(Use%), 마운트지점(Mounted on)을 순서로 확인할 수 있습니다. 목차✅ JVM의 4가지 기본 기능✅ 가비지 컬렉션(Garbage collection)df 명령어 옵션 웹사이트 접속이 안되는 오류 발생 시 디스크 용량을 확인해서 서버 관리를 하는 것이 기본적인 활용법이며, 파티션…

  • Varnish Cache란 무엇인가? | Varnish 설치 및 기본 설정하기

    Varnish Cache는 동적 웹사이트와 API에 적합한 HTTP 가속기입니다. 이는 스퀴드와 같은 클라이언트 사이드 캐시 역할을 하는 다른 웹 가속기와 달리 Nginx, 아파치와 같은 원본 서버 대신 HTTP 가속기로 설계 되었습니다. 또한, Varnish는 HTTP에 특화되어 있어 FTP, SMTP 및 다른 통신 프로토콜을 지원하는 프록시 서버와는 다릅니다. 목차✅ JVM의 4가지 기본 기능✅ 가비지 컬렉션(Garbage collection)✅…

  • 리눅스 Logrotate 개념과 설정

    리눅스 Logrotate는 “로그를 회전하다.”라는 뜻에서 알 수 있듯이 로그와 Rotate(회전하다[동사])의 합성어입니다. 리눅스 설치 시 기본으로 설치되어 있습니다. 로테이션(Rotation)은 사람을 일정한 순서에 따라 교대하는 일, 야구 경기에서 선발 투수를 차례로 기용하는 일 등의 예에서 볼 수 있듯이 반복과 교대의 개념을 가지고 있습니다. 리눅스에서 로그로테이션(Logrotation) > 로그 회전이라는 명사로도 언급됩니다. Logrotate가 설치되어 있지 않다면 명령어를…

답글 남기기

이메일 주소는 공개되지 않습니다. 필수 필드는 *로 표시됩니다

Prove your humanity: 4   +   5   =