Skip to content
/ rbh Public

rbh is a tool for helping deal with errant/unstable XRPL peers

License

Notifications You must be signed in to change notification settings

gnanderson/rbh

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

49 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

CircleCI Go Report Card

rbh - rippled ban hammer

Follow me on Twitter - @diakritikal

  1. Credit
  2. Status
  3. Requirements
  4. Installation
  5. Usage
  6. Configuration
  7. Rational

Credit

This tool is inspired by Rabbit's rippled ban hammer python script: https://github.com/crypticrabbit/rippled-ban-hammer

Many thanks to Rabbit, Alloy Networks and Nik Bougalis in providing valuable advice for operating XRPL nodes. Follow them on Twitter!

Status

WARNING

This tool should be tested against your test/alt net nodes before you consider deploying

TODO:

  • [✔] race check data structures accessed concurrently
  • [✔] whitelist support
  • [✔] config via file and env vars
  • [✔] add to CI
  • [✘] provide container/docker release - DBUS support patchy inside a container
  • [✔] release management
  • [✔] socket closing mechanism for banned peers
  • [✔] correctly support ipv6
  • [✔] connection retry on websocket connection close

Requirements

Ban Functionality

The ban functionality is built on firewalld. It is unlikely systems without firewalld will be supported. This is purely because as far as I'm aware the alternatives e.g. Ubuntu ufw don't have any convenient communication layer (D-BUS) exposed to program against. You can of course configure your Debian/Ubuntu system to use firewalld. There are official packages available.

Off the top of my head I think this should work on the following Linux flavours.

  • SLES 15+
  • RHEL 7+
  • CentOS 7+
  • OpenSUSE Leap
  • Fedora Core 21+ - I hope you have upgraded ;)
  • Arch

Socket Closing Functionality

An initial implementation of closing sockets via system utilities has been added. The default Disconnector uses iproute2 utility ss. Please see the code comments about this.

If your kernel doesn't support it, you can try the tcpkill option by passing the -k flag.

Testing has been only cursory on this functionality... Ping me if you see any problems.

Installation

There are some binaries for Linux, these should be considered alpha status

Alternatively you can install with go get github.com/gnanderson/rbh.

Usage

  • rbh help
  • rbh help run
  • rbh help ban
  • rbh help show

Configuration

Outside of flag usage you have the following configuration strategies available. Keys for both config strategies correspond to the flags you can discover from the help commands above.

  • yaml config, example
  • env vars, env var keys are prefixed with RBH_ e.g. RBH_ADDR

Rational

Rabbit's ban hammer script has been very helpful in helping stabilise my XRPL nodes. However, it performs direct modification of the servers iptables chains and since my servers utilise firewalld I didn't want to have conflicts or even have iptables lose the drop/reject entries. This might happen for example on a firewalld reload or modification of the zones.

A lesser concern was the Kernel developers plans to move away from iptables towards using bpfilter. That's probably some way off but firewalld would continue to act as the frontend when this happens so there's an amount of future proofing by leveraging firewalld

firewalld exposes it's functionality on the Kernel's D-BUS IPC layer, this is perfect for programatically integrating with Kernel netfiltering.

So I endeavoured to investigate this approach and base this tool around direct firewalld integration through D-BUS.

About

rbh is a tool for helping deal with errant/unstable XRPL peers

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages