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
  • 피어 탐색(Peer Discovery)
  • 피어 프로토콜 포트(Peer Protocol Port)
  • 노드 키 쌍(Node Key Pair)
  • 고정 피어(Fixed Peers) 및 피어 예약(Peer Reservations)
  • 개인 피어(Private Peers)
  • 피어링 구성의 장단점(Pros and Cons of Peering Configurations)
  • 개인 서버 구성
  • 참고
  1. Concepts
  2. XRP Ledger 서버

피어 프로토콜(Peer Protocol)

PreviousLedger 역사Next트랜잭션 검열 감지(Transaction Censorship Detection)

Last updated 1 year ago

XRP Ledger의 서버들은 XRP Ledger 피어 프로토콜을 사용하여 서로 통신합니다.

피어 프로토콜은 XRP Ledger의 서버들 간의 주요 통신 방식입니다. XRP Ledger의 동작, 진행 상황 및 연결 상태에 관한 모든 정보는 피어 프로토콜을 통해 전달됩니다. 피어 간 통신의 예시로는 다음과 같은 것들이 있습니다:

  • P2P 네트워크에서 다른 서버들과의 연결을 요청하거나 연결 슬롯의 가용성을 알리는 것.

  • 후보 트랜잭션을 네트워크의 나머지 부분과 공유하는 것.

  • 과거 ledger에서 ledger 데이터를 요청하거나 해당 데이터를 제공하는 것.

  • 일련의 트랜잭션을 컨센서스를 위해 제안하거나 컨센서스 트랜잭션 세트의 적용 결과를 공유하는 것.

피어간 연결을 설정하기 위해 한 서버가 다른 서버에 HTTPS를 통해 연결하고 를 요청하여 XRPL/2.0 프로토콜(이전에는 RTXP/1.2)로 전환합니다. (자세한 정보는 의 문서를 참조하세요.)

피어 탐색(Peer Discovery)

XRP Ledger는 "gossip" 프로토콜을 사용하여 XRP Ledger 네트워크에서 서로 연결할 다른 서버를 찾는 데 도움을 줍니다. 서버가 시작될 때마다 이전에 연결되었던 다른 피어들과 다시 연결합니다. 이후에는 를 대안으로 사용합니다. 서버가 피어에 성공적으로 연결되면 해당 피어에게 피어를 찾고 있는 다른 XRP Ledger 서버들의 연락처 정보(일반적으로 IP 주소와 포트)를 요청합니다. 서버는 이후 해당 서버들과 연결하고, 그 서버들로부터 더 많은 XRP Ledger 서버들의 연락처 정보를 요청할 수 있습니다. 이 과정을 통해 서버는 어떤 단일 피어와의 연결이 끊어져도 신뢰할 수 있게 네트워크 전체에 연결될 수 있습니다.

일반적으로 서버는 다른 피어를 찾기 위해 공개 허브에 단 한 번 연결하면 됩니다. 이후에는 네트워크 연결의 안정성, 허브의 사용량, 그리고 서버가 찾은 다른 고품질 피어의 수에 따라 허브에 대한 연결을 유지하거나 끊을 수 있습니다. 서버는 다른 피어들의 주소를 저장하여 네트워크 중단이나 재시작 후에 해당 피어들에 직접 재연결을 시도할 수 있습니다.

는 현재 서버에 연결된 피어들의 목록을 보여줍니다.

특정한 중요한 등과 같은 고부가 가치 서버의 경우, 서버가 피어 검색 과정을 통해 신뢰할 수 없는 피어에 연결되지 않도록 하는 것이 선호될 수 있습니다. 이 경우, 서버를 만 사용하도록 구성할 수 있습니다.

피어 프로토콜 포트(Peer Protocol Port)

XRP Ledger에 참여하기 위해, rippled 서버는 피어 프로토콜을 사용하여 임의의 피어에 연결합니다. (현재 서버와 경우를 제외하고 모든 피어는 신뢰할 수 없는 것으로 처리됩니다.)

