Hyperledger FabricメトリックAPIの問合せ

Hyperledger Fabricメトリックを問い合せて、出力をPrometheusデータベースに公開できます。

Hyperledger Fabric 1.4以降、RESTful操作サービスには、Prometheusを利用してピア・ノードおよびオーダラ・ノードから操作メトリックをプルできるメトリック・エンドポイントが用意されています。Oracle Blockchain Platformでは、これらのメトリックを問い合せることができる新しいエンドポイントが作成されています: 「ピアまたはオーダラのネイティブFabricメトリックの取得」

詳細は、Hyperledger Fabricメトリックのドキュメントを参照してください。

Prometheusデータベースの作成

標準的なPrometheusデプロイメントでは、インストゥルメント化されたターゲットによって公開されたHTTPエンドポイントからメトリックをリクエストすることで、メトリックをスクレイプします。Prometheusがメトリックのリクエストを処理するため、これはプル方式とみなされます。

次のサンプル構成を使用してPrometheusデータベースを構成します:
# my global config
global:
  scrape_interval:     15s # Set the scrape interval to every 15 seconds. Default is every 1 minute.
  evaluation_interval: 15s # Evaluate rules every 15 seconds. The default is every 1 minute.
  # scrape_timeout is set to the global default (10s). 

# Alertmanager configuration
alerting:
  alertmanagers:
  - static_configs:
    - targets:
      # - alertmanager:9093 

# Load rules once and periodically evaluate them according to the global 'evaluation_interval'.
rule_files:
  # - "first_rules.yml"
  # - "second_rules.yml" 

# A scrape configuration containing exactly one endpoint to scrape:
# Here it's Prometheus itself.
scrape_configs:
  # The job name is added as a label `job=<job_name>` to any timeseries scraped from this config.
  - job_name: 'prometheus'
  metrics_path: '/console/admin/api/v1.1/dashboard/statistics/metrics'
  params:
        nodeId:['peer0']
    scheme: 'https'
    tls_config:
        insecure_skip_verify: true
    static_configs:
       - targets: ['hostname.com:10001']

Hyperledger Fabricメトリックを問い合せるためのREST APIのコール

次のREST APIを使用して、Hyperledger Fabricメトリックを問い合せます。
  • メソッド: GET
  • パス: /console/admin/api/v1.1/dashboard/statistics/metrics
  • 問合せパラメータ: nodeID(required): The node ID of the peer or orderer to be queried.
たとえば、cURLでAPIをコールするには:
curl -X GET "https://<rest_server_url:port>/console/admin/api/v1.1/dashboard/statistics/metrics?nodeId=peer0" 
    -H "accept:application/json"