ZooKeeper는 분산형 오픈소스 분산 애플리케이션 조정 서비스로, Google의 Chubby를 오픈소스로 구현한 것이며 Hadoop 및 Hbase의 중요한 구성 요소입니다. 이 글을 통해 자바에서 Zookeeper의 간단한 사용법을 공유하겠습니다. 필요한 친구들은 참고하세요
1. Zookeeper의 기본 원리
데이터 모델은 다음과 같습니다.
ZooKeeper 데이터 모델의 구조와 구조 Unix 파일 시스템은 전체적으로 트리로 간주할 수 있으며 각 노드를 ZNode라고 합니다. 각 ZNode는 해당 경로로 고유하게 식별될 수 있습니다. 예를 들어 위 그림에서 세 번째 계층의 첫 번째 ZNode에는 /app1/c1 경로가 있습니다. 각 ZNode에는 소량의 데이터를 저장할 수 있습니다(기본값은 1M이며 구성을 통해 수정할 수 있습니다. 일반적으로 ZNode에 많은 양의 데이터를 저장하는 것은 권장되지 않습니다). 또한 각 ZNode는 Acl 정보도 저장합니다. ZNode의 트리 구조는 Unix 파일 시스템과 매우 유사하지만 Acl은 Unix 파일 시스템과 완전히 다릅니다. . , 하위 노드는 상위 노드를 상속하지 않습니다.
ZooKeeper 기능:
1. 읽기, 쓰기(업데이트) 모드
ZooKeeper 클러스터에서는 모든 ZooKeeperServer에서 읽기를 읽을 수 있어 ZooKeeper의 더 나은 읽기 성능이 보장됩니다. 쓰기 요청은 먼저 리더에게 전달된 다음 리더는 ZooKeeper의 원자 브로드캐스트 프로토콜을 통해 모든 팔로어에게 요청을 브로드캐스트합니다. 리더는 성공적인 쓰기 승인의 절반 이상을 받은 후 쓰기가 완료된 것으로 간주합니다. 성공하면 쓰기가 유지되고 클라이언트에 쓰기가 성공했다는 알림이 전달됩니다.
2. WAL 및 스냅샷
대부분의 분산 시스템과 마찬가지로 ZooKeeper에는 WAL(Write-Ahead-Log)도 있습니다. 모든 업데이트 작업에 대해 ZooKeeper는 먼저 WAL을 작성한 다음 메모리에 데이터를 업데이트합니다. 업데이트 결과를 클라이언트에게 알립니다. 또한 ZooKeeper는 정기적으로 메모리에 있는 디렉터리 트리의 스냅샷을 찍어 디스크에 저장합니다. 이는 HDFS의 FSImage와 유사합니다. 이렇게 하는 주요 목적은 물론 데이터의 지속성이며 두 번째는 다시 시작한 후 복구 속도를 높이는 것입니다. ReplayWAL을 통해 모두 복원하면 속도가 느려집니다.
3. FIFO
각 ZooKeeper 클라이언트에 대해 모든 작업은 다음 두 가지 기본 기능으로 보장됩니다. 첫째, ZooKeeper 클라이언트와 서버 간 네트워크 통신은 TCP를 기반으로 합니다. 클라이언트/서버 간 전송 패킷 순서 둘째, ZooKeeperServer는 FIFO 순서에 따라 클라이언트 요청을 실행합니다.
4. 선형성
ZooKeeper에서는 모든 업데이트 작업이 엄격한 부분 순서 관계를 가지며 업데이트 작업은 순차적으로 실행됩니다. 이는 ZooKeeper 기능의 정확성을 보장하는 핵심입니다.
2. Zookeeper의 일반적인 명령
Zookeeper-client를 실행하거나 /opt/cloudera/parcels/CDH-5.0.0-1.cdh5.0.0.p0.47/lib/zookeeper/bin을 실행할 수 있습니다. /zkCli.sh-server localhost에서 다음과 같이 Zookeeper 명령줄을 입력합니다.
그런 다음 ls /를 실행하면 다음을 볼 수 있습니다.
그런 다음 create /qyktest를 실행할 수 있습니다. 'qyktest' 다음과 같이 노드를 생성합니다.
그런 다음 get /qyktest를 실행하여 다음과 같이 노드 값을 가져옵니다.
그런 다음 set /qyktest를 실행할 수 있습니다. 111' 노드 값을 수정하려면 다음과 같이
마지막으로 delete /qyktest를 실행하여 이 노드를 삭제할 수 있습니다.
또한 이 qyktest 노드 아래에 하위 노드를 계속 생성할 수도 있습니다.
그렇습니다. 몇 가지 기본 명령어로 이 사람에 대한 정보를 확인할 수 있습니다.
3. Zookeeper의 javaapi 작업
Zookeeper의 Javaapi 작업에 대해서는 다음과 같이 저자가 직접 코드를 게시했습니다.
packageorg.zookeeper.demo; importjava.io.IOException; importjava.util.concurrent.CountDownLatch; importorg.apache.zookeeper.CreateMode; importorg.apache.zookeeper.KeeperException; importorg.apache.zookeeper.WatchedEvent; importorg.apache.zookeeper.Watcher; importorg.apache.zookeeper.Watcher.Event.KeeperState; importorg.apache.zookeeper.ZooDefs.Ids; importorg.apache.zookeeper.ZooKeeper; publicclassZookeeperClientimplementsWatcher{ //连接超时时间,10s privatestaticfinalintSESSION_TIMEOUT= 10000; //连接的zookeeperserver privatestaticfinalStringCONNECTION_STRING = "172.31.25.8:2181"; privatestaticfinalStringZK_PATH = "/qyktest"; privateZooKeeperzk = null; privateCountDownLatchconnectedSemaphore = newCountDownLatch(1); publicvoidcreateConnection(StringconnectString, intsessionTimeout){ this.releaseConnection(); try{ zk= newZooKeeper(connectString,sessionTimeout, this); connectedSemaphore.await(); }catch(InterruptedExceptione) { System.out.println("连接创建失败,发生InterruptedException"); e.printStackTrace(); }catch(IOExceptione) { System.out.println("连接创建失败,发生IOException"); e.printStackTrace(); } } publicvoidreleaseConnection(){ if(this.zk!= null){ try{ this.zk.close(); }catch(InterruptedExceptione) { e.printStackTrace(); } } } publicbooleancreatePath(Stringpath, String data) { try{ Stringresult = this.zk.create(path,data.getBytes(), Ids.OPEN_ACL_UNSAFE,CreateMode.PERSISTENT); System.out.println("节点创建成功,Path: "+result + ", content: "+data); }catch(KeeperExceptione) { System.out.println("节点创建失败,发生KeeperException"); e.printStackTrace(); }catch(InterruptedExceptione) { System.out.println("节点创建失败,发生InterruptedException"); e.printStackTrace(); } returntrue; } publicStringreadData(Stringpath) { try{ System.out.println("获取数据成功,path:"+path); returnnewString(this.zk.getData(path,false,null)); }catch(KeeperExceptione) { System.out.println("读取数据失败,发生KeeperException,path:"+path); e.printStackTrace(); return""; }catch(InterruptedExceptione) { System.out.println("读取数据失败,发生InterruptedException,path: "+path); e.printStackTrace(); return""; } } publicbooleanwriteData(Stringpath, String data) { try{ System.out.println("更新数据成功,path:"+path + ", stat: "+this.zk.setData(path,data.getBytes(), -1)); }catch(KeeperExceptione) { System.out.println("更新数据失败,发生KeeperException,path:"+path); e.printStackTrace(); }catch(InterruptedExceptione) { System.out.println("更新数据失败,发生InterruptedException,path: "+path); e.printStackTrace(); } returnfalse; } publicvoiddeleteNode(Stringpath) { try{ this.zk.delete(path,-1); System.out.println("删除节点成功,path:"+path); }catch(KeeperExceptione) { System.out.println("删除节点失败,发生KeeperException,path:"+path); e.printStackTrace(); }catch(InterruptedExceptione) { System.out.println("删除节点失败,发生InterruptedException,path: "+path); e.printStackTrace(); } } publicstaticvoidmain(String[]args) { ZookeeperClientsample = newZookeeperClient(); //获取连接 sample.createConnection(CONNECTION_STRING,SESSION_TIMEOUT); //读数据 Stringqyk = sample.readData("/qyktest"); System.out.println("qyk:"+qyk); Stringurl = sample.readData("/qyk/db/url"); System.out.println("url"+url); Stringdriver = sample.readData("/qyk/db/driver"); System.out.println("driver"+driver); StringuserName = sample.readData("/qyk/db/userName"); System.out.println("userName"+userName); Stringpassword = sample.readData("/qyk/db/password"); System.out.println("password"+password); //创建节点 sample.createPath(ZK_PATH,"我是节点初始内容"); System.out.println("数据内容:"+sample.readData(ZK_PATH) + "\n"); //更新节点 sample.writeData(ZK_PATH,"更新后的数据"); System.out.println("数据内容:"+sample.readData(ZK_PATH) + "\n"); //删除节点 sample.deleteNode(ZK_PATH); //释放连接 sample.releaseConnection(); } @Override publicvoidprocess(WatchedEventevent) { System.out.println("收到事件通知:"+event.getState() + "\n"); if(KeeperState.SyncConnected== event.getState()) { connectedSemaphore.countDown(); } } }
그런 다음 실행하면 다음과 같이 콘솔 출력이 나오는 것을 확인할 수 있습니다.
그래서 일부 일반적인 구성과 마찬가지로 Zookeeper에 저장한 후 다른 서비스를 사용할 수 있습니다
요약
위 내용은 Java에서 ZooKeeper 사용에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

javadevelopmentisnotentirelyplatform-IndectionentDuetoSeveralFactors.1) JVMVARIATIONSAFFERFFERFORMANDBEHAVIORACROSSDIFFERENTOS.2) nativelibrariesViajniintrictionPlatform-specificiss.3) filepathsandsystempropertiesdifferbetweenplatectry. 4)