이상적으로, 서버는 피어 프로토콜을 통해 연결을 보내고 받을 수 있어야 합니다. 를 rippled 서버로 전달해야 합니다.

예시:

[port_peer]
port = 2459
ip = 0.0.0.0
protocol = peer

노드 키 쌍(Node Key Pair)

서버가 처음 시작될 때, 피어 프로토콜 통신에서 자신을 식별하기 위해 노드 키 쌍을 생성합니다. 서버는 이 키를 사용하여 모든 피어 프로토콜 통신에 서명합니다. 이를 통해 신뢰할 수 없는 피어를 통해 서버의 메세지가 중계되는 경우에도 P2P 네트워크의 다른 서버의 메시지 무결성을 안정적으로 식별하고 검증할 수 있습니다.

고정 피어(Fixed Peers) 및 피어 예약(Peer Reservations)

일반적으로 rippled 서버는 정상적 수의 피어를 유지하려고 노력하며, 최대 수의 신뢰할 수 없는 피어에 자동으로 연결합니다. rippled 서버를 특정 피어 서버에 계속 연결되도록 구성하는 방법은 다음과 같습니다:

  • 고정된 피어를 사용하여 특정 다른 피어와 IP 주소를 기반으로 항상 연결된 상태를 유지합니다. 이는 피어의 IP 주소가 고정된 경우에만 작동합니다. 고정된 피어는 [ips_fixed] 설정 stanza를 사용하여 구성합니다. 이는 클러스터링이나 개인 피어의 필수 요소입니다. 고정된 피어는 설정 파일에서 정의되며, 변경 사항은 서버를 재시작한 후에 적용됩니다. 같은 개인 또는 조직에서 운영하는 서버를 연결하는 데 가장 유용합니다.

다음의 경우에는 rippled 서버가 신뢰할 수 없는 피어에 연결하지 않습니다:

개인 피어(Private Peers)

IP 주소를 일반 대중으로부터 숨기기 위해 rippled 서버를 "개인" 서버로 구성할 수 있습니다. 이는 서비스 거부 공격이나 신뢰할 수 있는 검증인과 같은 중요한 rippled 서버로부터의 침입 시도로부터의 예방 조치로 유용할 수 있습니다. 개인 서버는 P2P 네트워크에 참여하려면 적어도 하나의 비공개 서버에 연결되도록 구성되어야 합니다. 개인 서버는 비-개인 서버로부터 메시지를 전달하여 네트워크의 나머지로 메시지를 중계합니다.

Caution:

서버를 개인 서버로 구성하는 것은 다음과 같은 효과가 있습니다:

  • 서버는 명시적으로 해당 서버에 연결하기로 구성되지 않은 한 P2P 네트워크의 다른 서버에 대한 발신 연결을 생성하지 않습니다.

  • 서버는 다른 서버의 연결을 허용하도록 명시적으로 구성되지 않은 경우 다른 서버의 수신 연결을 허용하지 않습니다.

Caution:

개인 서버의 소스 코드를 수정하여 이 요청을 무시하고 즉시 피어의 IP 주소를 공유하는 것이 가능합니다. 개인 서버를 구성할 때 이와 같이 수정되지 않은 서버에만 연결하도록 구성해야 합니다.

피어링 구성의 장단점(Pros and Cons of Peering Configurations)

XRP Ledger에 참여하기 위해서는 rippled 서버가 개방된 P2P 네트워크의 나머지 부분에 연결되어야 합니다. 대략적으로 rippled 서버가 네트워크에 어떻게 연결되는지에 대해 세 가지 구성 카테고리가 있습니다:

  • 검색된 피어를 사용합니다. 서버가 적절하게 동작하는 한 서버는 찾은 신뢰할 수 없는 서버에 연결하고 연결 상태를 유지합니다. (예를 들어, 너무 많은 데이터를 요청하지 않고, 네트워크 연결이 안정적이며, 같은 네트워크를 따르는 것으로 보입니다.) 이것이 기본 설정입니다.

  • 동일한 개인 또는 조직이 운영하는 프록시를 사용하는 비공개 서버입니다. 프록시는 개인 서버와 고정 피어링 연결을 유지하는 스톡 rippled 서버(검색된 피어에도 연결됨)입니다.

  • 공개 허브를 사용하는 개인 서버입니다. 이것은 프록시를 사용하는 것과 유사하지만 특정 제3자에 의존합니다.

