From abda0c9ff7166d2c07ec871bf87848455e77b995 Mon Sep 17 00:00:00 2001 From: Payne Date: Wed, 13 Aug 2025 21:00:42 +0300 Subject: [PATCH] add temporary nitro erigon yml file --- .DS_Store | Bin 0 -> 14340 bytes .../arbitrum-one-nitro-archive-erigon.yml | 181 ++++++++++++++++++ 2 files changed, 181 insertions(+) create mode 100644 .DS_Store create mode 100644 arb/nitro/arbitrum-one-nitro-archive-erigon.yml diff --git a/.DS_Store b/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..c161d66490c58f3a1e957be484c73832a58c773c GIT binary patch literal 14340 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 literal 0 HcmV?d00001 diff --git a/arb/nitro/arbitrum-one-nitro-archive-erigon.yml b/arb/nitro/arbitrum-one-nitro-archive-erigon.yml new file mode 100644 index 00000000..79067222 --- /dev/null +++ b/arb/nitro/arbitrum-one-nitro-archive-erigon.yml @@ -0,0 +1,181 @@ +--- +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:arb/nitro/arbitrum-one-nitro-archive-erigon.yml +# +# docker compose up -d +# +# curl -X POST https://${IP}.traefik.me/arbitrum-one-nitro-archive-erigon \ +# -H "Content-Type: application/json" \ +# --data '{"jsonrpc":"2.0","method":"eth_blockNumber","params":[],"id":1}' + +services: + arbitrum-one-archive-erigon: + image: ${ARBITRUM_NITRO_IMAGE:-erigontech/nitro-erigon}:${ARBITRUM_ONE_NITRO_VERSION:-main-de68b93} + 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) + memlock: -1 # Disable memory locking limits (for in-memory DBs like MDBX) + user: root + ports: + - 21789:21789 + - 21789:21789/udp + - 27891:27891 + - 27891:27891/udp + - 38917:38917 + - 38917:38917/udp + - 43123:43123 + - 43123:43123/udp + - 49231:49231 + - 49231:49231/udp + expose: + - 8545 + - 5555 + entrypoint: [erigon] + command: + - --datadir=/root/.local/share/erigon + - --http + - --http.addr=0.0.0.0 + - --http.api=eth,erigon,web3,net,debug,trace,txpool,admin,ots + - --http.port=8545 + - --http.vhosts=* + - --maxpeers=50 + - --metrics + - --metrics.addr=0.0.0.0 + - --metrics.port=6060 + - --nat=extip:${IP} + - --p2p.allowed-ports=43123 + - --p2p.allowed-ports=49231 + - --port=21789 + - --prune.mode=archive + - --l2rpc="http://arbitrum-one-archive:8545" + - --torrent.download.rate=${ARBITRUM_ONE_NITRO_ARCHIVE_ERIGON_MAX_DOWNLOAD_RATE:-1000mb} + - --torrent.port=38917 + - --ws + - --ws.port=8545 + restart: unless-stopped + stop_grace_period: 5m + networks: + - chains + volumes: + - ${ARBITRUM_ONE_NITRO_ARCHIVE_ERIGON_DATA:-arbitrum-one-nitro-archive-erigon}:/root/.local/share/erigon + - /slowdisk:/slowdisk + logging: *logging-defaults + labels: + - prometheus-scrape.enabled=true + - prometheus-scrape.port=6060 + - prometheus-scrape.path=/debug/metrics/prometheus + - traefik.enable=true + - traefik.http.middlewares.arbitrum-one-nitro-archive-erigon-stripprefix.stripprefix.prefixes=/arbitrum-one-nitro-archive-erigon + - traefik.http.services.arbitrum-one-nitro-archive-erigon.loadbalancer.server.port=8545 + - ${NO_SSL:-traefik.http.routers.arbitrum-one-nitro-archive-erigon.entrypoints=websecure} + - ${NO_SSL:-traefik.http.routers.arbitrum-one-nitro-archive-erigon.tls.certresolver=myresolver} + - ${NO_SSL:-traefik.http.routers.arbitrum-one-nitro-archive-erigon.rule=Host(`$DOMAIN`) && (Path(`/arbitrum-one-nitro-archive-erigon`) || Path(`/arbitrum-one-nitro-archive-erigon/`))} + - ${NO_SSL:+traefik.http.routers.arbitrum-one-nitro-archive-erigon.rule=Path(`/arbitrum-one-nitro-archive-erigon`) || Path(`/arbitrum-one-nitro-archive-erigon/`)} + - traefik.http.routers.arbitrum-one-nitro-archive-erigon.middlewares=arbitrum-one-nitro-archive-erigon-stripprefix, ipallowlist + - traefik.http.routers.arbitrum-one-nitro-archive-erigon.service=arbitrum-one-nitro-archive-erigon + - traefik.http.routers.arbitrum-one-nitro-archive-erigon-node.service=arbitrum-one-nitro-archive-erigon-node + - traefik.http.services.arbitrum-one-nitro-archive-erigon-node.loadbalancer.server.port=5555 + - ${NO_SSL:-traefik.http.routers.arbitrum-one-nitro-archive-erigon-node.entrypoints=websecure} + - ${NO_SSL:-traefik.http.routers.arbitrum-one-nitro-archive-erigon-node.tls.certresolver=myresolver} + - ${NO_SSL:-traefik.http.routers.arbitrum-one-nitro-archive-erigon-node.rule=Host(`$DOMAIN`) && PathPrefix(`/arbitrum-one-nitro-archive-erigon/eth`)} + - ${NO_SSL:+traefik.http.routers.arbitrum-one-nitro-archive-erigon-node.rule=PathPrefix(`/arbitrum-one-nitro-archive-erigon/eth`)} + - traefik.http.routers.arbitrum-one-nitro-archive-erigon-node.middlewares=arbitrum-one-nitro-archive-erigon-stripprefix, ipallowlist + shm_size: 2gb + +volumes: + arbitrum-one-nitro-archive-erigon: + +x-upstreams: + - id: $${ID} + labels: + provider: $${PROVIDER} + connection: + generic: + rpc: + url: $${RPC_URL} + ws: + frameSize: 20Mb + msgSize: 50Mb + url: $${WS_URL} + chain: arbitrum-one + method-groups: + enabled: + - debug + - filter + - trace + methods: + disabled: + enabled: + - name: txpool_content # TODO: should be disabled for rollup nodes + # standard geth and erigon + - name: debug_accountRange + - name: debug_getModifiedAccountsByNumber + - name: debug_getModifiedAccountsByHash + # non standard geth and erigon + - name: eth_getRawTransactionByHash + - name: eth_getRawTransactionByBlockHashAndIndex + # non standard erigon only + - name: eth_getBlockReceipts + - name: eth_protocolVersion + - name: eth_callMany + - name: eth_callBundle + - name: debug_accountAt + - name: debug_traceCallMany + - name: erigon_getHeaderByHash + - name: erigon_getBlockReceiptsByBlockHash + - name: erigon_getHeaderByNumber + - name: erigon_getLogsByHash + - name: erigon_forks + - name: erigon_getBlockByTimestamp + - name: erigon_BlockNumber + - name: erigon_getLatestLogs + - name: ots_getInternalOperations + - name: ots_hasCode + - name: ots_getTransactionError + - name: ots_traceTransaction + - name: ots_getBlockDetails + - name: ots_getBlockDetailsByHash + - name: ots_getBlockTransactions + - name: ots_searchTransactionsBefore + - name: ots_searchTransactionsAfter + - name: ots_getTransactionBySenderAndNonce + - name: ots_getContractCreator + - id: $${ID}-beacon-chain + chain: eth-beacon-chain + labels: + provider: $${PROVIDER}-beacon-chain + connection: + generic: + rpc: + url: $${RPC_URL} +... \ No newline at end of file