Java 코드는 다른 플랫폼에서 실행할 때 성능 차이가 있습니다. 1) JVM의 구현 및 최적화 전략은 OracleJDK 및 OpenJDK와 같이 다릅니다. 2) 메모리 관리 및 스레드 스케줄링과 같은 운영 체제의 특성도 성능에 영향을 미칩니다. 3) 적절한 JVM을 선택하여 JVM 매개 변수 및 코드 최적화를 조정하여 성능을 향상시킬 수 있습니다.

Java'SplatformIndenceHASLIMITATIONSINTERFORMANTOWORHEAD, 버전 컴포팅 가능성, 도전 과제, 플랫폼-특이 적 식품, 및 JVMINSTALLATION/MAYMENDENT.ThesefacteThe "WriteOnce, Runanywhere"

Platform IndependenCealLowsProgramStorunannyplatformwithoutModification, whileCross-PlatformDevelopmentRequiressomplatformspecificAdJustments.platformIndence, PreemplifiedByjava, enableStalExecutionButmayPromiseperformance.cross-platformd

jitcompilationinjavaenhancesperformance는 platformindence.1) ItdynamicallyTransLatesByTecodeIntonativeMachinecodeatimeTime, 최적화 FREQUELTEREDCODE.2) TheJVMREMAINSPLATFORM- Independent, 허용 THEMEJAVAAPPLITIONTORUNONDIFFEREN을 허용합니다

