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
  • 개별 유효성 검증인의 부적절한 행동(Individual Validators Misbehaving)
  • 소프트웨어 취약점(Software Vulnerabilities)
  • 사이빌 공격(Sybil Attacks)
  • 51% 공격(51% Attack)
  • 유효성 검증인 중복 요구 사항(Validator Overlap Requirements)
  1. Concepts
  2. 컨센서스 네트워크(Consensus Protocol)

공격과 실패 모드에 대한 컨센서스 보호(Consensus Protections Against Attacks and Failure Modes)

Previous컨센서스 원칙과 규칙(Consensus Principles and Rules)Next불변성 체크

Last updated 1 year ago

XRP Ledger 컨센서스 프로토콜은 비잔틴 장애에 내구성이 있는 컨센서스 메커니즘으로, 모든 종류의 문제가 발생할 수 있는 상황에서 작동하도록 설계되었습니다. 참여자들은 신뢰할 수 없는 개방 네트워크를 통해 통신하며, 악의적인 행위자들은 언제든지 시스템을 제어하거나 중단하려고 시도할 수 있습니다. 게다가, XRP Ledger 컨센서스 프로토콜의 참여자 집합은 미리 알려져 있지 않으며 시간이 지남에 따라 변경될 수 있습니다.

트랜잭션을 빠르게 확인하는 것은 복잡한 과제이며, 완벽한 시스템을 구축하는 것은 불가능합니다. XRP Ledger 컨센서스 프로토콜은 대부분의 상황에서 최대한 잘 작동하도록 설계되었으며, 작동하지 못하는 상황에서는 가능한 우아하게 실패합니다.

이 문서는 XRP Ledger 컨센서스 프로토콜이 직면하는 일부 유형의 도전과 그 처리 방법에 대해 설명합니다.

개별 유효성 검증인의 부적절한 행동(Individual Validators Misbehaving)

유효성 검증인은 각 새로운 ledger 버전을 결정하는 과정에 적극적으로 기여하는 서버입니다. 유효성 검증인은 구성된 서버들에게 (간접적으로 포함되어) 신뢰를 받으며 영향을 미칠 수 있습니다. 어떤 유효성 검증인이 부적절한 행동을 한다고 해도 컨센서스는 지속될 수 있으며, 다양한 실패 사례를 포함하여 다음과 같습니다:

  • 이용 불가능하거나 과부하 상태인 경우.

  • 네트워크에서 부분적으로 연결이 끊긴 경우, 그들의 메시지가 일부 참가자에게만 지연 없이 도달하는 경우.

  • 다른 사람을 속이거나 네트워크를 중단하기 위해 의도적으로 행동하는 경우.

  • 억압적인 정부로부터의 위협과 같은 외부 요인으로 인해 악의적으로 행동하는 경우.

  • 버그나 오래된 소프트웨어로 인해 혼란스러운 또는 잘못된 메시지를 우연히 전송하는 경우.

일반적으로 컨센서스는 신뢰하는 유효성 검증인의 약 20% 미만이 잘못된 행동을 하는 경우에도 문제 없이 계속될 수 있습니다. (구체적인 비율 및 관련 수학적인 내용은 최신 문서를 참조하십시오.)

만약 유효성 검증인의 약 20% 이상이 도달할 수 없거나 적절하게 행동하지 않는 경우, 네트워크는 컨센서스에 도달하지 못하게 됩니다. 이러한 상황에서는 새로운 거래가 일시적으로 처리될 수 있지만, 새로운 ledger 버전은 검증되지 않으므로 해당 거래의 최종 결과는 확실하지 않습니다. 이러한 경우 XRP Ledger가 정상적으로 작동하지 않음이 명백해지며, 인간 참가자들은 기다릴지 아니면 신뢰하는 유효성 검증인의 구성을 다시 설정할지를 결정하는 개입을 할 수 있습니다.

잘못된 거래를 확인하기 위해서는 신뢰하는 유효성 검증인의 최소 80%가 해당 거래를 승인하고 정확한 결과에 동의해야 합니다. (잘못된 거래에는 이미 사용된 자금을 소비하는 거래 또는 네트워크의 규칙을 위반하는 거래가 포함됩니다.) 즉, 신뢰하는 유효성 검증인의 대다수가 의도적으로 협력해야만 잘못된 거래를 확인할 수 있습니다. 전 세계의 다양한 사람들과 기업들이 운영하는 수십 개의 신뢰할 수 있는 유효성 검증인이 있기 때문에 이는 의도적으로 달성하기 매우 어려울 것입니다.

소프트웨어 취약점(Software Vulnerabilities)

XRP Ledger 컨센서스 프로토콜의 구현, 일반적으로 배포되는 소프트웨어 패키지 또는 해당 의존성에 대한 버그(또는 악성 코드)는 심각한 문제입니다. 조심해야 할 사항입니다. 신중히 테스트하고 검토하는 절차를 거치고, 안전한 소프트웨어 패키지를 제공하기 위해 Ripple은 다음과 같은 조치를 취하고 있습니다:

  • 공식 XRP Ledger 저장소에 대한 변경 사항에 대한 철저하고 견고한 코드 검토 프로세스.

  • 모든 릴리스 및 공식 소프트웨어 패키지에 대한 Ripple 직원의 디지털 서명.

  • 보안 취약점 및 불안정성에 대한 정기적인 전문적인 검토.

사이빌 공격(Sybil Attacks)

이러한 신뢰는 자동으로 이루어지지 않으며, 성공적인 사이빌 공격을 수행하려면 대상 인간 및 기업을 설득하여 XRP Ledger 서버를 재구성하여 공격자의 유효성 검증인을 신뢰하도록 만드는 어려운 작업이 필요합니다. 실제로 하나의 개별 개체가 속았다고 하더라도, 이는 구성을 변경하지 않는 다른 참가자들에게는 최소한의 영향을 미칠 것입니다.

51% 공격(51% Attack)

유효성 검증인 중복 요구 사항(Validator Overlap Requirements)

XRP Ledger의 모든 참여자들이 인증된 거래에 대해 컨센서스를 이루려면, 그들은 우선 대부분의 다른 이들이 선택한 신뢰할 수 있는 검증인들의 집합을 선택해야 합니다. 최악의 경우, 약 90% 미만의 중복이 있을 경우 일부 참가자들이 서로 이겨나갈 수 있습니다. 이러한 이유로 Ripple은 회사, 산업 및 커뮤니티에서 운영하는 신뢰할 수 있고 잘 유지되는 서버를 포함한 추천 검증인 목록을 서명하여 게시합니다.

기본적으로 XRP Ledger 서버는 Ripple이 운영하는 검증인 목록 사이트를 사용하도록 설정되어 있습니다. 해당 사이트는 Ripple이 주기적으로 업데이트하는 추천 검증인 목록(또는 추천 Unique Node List, UNL)을 제공합니다. 이런 방식으로 설정된 서버들은 최신 버전의 목록에 있는 모든 검증인들을 신뢰하게 되며, 이는 동일한 목록을 사용하는 다른 서버들과 100% 중복을 보장합니다. 기본 설정에는 사이트의 내용의 진위를 검증하는 공개 키가 포함되어 있습니다. 사이트가 다운되는 경우, XRP Ledger의 P2P 네트워크에 있는 서버들이 서로 사이에서 서명된 목록 업데이트를 직접 중계할 수 있습니다.

기술적으로, 서버를 운영한다면, 개인적으로 신뢰하는 검증인를 개별적으로 선택하거나 자신만의 목록 사이트를 설정할 수 있지만, Ripple은 이렇게 하는 것을 권장하지 않습니다. 만약 선택한 검증인 집합이 다른 검증인 집합과 충분한 중복이 없다면, 서버는 네트워크의 나머지 부분과 이격할 수 있고, 서버의 이격된 상태에 따른 조치를 취함으로써 돈을 잃을 수 있습니다.

기반: 이를 통해 일반 대중이 관련 소프트웨어를 검토, 컴파일 및 독립적으로 테스트할 수 있습니다.

보안 연구자들이 책임을 지고 취약점을 공개할 경우 보상하는 프로그램.

은 가짜 신분을 가진 많은 수의 신분을 사용하여 네트워크를 제어하려는 시도입니다. XRP Ledger에서 사이빌 공격은 많은 수의 유효성 검증인을 실행한 다음, 다른 참가자들을 설득하여 해당 유효성 검증인을 신뢰하도록 만드는 형태로 이루어질 수 있습니다. 이러한 유형의 공격은 이론적으로 가능하지만, 유효성 검증인이 신뢰받기 위해서는 인간의 개입이 필요하기 때문에 실현하기는 매우 어려울 것입니다.

어떤 유효성 검사 서버를 실행하더라도, 해당 서버는 기존 참가자들이 검증된 것으로 여기는 내용에 어떠한 의견도 제시할 수 없습니다. 다른 서버들은 유효성 검증인 목록이나 명시적인 구성을 통해 신뢰하는 유효성 검증인들만을 수신합니다. (기본 유효성 검증인 목록이 작동 방식에 대한 요약은 아래 ""을 참조하십시오.)

"51% 공격"은 한 당사자가 모든 마이닝 또는 투표 권한의 50% 이상을 통제하는 블록체인 시스템에 대한 공격입니다. (엄밀히 말하면, 50% 이상의 어떤 양도 충분합니다.) XRP Ledger는 컨센서스 메커니즘에서 마이닝을 사용하지 않기 때문에 51% 공격에 취약하지 않습니다. XRP Ledger의 다음으로 가까운 유사한 공격 형태는 이며, 이 역시 어려울 것입니다.

보다 이질적인 검증인 목록을 허용하는 향상된 컨센서스 프로토콜 설계에 대한 연구가 진행 중입니다. 자세한 정보는 페이지를 참조하십시오.

네트워크의 원하는 속성을 유지하면서
컨센서스 연구
공개 소스 코드
버그 바운티
사이빌 공격
컨센서스 연구
유효성 검증인 중복 요구 사항
사이빌 공격