HyperLedgerFabric日志系统改造(日志适配器)

上篇文章从源码角度去修改代码从而实现日志持久化,本次将给基于x-appender这个项目实现fabric日志持久化改造,并且实现日志的分级输出持久化。

编译x-appender

GOOS=linux GOARCH=amd64 go build

修改镜像

基于fabric-peer原生镜像再添加x-appender二进制文件即可,并修改CMD,具体Dockerfile如下:

FROM hyperledger/fabric-peer:1.4.3
ADD x-appender /usr/bin/
CMD peer node start 2>&1|x-appender

使用镜像

镜像使用和官方稍有不同,如下几点:

  1. yaml文件中无需覆盖镜像的cmd

  2. 添加了了4个环境变量,用于控制x-appender的表现行为:

    • XAPPENDER_LOG_NAME_FORMAT 日志文件名格式,如:%Y-%m-%d

    • XAPPENDER_LOG_ROOT_PATH 日志持久化目录,如:/var/logs

    • XAPPENDER_LOG_MAX_AGE 日志最大保存时间,单位为天,如:30

    • XAPPENDER_LOG_ROTATION 日志切割时间,单位为小时,如:24

示例

peer.yaml,我已经将镜像上传至docker hub,如果你嫌麻烦,就无须制作镜像了。

services:
  peer-00:
    image: tianrandailoving/fabric-peer-x-appender:1.4.3
    environment:
      - CORE_VM_ENDPOINT=unix:///host/var/run/docker.sock
      # the following setting starts chaincode containers on the same
      # bridge network as the peers
      # https://docs.docker.com/compose/networking/
      - CORE_VM_DOCKER_HOSTCONFIG_NETWORKMODE=${COMPOSE_PROJECT_NAME}_byfn
      - FABRIC_LOGGING_SPEC=INFO
      #- FABRIC_LOGGING_SPEC=DEBUG
      - CORE_PEER_TLS_ENABLED=true
      - CORE_PEER_GOSSIP_USELEADERELECTION=true
      - CORE_PEER_GOSSIP_ORGLEADER=false
      - CORE_PEER_PROFILE_ENABLED=true
      - CORE_PEER_TLS_CERT_FILE=/etc/hyperledger/fabric/tls/server.crt
      - CORE_PEER_TLS_KEY_FILE=/etc/hyperledger/fabric/tls/server.key
      - CORE_PEER_TLS_ROOTCERT_FILE=/etc/hyperledger/fabric/tls/ca.crt
      - XAPPENDER_LOG_NAME_FORMAT=%Y-%m-%d
      - XAPPENDER_LOG_ROOT_PATH=/var/logs
      - XAPPENDER_LOG_MAX_AGE=30
      - XAPPENDER_LOG_ROTATION=24
    working_dir: /opt/gopath/src/github.com/hyperledger/fabric/peer
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容