From 25a4650b9ebf34d3064d14f3f7bd2c9a1498b3ab Mon Sep 17 00:00:00 2001 From: goldsquid Date: Wed, 1 Oct 2025 17:19:51 +0700 Subject: [PATCH] initial commit --- ...layer-mainnet-cdk-erigon-archive-trace.yml | 116 ++++++++++++++++++ ...xlayer-mainnet-cdk-erigon-pruned-trace.yml | 116 ++++++++++++++++++ xlayer/mainnet/erigon.yaml | 22 ++++ 3 files changed, 254 insertions(+) create mode 100644 xlayer/cdk-erigon/xlayer-mainnet-cdk-erigon-archive-trace.yml create mode 100644 xlayer/cdk-erigon/xlayer-mainnet-cdk-erigon-pruned-trace.yml create mode 100644 xlayer/mainnet/erigon.yaml diff --git a/xlayer/cdk-erigon/xlayer-mainnet-cdk-erigon-archive-trace.yml b/xlayer/cdk-erigon/xlayer-mainnet-cdk-erigon-archive-trace.yml new file mode 100644 index 00000000..dfea36f3 --- /dev/null +++ b/xlayer/cdk-erigon/xlayer-mainnet-cdk-erigon-archive-trace.yml @@ -0,0 +1,116 @@ +--- +x-logging-defaults: &logging-defaults + driver: json-file + options: + max-size: "10m" + max-file: "3" + +# Usage: +# +# mkdir rpc && cd rpc +# +# git init +# git remote add origin https://github.com/StakeSquid/ethereum-rpc-docker.git +# git fetch origin vibe +# git checkout origin/vibe +# +# docker run --rm alpine sh -c "printf '0x'; head -c32 /dev/urandom | xxd -p -c 64" > .jwtsecret +# +# env +# ... +# IP=$(curl ipinfo.io/ip) +# DOMAIN=${IP}.traefik.me +# COMPOSE_FILE=base.yml:rpc.yml:xlayer/cdk-erigon/xlayer-mainnet-cdk-erigon-archive-trace.yml +# +# docker compose up -d +# +# curl -X POST https://${IP}.traefik.me/xlayer-mainnet-archive \ +# -H "Content-Type: application/json" \ +# --data '{"jsonrpc":"2.0","method":"eth_blockNumber","params":[],"id":1}' + +services: + xlayer-mainnet-archive: + image: ${XLAYER_CDK_ERIGON_IMAGE:-xlayer/xlayer-erigon}:${XLAYER_MAINNET_CDK_ERIGON_VERSION:-v0.8.7.1} + sysctls: + # TCP Performance + net.ipv4.tcp_slow_start_after_idle: 0 # Disable slow start after idle + net.ipv4.tcp_no_metrics_save: 1 # Disable metrics cache + net.ipv4.tcp_rmem: 4096 87380 16777216 # Increase TCP read buffers + net.ipv4.tcp_wmem: 4096 87380 16777216 # Increase TCP write buffers + net.core.somaxconn: 32768 # Higher connection queue + # Memory/Connection Management + # net.core.netdev_max_backlog: 50000 # Increase network buffer + net.ipv4.tcp_max_syn_backlog: 30000 # More SYN requests + net.ipv4.tcp_max_tw_buckets: 2000000 # Allow more TIME_WAIT sockets + ulimits: + nofile: 1048576 # Max open files (for RPC/WS connections) + user: root + ports: + - 11358:11358 + - 11358:11358/udp + expose: + - 8545 + entrypoint: [cdk-erigon] + command: + - --config=/config/erigon.yaml + - --datadir=/root/.erigon + - --db.engine= + - --gcmode=archive + - --http + - --http.addr=0.0.0.0 + - --http.api= + - --http.port=8545 + - --nat=extip:${IP} + - --port=11358 + - --rpc.gascap=6000000000 + - --rpc.returndata.limit=1500000 + - --state.scheme= + - --syncmode=full + - --ws + - --ws.port=8545 + restart: unless-stopped + stop_grace_period: 5m + networks: + - chains + volumes: + - ${XLAYER_MAINNET_CDK_ERIGON_ARCHIVE_TRACE_DATA:-xlayer-mainnet-cdk-erigon-archive-trace}:/root/.erigon + - ./xlayer/mainnet:/config + - /slowdisk:/slowdisk + logging: *logging-defaults + labels: + - prometheus-scrape.enabled=false + - traefik.enable=true + - traefik.http.middlewares.xlayer-mainnet-cdk-erigon-archive-trace-stripprefix.stripprefix.prefixes=/xlayer-mainnet-archive + - traefik.http.services.xlayer-mainnet-cdk-erigon-archive-trace.loadbalancer.server.port=8545 + - ${NO_SSL:-traefik.http.routers.xlayer-mainnet-cdk-erigon-archive-trace.entrypoints=websecure} + - ${NO_SSL:-traefik.http.routers.xlayer-mainnet-cdk-erigon-archive-trace.tls.certresolver=myresolver} + - ${NO_SSL:-traefik.http.routers.xlayer-mainnet-cdk-erigon-archive-trace.rule=Host(`$DOMAIN`) && (Path(`/xlayer-mainnet-archive`) || Path(`/xlayer-mainnet-archive/`))} + - ${NO_SSL:+traefik.http.routers.xlayer-mainnet-cdk-erigon-archive-trace.rule=Path(`/xlayer-mainnet-archive`) || Path(`/xlayer-mainnet-archive/`)} + - traefik.http.routers.xlayer-mainnet-cdk-erigon-archive-trace.middlewares=xlayer-mainnet-cdk-erigon-archive-trace-stripprefix, ipallowlist + +volumes: + xlayer-mainnet-cdk-erigon-archive-trace: + +x-upstreams: + - id: $${ID} + labels: + provider: $${PROVIDER} + connection: + generic: + rpc: + url: $${RPC_URL} + ws: + frameSize: 20Mb + msgSize: 50Mb + url: $${WS_URL} + chain: xlayer + method-groups: + enabled: + - debug + - filter + - trace + methods: + disabled: + enabled: + - name: txpool_content # TODO: should be disabled for rollup nodes +... \ No newline at end of file diff --git a/xlayer/cdk-erigon/xlayer-mainnet-cdk-erigon-pruned-trace.yml b/xlayer/cdk-erigon/xlayer-mainnet-cdk-erigon-pruned-trace.yml new file mode 100644 index 00000000..11b7740b --- /dev/null +++ b/xlayer/cdk-erigon/xlayer-mainnet-cdk-erigon-pruned-trace.yml @@ -0,0 +1,116 @@ +--- +x-logging-defaults: &logging-defaults + driver: json-file + options: + max-size: "10m" + max-file: "3" + +# Usage: +# +# mkdir rpc && cd rpc +# +# git init +# git remote add origin https://github.com/StakeSquid/ethereum-rpc-docker.git +# git fetch origin vibe +# git checkout origin/vibe +# +# docker run --rm alpine sh -c "printf '0x'; head -c32 /dev/urandom | xxd -p -c 64" > .jwtsecret +# +# env +# ... +# IP=$(curl ipinfo.io/ip) +# DOMAIN=${IP}.traefik.me +# COMPOSE_FILE=base.yml:rpc.yml:xlayer/cdk-erigon/xlayer-mainnet-cdk-erigon-pruned-trace.yml +# +# docker compose up -d +# +# curl -X POST https://${IP}.traefik.me/xlayer-mainnet-pruned \ +# -H "Content-Type: application/json" \ +# --data '{"jsonrpc":"2.0","method":"eth_blockNumber","params":[],"id":1}' + +services: + xlayer-mainnet-pruned: + image: ${XLAYER_CDK_ERIGON_IMAGE:-xlayer/xlayer-erigon}:${XLAYER_MAINNET_CDK_ERIGON_VERSION:-v0.8.7.1} + sysctls: + # TCP Performance + net.ipv4.tcp_slow_start_after_idle: 0 # Disable slow start after idle + net.ipv4.tcp_no_metrics_save: 1 # Disable metrics cache + net.ipv4.tcp_rmem: 4096 87380 16777216 # Increase TCP read buffers + net.ipv4.tcp_wmem: 4096 87380 16777216 # Increase TCP write buffers + net.core.somaxconn: 32768 # Higher connection queue + # Memory/Connection Management + # net.core.netdev_max_backlog: 50000 # Increase network buffer + net.ipv4.tcp_max_syn_backlog: 30000 # More SYN requests + net.ipv4.tcp_max_tw_buckets: 2000000 # Allow more TIME_WAIT sockets + ulimits: + nofile: 1048576 # Max open files (for RPC/WS connections) + user: root + ports: + - 12399:12399 + - 12399:12399/udp + expose: + - 8545 + entrypoint: [cdk-erigon] + command: + - --config=/config/erigon.yaml + - --datadir=/root/.erigon + - --db.engine= + - --gcmode=full + - --http + - --http.addr=0.0.0.0 + - --http.api= + - --http.port=8545 + - --nat=extip:${IP} + - --port=12399 + - --rpc.gascap=6000000000 + - --rpc.returndata.limit=1500000 + - --state.scheme= + - --syncmode=full + - --ws + - --ws.port=8545 + restart: unless-stopped + stop_grace_period: 5m + networks: + - chains + volumes: + - ${XLAYER_MAINNET_CDK_ERIGON_PRUNED_TRACE_DATA:-xlayer-mainnet-cdk-erigon-pruned-trace}:/root/.erigon + - ./xlayer/mainnet:/config + - /slowdisk:/slowdisk + logging: *logging-defaults + labels: + - prometheus-scrape.enabled=false + - traefik.enable=true + - traefik.http.middlewares.xlayer-mainnet-cdk-erigon-pruned-trace-stripprefix.stripprefix.prefixes=/xlayer-mainnet-pruned + - traefik.http.services.xlayer-mainnet-cdk-erigon-pruned-trace.loadbalancer.server.port=8545 + - ${NO_SSL:-traefik.http.routers.xlayer-mainnet-cdk-erigon-pruned-trace.entrypoints=websecure} + - ${NO_SSL:-traefik.http.routers.xlayer-mainnet-cdk-erigon-pruned-trace.tls.certresolver=myresolver} + - ${NO_SSL:-traefik.http.routers.xlayer-mainnet-cdk-erigon-pruned-trace.rule=Host(`$DOMAIN`) && (Path(`/xlayer-mainnet-pruned`) || Path(`/xlayer-mainnet-pruned/`))} + - ${NO_SSL:+traefik.http.routers.xlayer-mainnet-cdk-erigon-pruned-trace.rule=Path(`/xlayer-mainnet-pruned`) || Path(`/xlayer-mainnet-pruned/`)} + - traefik.http.routers.xlayer-mainnet-cdk-erigon-pruned-trace.middlewares=xlayer-mainnet-cdk-erigon-pruned-trace-stripprefix, ipallowlist + +volumes: + xlayer-mainnet-cdk-erigon-pruned-trace: + +x-upstreams: + - id: $${ID} + labels: + provider: $${PROVIDER} + connection: + generic: + rpc: + url: $${RPC_URL} + ws: + frameSize: 20Mb + msgSize: 50Mb + url: $${WS_URL} + chain: xlayer + method-groups: + enabled: + - debug + - filter + - trace + methods: + disabled: + enabled: + - name: txpool_content # TODO: should be disabled for rollup nodes +... \ No newline at end of file diff --git a/xlayer/mainnet/erigon.yaml b/xlayer/mainnet/erigon.yaml new file mode 100644 index 00000000..8483b536 --- /dev/null +++ b/xlayer/mainnet/erigon.yaml @@ -0,0 +1,22 @@ +zkevm.l2-chain-id: 196 +zkevm.l2-sequencer-rpc-url: https://rpc.xlayer.tech +zkevm.l2-datastreamer-url: stream.xlayer.tech:8800 +zkevm.l1-rpc-url: ${your-l1-rpc-url} +zkevm.l1-chain-id: 1 + +zkevm.address-sequencer: "0xAF9d27ffe4d51eD54AC8eEc78f2785D7E11E5ab1" +zkevm.address-zkevm: "0x2B0ee28D4D51bC9aDde5E58E295873F61F4a0507" +zkevm.address-rollup: "0x5132A183E9F3CB7C848b0AAC5Ae0c4f0491B7aB2" +zkevm.address-ger-manager: "0x580bda1e7A0CFAe92Fa7F6c20A3794F169CE3CFb" + +zkevm.l1-rollup-id: 3 +zkevm.l1-first-block: 19218658 +zkevm.l1-block-range: 2000 +zkevm.l1-query-delay: 1000 +zkevm.datastream-version: 3 + +zkevm.increment-tree-always: false +zkevm.rebuild-tree-after: 10000000 + +zkevm.get-logs-timeout: 86400s +zkevm.get-logs-retries: 72 \ No newline at end of file