각 구성의 장단점은 다음과 같습니다:

구성
장점
단점

검색된 피어

  • 유지 관리 부담이 적은 가장 간단한 구성입니다.

  • 직접적인 피어 연결의 기회를 많이 만들어줍니다. 더 많은 직접적인 피어를 가지는 것에는 여러 가지 이점이 있습니다. 서버는 동기화 및 히스토리 백필링 시에 여러 피어로부터 히스토리를 병렬로 가져올 수 있습니다. 모든 피어가 전체 히스토리를 유지하지 않기 때문에 더 많은 피어에 액세스하면 더 많은 다양한 과거 데이터에 액세스할 수도 있습니다.

  • 서버가 연결이 끊긴 피어를 새로운 피어로 대체할 수 있기 때문에 네트워크와의 연결이 끊길 가능성이 낮아집니다.

  • 서버의 피어를 직접 선택할 수 없기 때문에 피어가 악의적으로 행동할 수 있는지 여부를 알 수 없습니다. rippled 서버는 악의적인 피어에 대한 보호를 위해 설계되었지만, 악의적인 피어가 소프트웨어 결함을 이용하여 서버에 영향을 줄 수 있는 위험이 항상 존재합니다.

  • 서버의 피어는 자주 연결이 끊어지거나 변경될 수 있습니다.

프록시를 사용하는 개인 서버

  • 효과적으로 구현할 때 가장 안전하고 신뢰할 수 있는 구성입니다.

  • 구현 방식에 따라 신뢰성과 중복성을 달성할 수 있습니다.

  • 클러스터링을 통해 개인 서버의 성능을 최적화할 수 있습니다.

  • 원하는 만큼 많은 직접적인 피어 연결을 생성할 수 있습니다. 개인 서버는 여러 피어로부터 히스토리를 병렬로 가져올 수 있습니다. 피어를 직접 운영하기 때문에 각 피어가 유지하는 ledger 히스토리의 양을 제어할 수도 있습니다.

  • 여러 개의 서버를 실행하는 것으로 인해 유지 보수 부담과 비용이 증가합니다.

  • 피어 연결 중단 가능성을 완전히 제거하지는 못합니다. 모든 프록시가 동일한 서버 랙에 존재할 경우네트워크 또는 전원 장애가 발생하면 모든 프록시에 영향을 줄 수 있습니다.

공개 허브를 사용하는 개인 서버

  • 적은 양의 구성으로 유지관리 부담이 적습니다.

  • 네트워크로 안전한 연결에 액세스할 수 있습니다.

  • 프록시를 사용하여 연결하는 것과 비교하여 동시에 여러 피어가 연결이 끊겨도 개인 서버가 네트워크와의 연결이 끊길 가능성이 상대적으로 적을 수 있습니다.

  • 신뢰성을 유지하기 위해 신뢰할 수 있는 제 3자에게 의존합니다.

  • 사용하는 공개 허브가 너무 바쁜 경우 개인 서버가 네트워크와의 연결이 끊길 수 있습니다. 공개 허브의 특성상 가장 인기가 많기 때문에 모든 사람에게 안정적인 연결을 유지할 수 없을 수 있습니다.

  • 이 문제를 피하기 위해 가능한 많은 공 허브를 사용하는 것이 좋습니다. 또한, 바쁘지 않은 기본 이외의 허브를 사용하는 것도 도움이 될 수 있습니다.

개인 서버 구성

참고

  • Concepts:

  • Tutorials:

  • References:

