Giter VIP home page Giter VIP logo

ik-networking / batfish Goto Github PK

View Code? Open in Web Editor NEW

This project forked from batfish/batfish

0.0 2.0 0.0 173.16 MB

Batfish is a network configuration analysis tool that can find bugs and guarantee the correctness of (planned or current) network configurations. It enables network engineers to rapidly and safely evolve their network, without fear of outages or security breaches.

Home Page: http://www.batfish.org

License: Apache License 2.0

Shell 0.30% Python 0.78% Java 93.77% ANTLR 5.15%

batfish's Introduction

Got questions, feedback, or feature requests? Join our community on Slack!

codecov

What is Batfish?

Batfish is a network configuration analysis tool that can find bugs and guarantee the correctness of (planned or current) network configurations. It enables network engineers to rapidly and safely evolve their network, without fear of outages or security breaches. See www.batfish.org for technical information on how it works.

Batfish does not require access to network devices. It can work with configuration files pulled by tools like RANCID or those generated via templates. Analytics

How do I get started?

The quickest way to get started is using pre-built Docker containers. Or, you can build from sources.

Batfish is also available as a supported service by Intentionet. Drop a line to [email protected] for more information.

What kinds of correctness checks does Batfish support?

Batfish supports many types of correctness checks, including

  1. Compliance and best-practices guidelines, e.g.:
  • Flag undefined-but-referenced or defined-but-unreferenced structures (e.g., ACLs, route maps)
  • Configuration settings for MTUs, AAA, NTP, logging, etc. are correct
  • Devices can only be accessed using SSHv2 and password is not null
  1. Consistency of configuration across two or more devices, e.g.:
  • BGP sessions and IPSec tunnels are compatibly configured across neighbors
  • All interface IP addresses are unique
  • Identically-named structures (e.g., ACLs, route maps) across devices have identical functionality
  1. Checks on data flow, e.g.:
  • Sensitive services can be reached only from specific subnets or devices
  • Certain services (e.g., DNS) are globally reachable and not blocked by any ACL in the network
  • Paths between endpoints are as expected (e.g., traverse a firewall)
  1. Fault-tolerance, e.g.:
  • End-to-end reachability is not impacted for any flow after any single-link or -device failure
  • Traffic correctly fails over after a failure
  1. "Differential" analysis of two sets of configuration, e.g.:
  • End-to-end reachability is identical across new and old configurations
  • Planned ACL or firewall changes are provably correct, including not causing collateral damage for other traffic
  • Two configurations, potentially from different vendors, are functionally equivalent

What configuration formats does Batfish support?

Batfish supports configurations for a large and growing set of (physical and virtual) devices, including:

  • Arista
  • Aruba
  • AWS VPCs
  • Cisco (All Cisco NX-OS, IOS, IOS-XR, IOS-XR devices including Cisco ASA)
  • Dell Force10
  • Foundry
  • iptables (on hosts)
  • Juniper (All JunOS plaforms: MX, EX, QFX, SRX)
  • MRV
  • Palo Alto Networks
  • Quagga
  • Quanta
  • VyOS

If you'd like support for additional vendors or currently-unsupported configuration features, let us know via Slackor GitHub. We'll try to add support. Or, you can -- we welcome pull requests! :)

batfish's People

Contributors

arifogel avatar dhalperi avatar ratulm avatar anothermattbrown avatar progwriter avatar millstein avatar haverma avatar kidsbear avatar sfraint avatar corinaminer avatar erikljungman avatar virtuald avatar rabeckett avatar yifeiyuan avatar vasu018 avatar mkremerbbn avatar nunoplopes avatar saparikh avatar dspicuzzbbn avatar jkhourybbn avatar buehlert avatar nickgian avatar agember avatar alb-17la avatar jitupadhye avatar rucarrol avatar gitter-badger avatar plannigan avatar xyzsa avatar

Watchers

James Cloos avatar Ivan Ka avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.