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
  • 배경
  • 탐지
  • 사전 감지
  • 사후 감지
  • rippled 1.1.0 이상 버전
  • rippled 1.1.0 이전 버전
  • 수정
  • 요구 사항
  • 마이그레이션 프로세스
  1. Tutorials
  2. rippled 서버 관리
  3. 문제 해결

SQLite 트랜잭션 데이터베이스 페이지 크기 문제 해결

전체 ledger 기록(또는 매우 많은 양의 트랜잭션 기록)이 있는 rippled 서버와 처음에 0.40.0(2017년 1월 출시) 이전의 rippled 버전으로 생성된 데이터베이스에서 서버가 제대로 작동하지 않게 하는 SQLite 데이터베이스 페이지 크기 문제가 발생할 수 있습니다. 최근 트랜잭션 기록만 저장하는 서버(기본 구성)와 데이터베이스 파일이 rippled 버전 0.40.0 이상으로 생성된 서버는 이 문제가 발생하지 않을 가능성이 높습니다.

이 문서에서는 이 문제가 발생하는 경우 이를 감지하고 수정하는 단계를 설명합니다.

배경

rippled 서버는 트랜잭션 기록의 사본을 SQLite 데이터베이스에 저장합니다. 버전 0.40.0 이전에는 이 데이터베이스의 용량이 약 2TB로 구성되었습니다. 대부분의 용도로는 이 정도면 충분합니다. 그러나 ledger 32570(프로덕션 XRP Ledger 기록에서 사용 가능한 가장 오래된 ledger 버전)까지의 전체 트랜잭션 내역은 SQLite 데이터베이스 용량을 초과할 가능성이 높습니다. rippled 서버 버전 0.40.0 이상에서는 더 큰 용량으로 SQLite 데이터베이스 파일을 생성하므로 이 문제가 발생하지 않을 가능성이 높습니다.

SQLite 데이터베이스의 용량은 데이터베이스의 페이지 크기 매개변수의 결과이며, 데이터베이스가 생성된 후에는 쉽게 변경할 수 없습니다. (SQLite 내부에 대한 자세한 내용은 공식 SQLite 설명서를 참조하세요.) 데이터베이스가 저장된 디스크 및 파일 시스템에 여유 공간이 남아 있어도 데이터베이스가 용량에 도달할 수 있습니다. 아래 수정 사항에 설명된 대로 이 문제를 방지하기 위해 페이지 크기를 재구성하려면 마이그레이션 프로세스에 다소 시간이 소요됩니다.

Tip:

대부분의 사용 사례에서는 전체 기록이 필요하지 않습니다. 전체 트랜잭션 기록이 있는 서버는 장기 분석 및 아카이브 목적이나 재해에 대한 예방책으로 유용할 수 있습니다. 트랜잭션 기록을 저장하는 데 리소스를 덜 많이 사용하는 방법은 히스토리 샤딩을 참조하세요.

탐지

서버가 이 문제에 취약한 경우 두 가지 방법으로 문제를 감지할 수 있습니다:

  • rippled 서버가 1.1.0 버전 이상인 경우 문제가 발생하기 전에 문제를 사전에 감지할 수 있습니다.

  • 모든 rippled 버전에서 문제를 사후적으로(서버가 충돌할 때) 감지할 수 있습니다.

두 경우 모두 문제를 감지하려면 rippled 서버 로그에 액세스해야 합니다.

Tip:

디버그 로그의 위치는 rippled 서버의 구성 파일에 따라 다릅니다. 기본 구성은 서버의 디버그 로그를 /var/log/rippled/debug.log 파일에 기록합니다.

사전 감지

SQLite 페이지 크기 문제를 사전에 감지하려면 rippled 1.1.0 이상을 실행 중이어야 합니다. rippled 서버는 디버그 로그에 다음과 같은 메시지를 2분에 한 번 이상 주기적으로 기록합니다. (로그 항목의 정확한 숫자 값과 트랜잭션 데이터베이스 경로는 사용자 환경에 따라 다릅니다.)

Transaction DB pathname: /opt/rippled/transaction.db; SQLite page size: 1024
  bytes; Free pages: 247483646; Free space: 253423253504 bytes; Note that this
  does not take into account available disk space.

SQLite 페이지 크기: 1024바이트 값은 트랜잭션 데이터베이스가 더 작은 페이지 크기로 구성되어 있으며 전체 트랜잭션 기록을 위한 용량이 없음을 나타냅니다. 값이 이미 4096바이트 이상인 경우에는 SQLite 데이터베이스에 전체 트랜잭션 기록을 저장할 수 있는 충분한 용량이 이미 있으므로 이 문서에 설명된 마이그레이션을 수행할 필요가 없습니다.

이 로그 메시지에 설명된 여유 공간이 524288000바이트(500MB) 미만이 되면 rippled 서버가 중지됩니다. 여유 공간이 이 임계값에 가까워지면 문제를 해결하여 예기치 않은 중단을 방지하세요.

사후 감지

서버의 SQLite 데이터베이스 용량이 이미 초과된 경우, rippled 서비스는 문제를 나타내는 로그 메시지를 작성하고 서비스를 중단합니다.

rippled 1.1.0 이상 버전

rippled 버전 1.1.0 이상에서는 서버의 디버그 로그에 다음과 같은 메시지와 함께 서버가 정상적으로 종료됩니다:

Free SQLite space for transaction db is less than 512MB. To fix this, rippled
  must be executed with the vacuum <sqlitetmpdir> parameter before restarting.
  Note that this activity can take multiple days, depending on database size.

rippled 1.1.0 이전 버전

