1. JPA와 최대 절전 모드의 차이점은 무엇인가요?
(추천 학습: java 인터뷰 질문)
JPA Java Persistence API는 Java EE 5의 표준 ORM 인터페이스이자 ejb3 사양의 일부입니다.
현재 매우 인기 있는 ORM 프레임워크인 Hibernate는 JPA를 구현한 것이지만 그 기능은 JPA의 상위 집합입니다.
JPA와 Hibernate의 관계는 JPA가 표준 인터페이스이고 Hibernate가 구현이므로 간단히 이해하면 됩니다. 그렇다면 Hibernate는 어떻게 JPA와 이러한 관계를 달성합니까? Hibernate는 주로 hibernate-annotation, hibernate-entitymanager 및 hibernate-core의 세 가지 구성 요소를 통해 구현됩니다.
hibernate-annotation은 Hibernate가 주석 구성을 지원하는 기반입니다. 여기에는 표준 JPA 주석과 Hibernate 고유의 특수 기능에 대한 주석이 포함되어 있습니다.
hibernate-core는 Hibernate의 핵심 구현이며 Hibernate의 모든 핵심 기능을 제공합니다.
hibernate-entitymanager는 Hibernate-core와 JPA 사이의 어댑터로 간주될 수 있지만 Hibernate-core를 JPA 사양과 호환되도록 캡슐화합니다.
2. 봄구름이란?
말 그대로 이해하면 Spring Cloud는 분산 시스템 및 클라우드 서비스 전용 프레임워크입니다.
Spring Cloud는 Spring 제품군 전체의 새로운 멤버이며 최근 클라우드 서비스의 인기가 높아짐에 따라 필연적으로 출시되는 제품입니다.
Spring Cloud는 개발자에게 다음과 같은 분산 시스템에서 몇 가지 공통 패턴을 신속하게 구축할 수 있는 도구를 제공합니다.
구성 관리
서비스 등록 및 검색
회로 차단기
스마트 라우팅
서비스 간 호출
로드 밸런싱
Micro-agent
버스 제어
일회성 토큰
전역 잠금
리더십 선거
분산 세션
클러스터 상태
분산 메시징
…
Spring Cloud 개발자는 이러한 패턴을 즉시 구현하는 서비스 및 애플리케이션을 구현할 수 있습니다. 이러한 서비스는 개발자의 노트북과 다양한 호스팅 플랫폼을 포함한 분산 환경을 포함한 모든 환경에서 실행될 수 있습니다.
3. 스프링클라우드 차단기의 기능은 무엇인가요?
Hystrix는 Spring Cloud에서 회로 차단기 기능을 구현하는 데 사용됩니다. 회로 차단기는 애플리케이션이 실패할 가능성이 있는 작업을 여러 번 수행하려고 시도하는 것을 방지하여 실패를 기다리지 않고 계속되도록 할 수 있습니다. 복구 또는 CPU 사이클 낭비, 장애가 지속되는 것으로 판단합니다.
회로 차단기 모드를 사용하면 애플리케이션에서 오류가 해결되었는지 여부를 감지할 수 있으며, 문제가 해결된 것으로 보이는 경우 애플리케이션에서 조치를 호출할 수 있습니다.
회로 차단기는 시스템에 안정성과 유연성을 추가하여 시스템이 오류에서 복구되는 동안 안정성을 제공하고 이 오류가 성능에 미치는 영향을 최소화합니다. 작업 시간이 초과되거나 반환되지 않을 때까지 기다리는 대신 실패할 가능성이 있는 작업에 대한 요청을 신속하게 거부하여 시스템 응답 시간을 보존하는 데 도움이 될 수 있습니다.
회로 차단기가 상태를 변경할 때마다 이벤트를 발생시키는 경우 이 정보를 사용하여 회로 차단기로 보호되는 시스템 구성 요소의 상태를 모니터링하거나 회로 차단기가 열린 상태로 전환될 때 관리자에게 경고할 수 있습니다.
4. 스프링 클라우드의 핵심 구성요소는 무엇인가요?
1. 서비스 검색 - Netflix Eureka
AWS 지역에서 실행되는 중간 계층 서비스를 찾는 데 사용되는 RESTful 서비스입니다. 이는 유레카 서버와 유레카 클라이언트의 두 가지 구성 요소로 구성됩니다. 유레카 서버는 서비스 등록 서버로 사용됩니다.
Eureka 클라이언트는 서버와의 상호 작용을 단순화하고, 폴링 로드 밸런서 역할을 하며, 서비스에 대한 장애 조치 지원을 제공하는 데 사용되는 Java 클라이언트입니다. Netflix는 프로덕션 환경에서 트래픽, 리소스 활용도 및 오류 상태를 기반으로 가중치가 부여된 로드 밸런싱을 제공하는 별도의 클라이언트를 사용합니다.
2. 클라이언트 측 로드 밸런싱 - Netflix Ribbon
Ribbon은 주로 클라이언트 측 소프트웨어 로드 밸런싱 알고리즘을 제공합니다. 리본 클라이언트 구성 요소는 연결 시간 초과, 재시도, 재시도 알고리즘 등과 같은 일련의 전체 구성 옵션을 제공합니다. 리본에는 플러그형 및 사용자 정의 가능한 로드 밸런싱 구성 요소가 내장되어 있습니다.
3. 회로 차단기 - Netflix Hystrix
회로 차단기는 애플리케이션이 실패할 가능성이 있는 작업을 여러 번 수행하려고 시도하는 것을 방지하여 오류가 복구될 때까지 기다리거나 CPU 주기를 낭비하지 않고 계속할 수 있도록 해줍니다. 실패는 지속됩니다. 또한 회로 차단기 모드를 사용하면 애플리케이션에서 오류가 해결되었는지 여부를 감지할 수 있습니다. 문제가 해결된 것으로 나타나면 애플리케이션은 작업 호출을 시도할 수 있습니다.
4. 서비스 게이트웨이 - Netflix Zuul
nginx와 유사하며 역방향 프록시 기능이 있지만 Netflix 자체에 다른 구성 요소와 협력할 수 있는 몇 가지 기능이 추가되었습니다.
5. 분산 구성——Spring Cloud 구성
이는 여전히 정적이며 동적 구성 업데이트를 달성하려면 Spring Cloud Bus와 결합되어야 합니다.
위 내용은 2020 신규 Java 면접 질문 - Spring Boot/Spring Cloud (2)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!