javaispopularforcross-platformdesktopapplicationsduetoits "writeonce, runanywhere"철학

Java에서 플랫폼 별 코드를 작성하는 이유에는 특정 운영 체제 기능에 대한 액세스, 특정 하드웨어와 상호 작용하고 성능 최적화가 포함됩니다. 1) JNA 또는 JNI를 사용하여 Windows 레지스트리에 액세스하십시오. 2) JNI를 통한 Linux 특이 적 하드웨어 드라이버와 상호 작용; 3) 금속을 사용하여 JNI를 통해 MacOS의 게임 성능을 최적화하십시오. 그럼에도 불구하고 플랫폼 별 코드를 작성하면 코드의 이식성에 영향을 미치고 복잡성을 높이며 잠재적으로 성능 오버 헤드 및 보안 위험을 초래할 수 있습니다.

Java는 Cloud-Native Applications, Multi-Platform 배포 및 교차 운용성을 통해 플랫폼 독립성을 더욱 향상시킬 것입니다. 1) Cloud Native Applications는 Graalvm 및 Quarkus를 사용하여 시작 속도를 높입니다. 2) Java는 임베디드 장치, 모바일 장치 및 양자 컴퓨터로 확장됩니다. 3) Graalvm을 통해 Java는 Python 및 JavaScript와 같은 언어와 완벽하게 통합되어 언어 교차 수용 가능성을 향상시킵니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

WebStorm Mac 버전
유용한 JavaScript 개발 도구

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!