1.1.0 이전 rippled 버전에서는 서버의 디버그 로그에 다음과 같은 메시지와 함께 서버가 반복적으로 충돌합니다:

Terminating thread doJob: AcquisitionDone: unhandled
  N4soci18sqlite3_soci_errorE 'sqlite3_statement_backend::loadOne: database or
  disk is full while executing "INSERT INTO [...]

수정

이 문서에 설명된 단계에 따라 지원되는 Linux 시스템에서 rippled를 사용하여 이 문제를 해결할 수 있습니다. 권장 하드웨어 구성과 거의 일치하는 시스템 사양을 갖춘 전체 기록 서버의 경우 이 프로세스에 이틀 이상이 소요될 수 있습니다.

요구 사항

  • rippled 버전 1.1.0 이상을 실행 중이어야 합니다.

    • 이 프로세스를 시작하기 전에 rippled를 최신 안정 버전으로 업그레이드하세요.

    • 다음 명령을 실행하여 로컬에 설치한 rippled 버전을 확인할 수 있습니다:

rippled --version

rippled 사용자가 쓰기 가능한 디렉터리에 트랜잭션 데이터베이스의 두 번째 복사본을 임시로 저장할 수 있는 충분한 여유 공간이 있어야 합니다. 이 여유 공간은 기존 트랜잭션 데이터베이스와 동일한 파일 시스템에 있을 필요는 없습니다. 트랜잭션 데이터베이스는 구성의 [database_path] 설정으로 지정한 폴더에 있는 transaction.db 파일에 저장됩니다. 이 파일의 크기를 확인하여 필요한 여유 공간을 확인할 수 있습니다. 예를 들어:

ls -l /var/lib/rippled/db/transaction.db

마이그레이션 프로세스

트랜잭션 데이터베이스를 더 큰 페이지 크기로 마이그레이션하려면 다음 단계를 수행하세요:

  1. 모든 필수 요건을 충족하는지 확인합니다.

  2. 마이그레이션 프로세스 중에 임시 파일을 저장할 폴더를 만듭니다.

mkdir /tmp/rippled_txdb_migration
  1. rippled 사용자에게 임시 폴더에 대한 소유권을 부여하여 해당 폴더에 파일을 쓸 수 있도록 합니다. (임시 폴더가 rippled 사용자가 이미 쓰기 권한이 있는 위치에 있는 경우에는 이 작업이 필요하지 않습니다.)

chown rippled /tmp/rippled_txdb_migration
df -h /tmp/rippled_txdb_migration

Filesystem      Size  Used Avail Use% Mounted on
/dev/sda2       5.4T  2.6T  2.6T  50% /tmp
  1. rippled가 여전히 실행 중이면 중지합니다:

sudo systemctl stop rippled
  1. 로그아웃할 때 프로세스가 중지되지 않도록 화면 세션(또는 기타 유사한 도구)을 엽니다:

screen
  1. rippled 사용자가 됩니다:

sudo su - rippled
  1. 임시 디렉터리 경로와 함께 --vacuum 명령을 사용하여 rippled 실행 파일을 직접 실행합니다:

/opt/ripple/bin/rippled -q --vacuum /tmp/rippled_txdb_migration

rippled 실행 파일은 즉시 다음 메시지를 표시합니다:

VACUUM beginning. page_size: 1024
  1. 프로세스가 완료될 때까지 기다리세요. 이 과정은 이틀 이상 걸릴 수 있습니다. 프로세스가 완료되면 rippled 실행 파일에 다음 메시지가 표시된 후 종료됩니다:

VACUUM finished. page_size: 4096

기다리는 동안 CTRL-A를 누른 다음 D를 눌러 화면 세션을 분리할 수 있으며, 나중에 다음과 같은 명령을 사용하여 화면 세션을 다시 연결할 수 있습니다:

screen -x -r

프로세스가 끝나면 화면 세션을 종료합니다:

exit

화면 명령에 대한 자세한 내용은 공식 화면 사용 설명서 또는 온라인에서 제공되는 기타 여러 리소스를 참조하세요.

  1. rippled 서비스를 다시 시작합니다.

sudo systemctl start rippled
  1. rippled 서비스가 성공적으로 시작되었는지 확인합니다. 커맨드라인 인터페이스를 사용하여 서버 상태를 확인할 수 있습니다(JSON-RPC 요청을 수락하지 않도록 서버를 구성하지 않은 경우). 예를 들어:

/opt/ripple/bin/rippled server_info

이 명령의 예상 응답에 대한 설명은 server_info 메소드 문서를 참조하세요.

  1. 서버의 디버그 로그를 확인하여 SQLite 페이지 크기가 이제 4096인지 확인합니다:

tail -F /var/log/rippled/debug.log

주기적인 로그 메시지에도 마이그레이션 전보다 훨씬 더 많은 여유 페이지와 여유 페이지가 표시되어야 합니다.

  1. 원하는 경우 마이그레이션 프로세스를 위해 만든 임시 폴더를 제거할 수 있습니다.

rm -r /tmp/rippled_txdb_migration

트랜잭션 데이터베이스의 임시 복사본을 보관하기 위해 추가 스토리지를 마운트한 경우 지금 마운트를 해제하고 제거할 수 있습니다.

Previousrippled 서버가 시작되지 않음Next클리오 서버 관리

Last updated 1 year ago

임시 폴더에 트랜잭션 데이터베이스 사본을 저장할 수 있는 충분한 여유 공간이 있는지 확인합니다. 예를 들어, df 명령의 사용 가능 출력을 파일의 크기와 비교합니다.

transaction.db