IANA는 XRP Ledger 피어 프로토콜을 위해 , 레거시 시스템과의 호환성을 위해 모든 네트워크 인터페이스에서 들어오는 피어 프로토콜 연결을 포트 51235에서 수신 대기합니다. 서버를 실행하는 경우, rippled.cfg 파일을 사용하여 서버가 수신 대기할 포트를 구성할 수 있습니다.

피어 프로토콜 포트는 도 제공합니다.

노드 키 쌍은 데이터베이스에 저장되고 서버가 재시작할 때 재사용됩니다. 데이터베이스를 삭제하면 새로운 노드 키 쌍이 생성되어 다른 식별 정보로 온라인에 나타납니다. 데이터베이스가 삭제되더라도 동일한 키 쌍을 재사용하려면 서버를 [node_seed] 구절로 구성할 수 있습니다. [node_seed] 구절에 사용할 수 있는 값을 생성하려면 를 사용하세요.

노드 키 쌍은 이나 다른 서버의 식별에도 사용됩니다. 서버 클러스터를 가지고 있다면 클러스터의 각 서버를 고유한 [node_seed] 설정으로 구성해야 합니다. 클러스터 설정에 대한 자세한 내용은 ""를 참조하세요.

피어 예약을 사용하여 특정 피어에 우선순위를 부여할 수 있습니다. 서버에 특정 피어에 대한 피어 예약이 있는 경우, 서버는 이미 최대 연결 피어 수에 도달한 경우에도 해당 피어의 연결 요청을 항상 수락합니다. (이로 인해 서버는 최대 피어 수를 초과할 수 있습니다.) 으로 예약된 피어를 식별하므로 IP 주소가 가변되는 피어에 대해서도 이 작업을 수행할 수 있습니다. 피어 예약은 관리자 명령을 통해 구성되며 서버 데이터베이스에 저장되어 온라인에서 조정할 수 있으며 재시작 후에도 유지됩니다. 피어 예약은 서로 다른 사람이나 조직에서 운영하는 서버를 연결하는 데 가장 유용합니다.

서버가 로 구성된 경우, 고정된 피어에만 연결합니다.

서버가로 실행 중인 경우, 어떤 피어에도 연결하지 않습니다.

가 없는 개인 서버를 구성하면 서버가 네트워크에 연결할 수 없으므로 네트워크 상태를 알 수 없으며, 트랜잭션을 브로드캐스트하거나 컨센서스 프로세스에 참여할 수 없습니다.

서버는 비신뢰적인 통신을 포함한 자신의 직접 을 포함하는 신뢰되지 않은 통신들에서 자신의 IP 주소를 공개하지 않도록 요청합니다. 이는 와 같은 신뢰할 수 있는 통신에는 영향을 주지 않습니다. 검증인은 개인 서버 설정에 관계없이 항상 자신의 피어가 그들의 IP 주소를 숨기도록 요청합니다. 이는 서비스 거부 공격에 의한 과부하로부터 검증인 보호하는 데 도움이 됩니다.

개인 서버로 서버를 구성하려면 구성 파일에서 [peer_private] 설정을 1로 설정하십시오. 자세한 지침은 을 참조하십시오.

포트 2459를 할당했지만
기본 rippled config 파일은
특수 피어 포트 메소드
validation_create 메소드
stand-alone 모드
비공개 서버 구성
Consensus
Parallel Networks
Cluster rippled Servers
Configure a Private Server
Configure the Peer Crawler
Forward Ports for Peering
Manually Connect to a Specific Peer
Set Maximum Number of Peers
Use a Peer Reservation
peers method
peer_reservations_add method
peer_reservations_del method
peer_reservations_list method
connect method
fetch_info method
Peer Crawler
HTTP 업그레이드
rippled repository
Overlay Network
하드코딩된 공개 허브
peers 메소드
검증
클러스터링된
방화벽을 통해 피어 프로토콜에 사용되는 포트
개인 피어
클러스터링
Cluster rippled Servers
피어 슬롯 예약과 같은
개인 피어
고정된 피어
노드 키 쌍
피어 크롤러 API 응답
피어 관리자 메소드
New in: rippled 1.4.0
New in: rippled 1.2.1