XRPL Docs (Korean)
  • XRPL Docs(Kor)
  • Introduction
    • XRP Ledger란?
    • XRP란?
    • Crypto Wallets
    • Transactions and Requests
    • Software Ecosystem
  • Use Cases
    • 결제(Payments)
      • P2P 결제(Peer-to-Peer Payments)
      • 예금 제한(Restricting Deposits)
      • 스마트 컨트랙트(Smart Contracts)
    • 토큰화(Tokenization)
      • 스테이블코인 발행인(Stablecoin Issuer)
      • NFT 마켓플레이스 개요(NFT Marketplace Overview)
    • 탈중앙화 금융(Decentralized Finance)
      • 알고리즘 트레이딩(Algorithmic Trading)
      • 거래소에 XRP 상장하기((List XRP as an Exchange)
  • Concepts
    • 소개
      • 컨센서스 소개
      • XRP
      • 소프트웨어 생태계
    • XRP Ledger 서버
      • rippled 서버 모드(rippled Server Modes)
      • 클러스터링(Clustering)
      • Ledger 역사
      • 피어 프로토콜(Peer Protocol)
      • 트랜잭션 검열 감지(Transaction Censorship Detection)
      • 병렬 네트워크(Parallel Networks)
      • 수정안(Amendments)
        • XRP Ledger에 코드를 기여하는 방법
        • 알려진 수정안
      • 클리오 서버(The Clio Server)
    • 컨센서스 네트워크(Consensus Protocol)
      • 컨센서스 구조(Consensus Structure)
      • 컨센서스 원칙과 규칙(Consensus Principles and Rules)
      • 공격과 실패 모드에 대한 컨센서스 보호(Consensus Protections Against Attacks and Failure Modes)
      • 불변성 체크
      • 부정 UNL
      • 트랜잭션 취소 정보
      • 트랜잭션 변조 가능성
      • 수수료 투표
      • 컨센서스 연구
    • Ledgers
      • Ledger 구조(Ledger Structure)
      • 개방형, 폐쇄형, 검증형 Ledgers(Open, Closed, and Validated Ledgers)
      • Ledger 마감 시간(Ledger Close Times)
    • 트랜잭션(Transactions)
      • 수수료(Fees)
      • 신뢰할 수 있는 트랜잭션 제출(Reliable Transaction Submission)
      • 보안 서명(Secure Signing)
      • 출발, 데스티네이션 태그(Source and Destination Tags)
      • 트랜잭션 비용(Transaction Cost)
      • 트랜잭션 대기열(Transaction Queue)
      • 결과의 불변성(Finality of Results)
        • 트랜잭션 결과 조회(Look Up Transaction Results)
        • Transaction Malleability
    • 결제 유형
      • XRP 직접 결제
      • 교차 화폐 결제
      • 수표
      • 에스크로
      • 부분 결제
      • 결제 채널
    • 토큰(Tokens)
      • Non-Fungible Tokens
        • NFT 정보 저장소(NFT Payload Storage)
        • XRP Ledger에서 NFT 토큰 거래(Trading NFTokens on the XRP Ledger)
        • NFT Reserve Requirements
        • 일괄 발행(Batch minting)
        • 다른 계정에게 NFT 발행 권한 부여(Authorizing Another Account to Mint Your NFTs)
        • NFT 경매 진행하기(Running an NFT Auction)
        • NFT를 컬렉션으로 발행하기(Minting NFTs into Collections)
        • NFT의 고정 공급 보장하기(Guaranteeing a Fixed Supply of NFTs)
        • NFT 관련 API(NFT APIs)
      • 신뢰선과 발급(Trust Lines and Issuing)
      • 승인된 신뢰선(Authorized Trust Lines)
      • 토큰 환수(Clawing Back Tokens)
      • Freezing Tokens(토큰 동결)
        • 동결에 대한 일반적인 오해(Common Misunderstandings about Freezes )
      • Rippling
      • 이체 수수료(Transfer Fees)
      • 경로(Paths)
      • Demurrage(과잉보유비용)
      • 탈중앙화 거래소(Decentralized Exchange)
        • 제안(Offers)
        • Auto-Bridging
        • Tick Size
        • AMM(Automated Market Makers)
    • 계정
      • 다중 서명
      • 티켓
      • 계정 유형
      • 계정 삭제
      • 준비금(Reserves)
      • 주소(Addresses)
      • 암호화 키(Cryptographic Keys)
      • 입금 승인(Deposit Authorization)
  • Tutorials
    • 퍼블릭 서버(Public Servers)
    • Python
      • Python으로 시작하기(Get Started Using Python)
      • python 모듈형 튜토리얼(Modular Tutorials in Python)
        • python을 이용한 Send Payments(Send Payments Using Python)
          • 계정 생성 및 XRP 전송(Create Accounts and Send XRP Using Python)
          • 신뢰 생성 및 Currency 전송 (Create Trust Line and Send Currency Using Python)
          • 시간 보류 에스크로 생성(Create Time-based Escrows Using Python)
        • python을 이용한 NFTs(NFTs Using Python)
          • NFTs 발행과 소각(Mint and Burn NFTs Using Python)
          • NFTs 전송 (Transfer NFTs Using Python)
          • NFT 판매 중개 (Broker an NFT Sale Using Python)
          • 공인 발행인 지정 (Assign an Authorized Minter Using Python)
          • NFTs 일괄 발행 (Batch Mint NFTs Using Python)
        • Python에서 데스크톱 지갑 구축(Build a Desktop Wallet in Python)
    • JavaScript
      • JavaScript로 시작하기(Get Started Using JavaScript)
      • JavaScript 모듈형 튜토리얼(Modular Tutorials in JavaScript)
        • JavaScript를 이용한 Send Payments(Send Payments Using JavaScript)
          • JavaScript를 이용한 계정 생성 및 XRP 전송(Create Accounts and Send XRP Using JavaScript)
          • JavaScript를 이용한 신뢰선 생성 및 화폐 전송(Create Trust Line and Send Currency Using JavaScript)
          • 시간 기반 에스크로 생성하기(Create Time-based Escrows Using JavaScript)
          • 조건부 에스크로 생성하기(Create Conditional Escrows Using JavaScript)
        • JavaScript를 이용한 NFTs(NFTs Using JavaScript)
          • JavaScript를 이용한 NFTs 발행 및 소각(Mint and Burn NFTs Using JavaScript)
          • JavaScript를 이용한 NFTs 전송(Transfer NFTs Using JavaScript)
          • JavaScript를 이용한 NFT 판매 중개(Broker an NFT Sale Using JavaScript)
          • JavaScript를 이용한 공인 발행인 지정(Assign an Authorized Minter Using JavaScript)
          • JavaScript를 이용한 NFTs 일괄 발행(Batch Mint NFTs Using JavaScript)
      • JavaScript를 이용한 브라우저 지갑 개발(Build a Browser Wallet in JavaScript)
      • JavaScript를 이용한 데스크탑 지갑 개발(Build a Desktop Wallet in JavaScript)
    • Java
      • Java로 시작하기(Get Started Using Java)
    • HTTP / Websocket APIs
      • HTTP/WebSocket API 사용 시작하기(Get Started Using HTTP / WebSocket APIs)
      • WebSocket으로 수신 결제 모니터링(Monitor Incoming Payments with WebSocket)
    • Tasks
      • 계정 설정 관리(Manage Account Settings)
        • 일반 키 쌍 할당
        • 일반 키 쌍 변경 또는 제거
        • 마스터 키 쌍 비활성화
        • 다중 서명 설정
        • 다중 서명 트랜잭션 전송
        • 데스티네이션 태그 필요
        • 오프라인 계정 설정 튜토리얼
        • 티켓 사용(Use Tickets)
      • XRP 보내기(Send XRP)
      • 특수 결제 유형 사용(Use Specialized Payment Types)
        • 에스크로 사용(Use escrow)
          • 시간 보류 에스크로 보내기(Send a Time-Held Escrow)
          • 조건부 보류 에스크로 보내기(Send a Conditionally-Held Escrow)
          • 만료된 에스크로 취소(Cancel an Expired Escrow)
          • 에스크로 조회(Look up Escrows)
          • 에스크로를 스마트 컨트랙트로 사용(Use an Escrow as a Smart Contract)
        • 결제 채널 사용(Use Payment Channels)
          • 결제 채널을 열어 거래소 간 네트워크 활성화(Open a Payment Channel to Enable an Inter-Exchange Network)
        • 수표 사용(Use Checks)
          • 수표 전송(Send a Check)
          • 정확한 금액의 수표 현금화(Cash a Check for an Exact Amount)
          • 유연한 금액의 수표 현금화(Cash a Check for a Flexible Amount)
          • 수표 취소(Cancel a Check)
          • 발신자별 수표 조회(Look Up Checks by Sender)
          • 수취인별 수표 조회(Look Up Checks by Recipient)
      • 토큰 사용(Use Tokens)
        • 대체가능한 토큰 발행(Issue a Fungible Token)
        • 탈중앙화 거래소에서 거래(Trade in the Decentralized Exchange)
        • 동결 금지 활성화
        • 글로벌 동결 시행
        • 신뢰선 동결하기
    • Apps 구축
      • JS에서 데스크톱 지갑 구축
      • JS에서 브라우저 지갑 구축
    • XRP Ledger 비즈니스
      • XRP 차트에 거래소 등록하기
      • 스테이블코인 발행자 되기
    • rippled 서버 관리
      • rippled 설치
        • 시스템 요구 사항
        • CentOS/Red Hat에 yum으로 설치하기
        • 우분투 또는 데비안 리눅스에 설치
        • 리눅스에서 자동 업데이트
        • CentOS/Red Hat에서 수동 업데이트
        • 우분투 또는 데비안에서 수동 업데이트
        • 리포팅 모드에서 rippled 빌드 및 실행
        • 용량 계획
        • rippled v1.3.x 마이그레이션 지침
      • rippled 구성
        • rippled를 검증인으로 실행하기
        • rippled를 스톡 서버로 실행
        • 수정안 투표 구성
        • 수정안 테스트
        • StatsD 구성
        • rippled를 병렬 네트워크에 연결하기
        • 온라인 삭제 구성
        • 권고 삭제 구성
        • 히스토리 샤딩 구성
        • 전체 히스토리 구성
        • gRPC 구성
        • 공개 서명 사용
      • 피어링 구성
        • 클러스터 rippled 서버
        • 비공개 서버 구성
        • 피어 크롤러 구성
        • 링크 압축 사용
        • 피어링을 위한 포트 포워드
        • 특정 피어에 수동으로 연결
        • 최대 피어 수 설정
        • 피어 예약 사용
      • stand-alone 모드에서 rippled 기능 테스트하기
        • stand-alone 모드에서 새 제네시스 ledger 시작하기
        • stand-alone 모드에서 저장된 ledger 불러오기
        • stand-alone 모드에서 ledger 진행하기
      • 문제 해결
        • rippled 문제 진단하기
        • 상태 확인 개입
        • 로그 메시지 이해
        • rippled 서버가 동기화되지 않음
        • rippled 서버가 수정이 차단됨
        • rippled 서버가 시작되지 않음
        • SQLite 트랜잭션 데이터베이스 페이지 크기 문제 해결
    • 클리오 서버 관리
      • 우분투 리눅스에 클리오 설치
  • References
    • XRP Ledger 프로토콜 참조(XRP Ledger Protocol Reference)
      • 기본 데이터 유형(Basic Data Types)
        • base58 인코딩(base58 Encodings)
        • 화폐 형식(Currency Formats)
        • NFToken
      • Ledger 데이터 형식(Ledger Data Formats)
        • Ledger 헤더(Ledger Header)
        • Ledger 객체 IDs
        • Ledger 객체 유형
          • AccountRoot
          • Amendments
          • AMM(experimental - 수정중)
          • Check
          • DepositPreauth
          • DirectoryNode
          • Escrow
          • FeeSettings
          • LedgerHashes
          • NegativeUNL
          • NFTokenOffer
          • NFTokenPage
          • Offer
          • PayChannel
          • RippleState
          • SignerList
          • Ticket
      • 트랜잭션 참조(Transaction Reference)
        • 트랜잭션 공통 필드(Transaction Common Fields)
        • 트랜잭션 유형(Transaction Types)
          • AccountSet
          • AccountDelete
          • AMMBid
          • AMMCreate
          • AMMDelete
          • AMMDeposit
          • CheckCancel
          • CheckCash
          • CheckCreate
          • DepositPreauth
          • EscrowCancel
          • EscrowCreate
          • EscrowFinish
          • NFTokenAcceptOffer
          • NFTokenBurn
          • NFTokenCancelOffer
          • NFTokenCreateOffer
          • NFTokenMint
          • OfferCancel
          • OfferCreate
          • Payment
          • PaymentChannelClaim
          • PaymentChannelCreate
          • PaymentChannelFund
          • SetRegularKey
          • SignerListSet
          • TicketCreate
          • TrustSet
        • Pseudo-Transactions
          • EnableAmendment
          • SetFee
          • UNLModify
        • 트랜잭션 결과(Transaction Results)
          • tec Codes
          • tef Codes
          • tel Codes
          • tem Codes
          • ter Codes
          • tes Success
        • 트랜잭션 메타데이터(Transaction Metadata)
      • Binary Format
    • 클라이언트 라이브러리
      • JavaScript / TypeScript 클라이언트 라이브러
        • ripple-lib 1.x에서 xrpl.js 2.x로의 마이그레이션 가이드
      • Python 클라이언트 라이브러리
      • Java 클라이언트 라이브러리
      • Ruby 클라이언트 라이브러리
    • HTTP / WebSocket APIs
      • API 규칙
        • 요청 형식
        • 응답 형식
        • 오류 형식
        • 마커 및 페이지네이션
        • 속도 제한
        • rippled 서버 상태
      • 공개 API 메소드
        • 계정 메소드
          • account_channels
          • account_currencies
          • account_info
          • account_lines
          • account_nfts
          • account_objects
          • account_offers
          • account_tx
          • gateway_balances
          • noripple_check
        • Ledger 메소드
          • ledger
          • ledger_closed
          • ledger_current
          • ledger_data
          • ledger_entry
        • 트랜잭션 메소드
          • submit
          • submit_multisigned
          • transaction_entry
          • tx
          • tx_history
        • 경로와 오더북 메소드
          • book_offers
          • deposit_authorized
          • nft_buy_offers
          • nft_sell_offers
          • path_find
          • ripple_path_find
        • 결제 채널 메소드
          • channel_authorize
          • channel_verify
        • 구독 메소드
          • 구독
          • 구독 취소
        • Server Info 메소드
          • fee
          • manifest
          • server_info (rippled)
          • server_state
        • 클리오 서버
          • server_info
          • ledger
          • nft_history
          • nft_info
        • 유틸리티 메소드
          • json
          • ping
          • random
      • 관리자 API 메소드
        • 키 생성 방법
          • validation_create
          • wallet_propose
        • 로깅 및 데이터 관리 메소드
          • can_delete
          • crawl_shards
          • download_shard
          • ledger_cleaner
          • ledger_request
          • log_level
          • logrotate
          • node_to_shard
        • 서버 컨트롤 메소드
          • ledger_accept
          • stop
          • validation_seed
        • 서명 메소드
          • sign
          • sign_for
        • 피어 관리 메소드
          • connect
          • peer_reservations_add
          • peer_reservations_del
          • peer_reservations_list
          • peers
        • 상태 및 디버깅 메소드
          • consensus_info
          • feature
          • fetch_info
          • get_counts
          • print
          • validator_info
          • validators
        • rippled 커맨드라인 사용 참조
        • 피어 포트 메소드
          • 상태 확인
          • 피어 크롤러
          • 유효성 검증인 목록 메소드
    • xrp-ledger.toml File
  • Infrastructure
    • 커맨드 라인 사용법(Commandline Usage)
    • Install rippled
      • System Requirements
      • Install on CentOS/RedHat with yum
      • Install on Ubuntu or Debian Linux
      • Update Automatically on Linux
      • Update Manually on CentOS/Red Hat
      • Update Manually on Ubuntu or Debian
      • Build and Run rippled in Reporting Mode
      • Capacity Planning
    • Configure rippled
      • Server Modes
        • Run rippled as a Validator
        • Run rippled as a Stock Server
      • Data Retention
        • Configure Full History
        • 온라인 삭제(Online Deletion)
        • Configure Online Deletion
        • Configure Advisory Deletion
        • 히스토리 샤딩(History Sharding)
        • Configure History Sharding
      • Configure Amendment Voting
      • Test Amendments
      • Configure StatsD
      • Connect Your rippled to a Parallel Network
      • Configure gRPC
      • Enable Public Signing
    • Peering
      • Cluster rippled Servers
      • Configure a Private Server
      • Configure the Peer Crawler
      • Enable Link Compression
      • Forward Ports for Peering
      • Manually Connect to a Specific Peer
      • Set Maximum Number of Peers
      • Use a Peer Reservation
    • Testing and Auditing
      • Start a New Genesis Ledger in Stand-Alone Mode
      • Load a Saved Ledger in Stand-Alone Mode
      • Advance the Ledger in Stand-Alone Mode
    • Troubleshooting
      • Diagnosing Problems with rippled
      • Health Check Interventions
      • Understanding Log Messages
      • rippled Server Doesn't Sync
      • rippled Server is Amendment Blocked
      • rippled Server Won't Start
    • Install Clio on Ubuntu Linux
    • Run a Private Network with Docker
Powered by GitBook
On this page
  • 배경
  • 요약
  • 작동 방식
  • 신뢰성 측정
  • Negative UNL 수정하기
  • Negative UNL 제한
  • 다중 후보 유효성 검증인에서 선택
  • 유효성 검사
  • 예시
  1. Concepts
  2. 컨센서스 네트워크(Consensus Protocol)

부정 UNL

Previous불변성 체크Next트랜잭션 취소 정보

Last updated 1 year ago

(에 의해 추가되었습니다.)

Negative UNL은 XRP Ledger 의 기능으로서, 네트워크가 일부 다운된 상태에서도 전진할 수 있는 능력인 활성성(liveness)을 향상시킵니다. Negative UNL을 사용하여 서버는 현재 온라인 및 동작 중인 검증인에 따라 유효한 이 선언될 수 있도록 유효한 UNL(effective UNL)을 조정합니다. 따라서 신뢰할 수 있는 검증인 중 일부가 오프라인 상태인 경우에도 새로운 ledger 버전이 유효하다고 선언될 수 있습니다.

Negative UNL은 네트워크가 트랜잭션을 처리하는 방식이나 트랜잭션 결과에는 영향을 주지 않습니다. 다만 일부 유형의 일시적인 다운 상태에서 트랜잭션의 최종 결과를 선언하는 네트워크의 능력을 향상시킵니다.

배경

XRP Ledger 프로토콜의 각 서버는 동조하지 않을 것으로 신뢰하는 검증인의 목록인 고유한 노드 목록(Unique Node List, UNL)을 갖습니다. 각 서버는 신뢰하는 검증인들이 새로운 ledger 버전에 대해 컨센서스를 이룰 때 충분한 수의 검증인이 동의할 때 ledger 버전이 유효하게 선언되도록 독립적으로 결정합니다. (기본 구성은 Ripple이 서명한 권장 UNL로, Ripple이 충분히 고유하고 신뢰할 수 있으며 독립적인 검증인으로 간주하는 검증인들의 목록을 사용합니다.) 표준 컨센서스 요구사항은 신뢰하는 검증인 중 최소 80%가 동의해야 합니다.

만약 신뢰하는 검증인 중 20% 이상이 오프라인이 되거나 네트워크와 통신할 수 없는 상태가 되면, 네트워크는 쿼럼을 충족할 수 없으므로 새로운 ledger를 유효화하지 않습니다. 이는 트랜잭션의 최종 결과가 선언된 후에는 트랜잭션의 결과가 변경될 수 없도록 보장하기 위한 설계 선택입니다. 이러한 상황에서 남아 있는 서버들은 여전히 온라인 상태이며 과거 및 임시적인 트랜잭션 데이터를 제공할 수 있지만, 새로운 트랜잭션의 최종 및 변경할 수 없는 결과를 확인할 수는 없습니다.

그러나 이는 일부 신뢰할 수 있는 검증인이 오프라인 상태가 될 경우 네트워크가 전진하는 것을 막을 수도 있습니다. 2020년 10월 6일 기준으로 Ripple의 권장 UNL에는 34개의 검증인이 있으므로, 7개 이상의 검증인이 오프라인 상태가 되면 네트워크는 전진할 수 없게 됩니다. 또한, 하나 또는 두 개의 검증인이 장기간 오프라인 상태인 경우, 남아 있는 검증인 간의 의견 차이가 더 작아져 컨센서스에 도달하는 데 더 많은 시간이 소요될 수 있습니다.

요약

다양한 유효성 검증인들이 항상 100% 가동 상태를 유지하는 것은 합리적으로 기대하기 어렵습니다. 하드웨어 유지보수, 소프트웨어 업그레이드, 인터넷 연결 문제, 표적 공격, 인적 실수, 하드웨어 고장 및 자연재해와 같은 외부 요인으로 인해 유효성 검증인은 일시적으로 사용할 수 없게 될 수 있습니다.

"Negative UNL"은 남은 유효성 검증인들의 컨센서스에 따라 오프라인 상태나 동작 오류가 발생하는 신뢰할 수 있는 유효성 검증인의 목록입니다. Negative UNL에 포함된 유효성 검증인은 새로운 ledger 버전의 컨센서스 도달 여부를 결정하는 데 사용되지 않습니다.

Negative UNL에 있는 유효성 검증인이 온라인으로 돌아오고 일관된 유효성 검증 투표를 보내면, 남은 유효성 검증인들은 일정 시간이 지난 후에 Negative UNL에서 해당 검증인을 제거합니다.

유효성 검증인들이 하나 또는 둘씩 오프라인 상태가 되는 경우, 남은 유효성 검증인들은 Negative UNL을 사용하여 점진적으로 유효 UNL을 조정할 수 있습니다. 이렇게 함으로써 네트워크는 항상 온라인 유효성 검증인의 80%만 있으면 컨센서스 도달을 위한 쿼럼을 충족할 수 있습니다. 네트워크가 분할되는 것을 방지하기 위해 쿼럼은 최소 60%의 총 유효성 검증인을 가져야 합니다.

만약 20% 이상의 유효성 검증인이 동시에 갑자기 오프라인 상태가 된다면, 남은 서버들은 새로운 ledger를 검증할 수 있는 필요한 쿼럼을 충족할 수 없게 됩니다. 그러나 이러한 서버들은 계속해서 연속적인 컨센서스 라운드를 통해 예비적인 전진을 할 수 있습니다. 시간이 지나면서 남은 유효성 검증인들은 예비 ledger 및 조정된 Negative UNL에서 변경사항을 계속 적용하고 유효 UNL을 조정할 것입니다. 상황이 계속되면 네트워크는 예비 ledger 버전의 조정된 Negative UNL을 사용하여 완전히 ledger를 검증할 수 있게 됩니다.

Negative UNL은 stand-alone 모드에는 영향을 주지 않습니다. 에서 서버는 컨센서스를 사용하지 않기 때문입니다.

작동 방식

Negative UNL은 컨센서스 프로세스와 밀접하게 관련되어 있으며, 악재에 대한 네트워크의 연속성과 신뢰성을 유지하기 위해 안전장치가 구축되어 있습니다. 모든 신뢰할 수 있는 유효성 검증인들이 정상적으로 작동하는 경우에는 Negative UNL은 사용되지 않으며 영향을 미치지 않습니다. 일부 유효성 검증인들이 오프라인 상태이거나 동기화되지 않은 것처럼 보일 때에만 Negative UNL 규칙이 적용됩니다.

Negative UNL은 주어진 ledger 버전의 컨센서스 프로세스에 어떤 Negative UNL이 적용되어야 하는지에 대한 시간 기반적인 논쟁을 피하기 위해 느리게 변경될 수 있도록 고안되었습니다.

신뢰성 측정

네트워크의 각 서버는 신뢰할 수 있는 유효성 검증인 목록인 UNL을 가지고 있습니다. (기본적으로 서버의 정확한 UNL은 Ripple이 발행하는 권장 유효성 검증인 목록에 따라 암묵적으로 구성됩니다.) 각 서버는 자체적으로 신뢰하는 유효성 검증인들의 신뢰성을 추적하기 위해 단일 지표인 "신뢰성"을 사용합니다. 이 신뢰성 지표는 서버의 자체적인 컨센서스 뷰와 일치하는 마지막 256개의 ledger에서 해당 유효성 검증인의 유효성 투표가 서버의 뷰와 일치한 횟수의 백분율입니다. 즉:

Reliability = Va ÷ 256

Va는 한 유효성 검증인으로부터 받은 지난 256개의 ledger에서 서버의 뷰와 일치한 유효성 투표의 총 수입니다.

이 신뢰성 지표는 유효성 검증인의 가용성과 동작을 측정합니다. 유효성 검증인은 네트워크의 나머지 부분과 동기화되어 있으며 서버의 프로토콜 규칙을 따르는 경우에 신뢰성 점수가 높아야 합니다. 유효성 검증인의 신뢰성 점수는 다음과 같은 이유로 인해 감소할 수 있습니다.

  • 서버와의 네트워크 연결 문제로 인해 유효성 검증인의 유효성 투표가 서버에 도달하지 않는 경우.

  • 유효성 검증인이 작동을 중지하거나 과부하가 걸리는 경우.

유효성 검증인의 신뢰성이 50% 미만인 경우, 해당 유효성 검증인은 Negative UNL에 추가될 수 있는 후보입니다. Negative UNL에서 제거되려면 유효성 검증인의 신뢰성이 80% 이상이어야 합니다.

각 서버, 유효성 검증인을 포함하여 신뢰할 수 있는 유효성 검증인들에 대한 신뢰성 점수를 독립적으로 계산합니다. 서로 다른 서버들은 유효성 검증인의 신뢰성에 대해 다른 결론에 도달할 수 있으며, 이는 해당 유효성 검증인의 투표가 한 서버에 도달하지 않았거나 서로 다른 ledger에서 특정 ledger에 대해 동의나 비동의하는 횟수가 다른 경우일 수 있습니다. Negative UNL에서 유효성 검증인을 추가하거나 제거하기 위해서는 신뢰할 수 있는 유효성 검증인의 컨센서스가 특정 유효성 검증인이 신뢰성 기준에 부합하는지 여부에 대해 컨센서스해야 합니다.

Tip:

유효성 검증인들은 자신의 신뢰성을 추적하지만, 스스로 Negative UNL에 추가할 수는 없습니다. 유효성 검증인이 자체적으로 측정한 신뢰성은 투표가 네트워크를 통해 성공적으로 전파되는 정도를 고려할 수 없으므로 외부 서버의 측정보다 신뢰성이 떨어질 수 있습니다.

Negative UNL 수정하기

Ledger 버전의 ledger 인덱스가 256으로 나누어 떨어지면 해당 ledger 버전은 플래그 ledger로 간주됩니다. Negative UNL은 오직 플래그 ledger에서만 수정할 수 있습니다. (플래그 ledger는 XRP Ledger Mainnet에서 약 15분마다 발생합니다. 거래량이 적은 테스트 네트워크에서는 더 긴 간격으로 발생할 수 있습니다.)

각 플래그 ledger마다 다음과 같은 변경 사항이 적용됩니다:

  1. 이전 플래그 ledger에서 예약된 Negative UNL 변경 사항이 다음 ledger 버전에 적용됩니다. 플래그 ledger 자체의 컨센서스 프로세스에서는 예약된 변경 사항을 사용하지 않습니다.

  1. 만약 Negative UNL이 가득 차 있지 않다면, 각 서버는 신뢰도가 50% 미만인 신뢰할 수 있는 유효성 검증인 중에서 최대 1명을 Negative UNL에 추가하기 위해 제안합니다.

  2. 만약 Negative UNL이 비어 있지 않다면, 각 서버는 Negative UNL에서 최대 1명의 유효성 검증인을 제거하기 위해 제안할 수 있습니다. 서버는 다음과 같은 이유로 Negative UNL에서 유효성 검증인을 제거할 수 있습니다:

  • 해당 유효성 검증인의 신뢰도가 80% 이상인 경우.

  • 해당 유효성 검증인이 자신의 UNL에 포함되어 있지 않은 경우. (유효성 검증인이 영구적으로 다운되면 이 규칙에 따라 UNL에서 제거될 수 있도록 보장됩니다.)

  1. Negative UNL에 대한 제안 변경 사항이 컨센서스를 달성하면 해당 변경 사항은 다음 플래그 ledger에 적용될 수 있도록 예약됩니다. 한 번에 최대 1명의 추가와 1명의 제거가 이와 같은 방식으로 예약될 수 있습니다.

Negative UNL에 대한 예약된 및 실제 변경 사항은 ledger의 상태 데이터에 있는 NegativeUNL 객체에서 추적됩니다.

Negative UNL 제한

네트워크가 두 개 이상의 하위 네트워크로 분리되는 것을 방지하기 위해 Negative UNL은 전체 UNL 항목 수의 60%보다 적은 쿼럼 요구사항을 줄일 수 없습니다. 이를 보장하기 위해 서버는 Negative UNL에 있는 유효성 검증인 수가 서버의 구성된 UNL에 있는 유효성 검증인 수의 25% (내림하여 반올림)인 경우 Negative UNL을 "가득 찬" 것으로 간주합니다. (25%는 75%가 남은 상태에서 80% 컨센서스가 원래 수의 60%와 동일하도록 25%의 유효성 검증인이 제거된 경우를 기반으로 계산됩니다.) 서버가 Negative UNL이 가득 찬 것으로 간주되면 새로운 추가 제안은 하지 않지만, 최종 결과는 신뢰할 수 있는 유효성 검증인의 컨센서스에 따라 달라집니다.

다중 후보 유효성 검증인에서 선택

신뢰성 임계값에 따라 여러 개의 유효성 검증인이 Negative UNL에 추가될 수 있는 경우가 있습니다. 하나의 유효성 검증인만 한 번에 Negative UNL에 추가될 수 있으므로, 서버는 어떤 유효성 검증인을 추가 제안할지 선택해야 합니다. 여러 후보가 있는 경우, 서버는 다음 메커니즘을 사용하여 어떤 유효성 검증인을 제안할지 선택합니다:

  1. 부모 ledger 버전의 ledger 해시로 시작합니다.

  2. 각 후보 유효성 검증인의 공개 키를 사용합니다.

  3. 후보 유효성 검증인과 부모 ledger의 해시의 XOR(exclusive-or) 값을 계산합니다.

  4. XOR 연산의 결과값이 숫자적으로 가장 작은 유효성 검증인을 제안합니다.

주어진 플래그 ledger에서 Negative UNL에서 제거해야 할 다중 후보가 있는 경우, 서버는 동일한 메커니즘을 사용하여 후보 중 하나를 선택합니다.

이 메커니즘은 다음과 같은 유용한 특성을 가지고 있습니다:

  • 모든 서버가 사용할 수 있는 정보로 빠르게 계산할 수 있습니다. 대부분의 서버는 신뢰할 수 있는 유효성 검증인에 대해 약간 다른 점수를 계산하더라도 동일한 후보를 선택합니다. 이는 어떤 서버에서 유효성 검증인이 가장 신뢰성이 낮거나 높은지에 대해 다른 의견이 있더라도 유효성 검증인을 선택하는 데에 큰 영향을 주지 않습니다. 이는 서버들이 어떤 유효성 검증인을 추가하거나 제거할지에 대한 컨센서스를 달성할 가능성이 높다는 것을 의미합니다.

  • 이 방법은 항상 동일한 결과를 제공하지는 않습니다. Negative UNL에 대한 하나의 제안 변경이 컨센서스를 달성하지 못하는 경우, 네트워크는 계속해서 동일한 유효성 검증인을 추가하거나 제거하려는 일부 서버들로 인해 매번 문제가 발생하지 않습니다. 네트워크는 나중에 다른 후보 유효성 검증인을 Negative UNL에 추가하거나 제거하기 위해 노력할 수 있습니다.

유효성 검사

Note:

Negative UNL은 쿼럼을 직접 변경하는 것이 아니라 쿼럼을 계산하는 데 사용되는 총 신뢰할 수 있는 유효성 검증인 수를 조정합니다. 쿼럼은 백분율이지만 투표 수는 정수이므로 총 신뢰할 수 있는 유효성 검증인 수를 줄이면 항상 쿼럼에 도달하는 데 필요한 투표 수가 변경되지는 않습니다. 예를 들어, 총 15개의 유효성 검증인이 있는 경우 80%는 정확히 12개의 유효성 검증인입니다. 총 14개의 유효성 검증인으로 줄이면 80%는 11.2개의 유효성 검증인이므로 여전히 쿼럼에 도달하기 위해서는 12개의 유효성 검증인이 필요합니다.

Negative UNL은 다른 컨센서스 과정, 예를 들어 제안된 트랜잭션 세트에 포함할 트랜잭션을 선택하는 과정에는 영향을 미치지 않습니다. 이 단계들은 항상 구성된 UNL을 기반으로 하며, 임계값은 신뢰할 수 있는 유효성 검증인이 현재 컨센서스 라운드에 활동적으로 참여하는 수에 따라 결정됩니다. Negative UNL에 있는 유효성 검증인도 컨센서스 과정에 참여할 수 있습니다.

예시

다음 예제는 Negative UNL이 컨센서스 과정에 어떻게 영향을 미치는지를 보여줍니다:

  1. 서버의 UNL에는 38개의 신뢰할 수 있는 유효성 검증인이 포함되어 있으므로 80%의 쿼럼은 38개 중 최소 31개의 신뢰할 수 있는 유효성 검증인입니다.

  1. MissingA와 UnsteadyB라는 2개의 유효성 검증인이 오프라인으로 보입니다. (두 유효성 검증인 모두 신뢰성 점수 < 50%입니다.) ledger N의 컨센서스 과정에서 나머지 유효성 검증인들 중 많은 수가 UnsteadyB를 Negative UNL에 추가하기 위해 제안합니다. 최소 31개의 남은 유효성 검증인의 컨센서스를 통과하여 ledger N은 UnsteadyB가 비활성화될 예정인 상태로 유효성을 검증합니다.

  1. N+1부터 N+256까지의 ledger에서 컨센서스 과정은 변경 없이 계속됩니다.

  2. 다음 플래그 ledger인 N+256에서 UnsteadyB는 자동으로 ledger의 "비활성화" 목록으로 이동합니다. 또한 MissingA는 여전히 오프라인이므로 유효성 검증인들의 컨센서스에 따라 다음 플래그 ledger에서 MissingA가 비활성화될 예정입니다.

  1. N+257부터 N+512까지의 ledger에서 쿼럼은 이제 37개의 유효성 검증인 중 30개입니다.

  2. UnsteadyB는 N+270의 ledger에서 다시 온라인으로 돌아옵니다. UnsteadyB는 N+270부터 N+511까지의 유효성 검증 투표를 네트워크와 일치시켜 신뢰성 점수가 80% 이상으로 계산됩니다.

  1. 다음 플래그 ledger인 N+256에서 MissingA는 예정된 대로 비활성화 목록으로 자동으로 이동합니다. 한편, 유효성 검증인들의 컨센서스에 따라 향상된 신뢰성 점수 때문에 UnsteadyB가 Negative UNL에서 제거되도록 예정됩니다.

  1. N+513부터 N+768까지의 ledger에서 쿼럼은 이제 36개의 유효성 검증인 중 29개입니다. UnsteadyB는 계속해서 안정적으로 유효성 검증을 보내는 동안 MissingA는 여전히 오프라인입니다.

  2. N+768의 플래그 ledger에서 예정된 대로 UnsteadyB가 자동으로 비활성화 목록에서 제거됩니다.

  1. 결국, MissingA가 아마도 돌아오지 않을 것이라고 판단하여 MissingA를 서버의 구성된 UNL에서 제거합니다. 이후로 서버는 매 플래그 ledger마다 MissingA를 Negative UNL에서 제거하도록 제안합니다.

  1. 유효성 검증인 운영자들이 구성된 UNL에서 MissingA를 제거함에 따라 그들의 유효성 검증인들은 MissingA를 Negative UNL에서 제거하기 위해 투표합니다. 충분한 유효성 검증인들이 이를 수행하면 MissingA를 제거하기 위한 제안이 컨센서스에 도달하고, MissingA는 예정된 후에 Negative UNL에서 최종적으로 제거됩니다.

유효성 검증인이 서버와 같은 프로토콜 규칙을 따르지 않는 경우. (설정 오류, 소프트웨어 버그, 를 의도적으로 따르거나 악의적인 동작 등 여러 가지 가능성이 있음)

Note: 이는 이나 유사한 없이도 ledger의 상태 데이터가 수정되는 몇 가지 경우 중 하나입니다.

Negative UNL에 유효성 검증인을 추가하거나 제거하기 위한 제안은 형태로 이루어집니다. 컨센서스 프로세스는 각 이 컨센서스를 달성하거나 폐기되는지를 결정합니다. 즉, 특정 유효성 검증인을 Negative UNL에서 추가하거나 제거하기 위해서는 신뢰할 수 있는 서버들의 컨센서스가 동일한 변경 사항을 제안해야 합니다.

에서는 부모 ledger의 Negative UNL에 있는 유효성 검증인이 비활성화됩니다. 각 서버는 비활성화된 유효성 검증인을 제거하여 구성된 UNL로 구성된 "유효 UNL"을 계산하고 쿼럼을 다시 계산합니다. (쿼럼은 항상 유효 UNL의 최소 80% 및 구성된 UNL의 최소 60%입니다.) 비활성화된 유효성 검증인이 유효성 검증 투표를 보내면, 서버는 해당 투표를 비활성화된 유효성 검증인의 신뢰도 측정을 계산하기 위한 용도로 추적하지만, 해당 투표를 컨센서스에 도달하는 데 사용하지 않습니다.

NegativeUNL 수정안
컨센서스 프로토콜
ledger 버전
stand-alone 모드
다른 네트워크
트랜잭션
의사 트랜잭션
UNLModify 의사 트랜잭션
의사 트랜잭션
유효성 검사 단계