Bro简介与安装

Bro是一款强大的网络安全工具,以及协议识别与统计的工具。

Bro is a powerful network analysis framework that is much different from the typical IDS you may know.

  • Adaptable

    Bro's domain-specific scripting language enables site-specific monitoring policies.

  • Efficient

    Bro targets high-performance networks and is used operationally at a variety of large sites.

  • Flexible

    Bro is not restricted to any particular detection approach and does not rely on traditional signatures.

  • Forensics

    Bro comprehensively logs what it sees and provides a high-level archive of a network's activity.

  • In-depth Analysis

    Bro comes with analyzers for many protocols, enabling high-level semantic analysis at the application layer.

  • Highly Stateful

    Bro keeps extensive application-layer state about the network it monitors.

  • Open Interfaces

    Bro interfaces with other applications for real-time exchange of information.

  • Open Source

    Bro comes with a BSD license, allowing for free use with virtually no restrictions.

While focusing on network security monitoring, Bro provides a comprehensive platform for more general network traffic analysis as well. Well grounded in more than 15 years of research, Bro has successfully bridged the traditional gap between academia and operations since its inception. Today, it is relied upon operationally in particular by many scientific environments for securing their cyberinfrastructure. Bro's user community includes major universities, research labs, supercomputing centers, and open-science communities.

Bro has originally been developed by Vern Paxson, who continues to lead the project now jointly with a core team of researchers and developers at the International Computer Science Institute in Berkeley, CA; and theNational Center for Supercomputing Applications in Urbana-Champaign, IL.




























1.安装Bro-2.1

http://www.bro-ids.org/documentation/quickstart.html 
以Ubuntu为例:
./configure时显示说需要先装cmake---sudo apt-get install cmake
can not find LibMagic---sudo apt-get install libmagic-dev
can not find ZLIB--sudo apt-get install libz-dev
can not find BISON--sudo apt-get install bison
can not find FLEX--sudo apt-get install flex
can not find OpenSSL--sudo apt-get install libssl-dev
can not find SWIG--sudo apt-get install swig
can not find PathonDev--sudo apt-get install python-dev

2.安装DataSeries, DataSeries: an efficient binary format for recording structured bulk data. DataSeries is developed and maintained at  HP  Labs. See doc/logging-dataseries for more information.

安装DataSeries需要先安装Lintel
--useful links
git clone http://github.com/dataseries/Lintel
 git clone http://github.com/dataseries/DataSeries (假如没有git sudo apt-get一下)
装Lintel和DataSeries时要按照/usr/local/bro-2.1/doc/logging-dataseries.rst的说明进行。在装的时候可能会却一些库,使用下面的命令去查看,然后apt-get install 一下
sudo aptitude search libboost

Fedora的输出:
=============================
Binary Output with DataSeries
=============================
-- The C compiler identification is GNU
-- The CXX compiler identification is GNU
-- Check for working C compiler: /usr/lib/ccache/gcc
-- Check for working C compiler: /usr/lib/ccache/gcc -- works
-- Detecting C compiler ABI info
-- Detecting C compiler ABI info - done
-- Check for working CXX compiler: /usr/lib/ccache/c++
-- Check for working CXX compiler: /usr/lib/ccache/c++ -- works
-- Detecting CXX compiler ABI info
-- Detecting CXX compiler ABI info - done
WARNING: you did not set a CMAKE_BUILD_TYPE; assuming RelWithDebInfo
-- Boost version: 1.44.0
-- Found program lintel-config as /usr/local/bro/bin/lintel-config
-- Found header boost/program_options.hpp in /usr/include
-- Found library  as /usr/lib/libboost_program_options.so
-- Found header Lintel/AssertBoost.hpp in /usr/local/bro/include
-- Found library  as /usr/local/bro/lib/libLintel.so
-- Found header Lintel/PThread.hpp in /usr/local/bro/include
-- Found library  as /usr/local/bro/lib/libLintelPThread.so
-- Looking for include files CMAKE_HAVE_PTHREAD_H
-- Looking for include files CMAKE_HAVE_PTHREAD_H - found
-- Looking for pthread_create in pthreads
-- Looking for pthread_create in pthreads - not found
-- Looking for pthread_create in pthread
-- Looking for pthread_create in pthread - found
-- Found Threads: TRUE 
-- Found header boost/thread/tss.hpp in /usr/include
-- Found library  as /usr/lib/libboost_thread-mt.so
-- Found LibXml2: /usr/lib/libxml2.so 
-- Found ZLIB: /usr/include (found version "1.2.5")
-- Could NOT find BZip2 (missing:  BZIP2_LIBRARIES BZIP2_INCLUDE_DIR) 
WITH_BZIP2 on, but could not find bzip2 includes/libraries.
  bzip2 compression support and nettrace2ds will be skipped.
-- Found program bunzip2 as /usr/bin/bunzip2
WITH_SRT on, but could not find header file SRT/SRTTrace.H or library SRTlite
  will skip building srt2ds, cmpsrtds
WITH_LZO on, but could not find header file lzo1x.h or library lzo
  lzo compression support will be skipped.
-- Found header openssl/sha.h in /usr/include
-- Found library  as /usr/lib/libcrypto.so
WITH_PCRE on, but could not find header file pcre.h or library pcre
  will skip building bacct2ds
-- Found header pcap.h in /usr/local/include
-- Found header linux/if_packet.h in /usr/include
-- Found header boost/foreach.hpp in /usr/include
WITH_AVRO on, but could not find header file avro.h or library avro
WITH_GNUPLOT on, but could NOT find program gnuplot
-- Found Perl: /usr/bin/perl 
-- Found perl module XML::Parser
Could NOT find perl module Date::Parse in default perl paths
  or /usr/local/bro/share/perl5
Could NOT find perl module Crypt::Rijndael in default perl paths
  or /usr/local/bro/share/perl5
Could NOT find perl module Filesys::Statvfs in default perl paths
  or /usr/local/bro/share/perl5
-- Found Doxygen: /usr/bin/doxygen 
-- Found program pod2man as /usr/bin/pod2man
-- Found program cmake as /usr/bin/cmake
-- checking for module 'thrift'
--   package 'thrift' not found
WITH_THRIFT on, but could NOT find program thrift
Missing either thrift or parallel/losertree.h, will skip data-series-server
WITH_LINTEL_LATEX_REBUILD on, but could NOT find program lintel-latex-rebuild
WITH_LINTEL_LATEX_REBUILD enabled, but lintel-latex-rebuild not found
  latex-documentation will remain un-built
lsfdsplots will NOT be built PERL_CRYPT_RIJNDAEL_ENABLED=OFF, PERL_DATE_PARSE_ENABLED=OFF, GNUPLOT_ENABLED=OFF

************************************
  Some optional dependency was not found.
  /usr/local/bro-2.1/DataSeries/doc/dependencies.txt
  may help identify the right packages
************************************

-- Configuring done
-- Generating done
-- Build files have been written to: /usr/local/bro-2.1/DataSeries/build
***************************************************************************
-
Ubuntu 14的输出:
-----------------------
-- The C compiler identification is GNU
-- The CXX compiler identification is GNU
-- Check for working C compiler: /usr/bin/gcc
-- Check for working C compiler: /usr/bin/gcc -- works
-- Detecting C compiler ABI info
-- Detecting C compiler ABI info - done
-- Check for working CXX compiler: /usr/bin/c++
-- Check for working CXX compiler: /usr/bin/c++ -- works
-- Detecting CXX compiler ABI info
-- Detecting CXX compiler ABI info - done
WARNING: you did not set a CMAKE_BUILD_TYPE; assuming RelWithDebInfo
-- Boost version: 1.46.1
-- Found program lintel-config as /usr/local/bro/bin/lintel-config
-- Found header boost/program_options.hpp in /usr/include
-- Found library  as /usr/lib/libboost_program_options.so
-- Found header Lintel/AssertBoost.hpp in /usr/local/bro/include
-- Found library  as /usr/local/bro/lib/libLintel.so
-- Found header Lintel/PThread.hpp in /usr/local/bro/include
-- Found library  as /usr/local/bro/lib/libLintelPThread.so
-- Looking for include files CMAKE_HAVE_PTHREAD_H
-- Looking for include files CMAKE_HAVE_PTHREAD_H - found
-- Looking for pthread_create in pthreads
-- Looking for pthread_create in pthreads - not found
-- Looking for pthread_create in pthread
-- Looking for pthread_create in pthread - found
-- Found Threads: TRUE 
-- Found header boost/thread/tss.hpp in /usr/include
-- Found library  as /usr/lib/libboost_thread.so
-- Found LibXml2: /usr/lib/x86_64-linux-gnu/libxml2.so 
-- Found ZLIB: /usr/lib/x86_64-linux-gnu/libz.so (found version "1.2.3.4")
-- Could NOT find BZip2 (missing:  BZIP2_LIBRARIES BZIP2_INCLUDE_DIR) 
WITH_BZIP2 on, but could not find bzip2 includes/libraries.
  bzip2 compression support and nettrace2ds will be skipped.
-- Found program bunzip2 as /bin/bunzip2
WITH_SRT on, but could not find header file SRT/SRTTrace.H or library SRTlite
  will skip building srt2ds, cmpsrtds
WITH_LZO on, but could not find header file lzo1x.h or library lzo
  lzo compression support will be skipped.
-- Found header openssl/sha.h in /usr/include
-- Found library  as /usr/lib/x86_64-linux-gnu/libcrypto.so
-- Found header pcre.h in /usr/include
-- Found library  as /usr/lib/x86_64-linux-gnu/libpcre.so
-- Found header pcap.h in /usr/include
-- Found header linux/if_packet.h in /usr/include
-- Found header boost/foreach.hpp in /usr/include
WITH_AVRO on, but could not find header file avro.h or library avro
-- Found program gnuplot as /usr/bin/gnuplot
-- Found Perl: /usr/bin/perl 
-- Found perl module XML::Parser
-- Found perl module Date::Parse
-- Found perl module Crypt::Rijndael
-- Found perl module Filesys::Statvfs
-- Found Doxygen: /usr/bin/doxygen 
-- Found program pod2man as /usr/bin/pod2man
-- Found program cmake as /usr/bin/cmake
WITH_THRIFT on, but could NOT find program thrift
Missing either thrift or parallel/losertree.h, will skip data-series-server
-- Found program lintel-latex-rebuild as /usr/local/bro/bin/lintel-latex-rebuild
Unable to find latex file ptmb8t.tfm for DataSeries OSR 2008 paper
Unable to find latex file ptmb8t.vf for DataSeries OSR 2008 paper

************************************
  Some optional dependency was not found.
  /usr/local/bro-2.1/DataSeries/doc/dependencies.txt
  may help identify the right packages
************************************

-- Configuring done
-- Generating done
-- Build files have been written to: /usr/local/bro-2.1/DataSeries/build


附录:
/usr/local/bro-2.1/doc/logging-dataseries.rst


.. rst-class:: opening

   Bro's default ASCII log format is not exactly the most efficient
   way for storing and searching large volumes of data. An an
   alternative, Bro comes with experimental support for `DataSeries
   <http://www.hpl.hp.com/techreports/2009/HPL-2009-323.html>`_
   output, an efficient binary format for recording structured bulk
   data. DataSeries is developed and maintained at HP Labs.

.. contents::

Installing DataSeries
---------------------

To use DataSeries, its libraries must be available at compile-time,
along with the supporting *Lintel* package. Generally, both are
distributed on `HP Labs' web site
<http://tesla.hpl.hp.com/opensource/>`_. Currently, however, you need
to use recent development versions for both packages, which you can
download from github like this::

    git clone http://github.com/dataseries/Lintel
    git clone http://github.com/dataseries/DataSeries

To build and install the two into ``<prefix>``, do::

    ( cd Lintel     && mkdir build && cd build && cmake -DCMAKE_INSTALL_PREFIX=<prefix> .. && make && make install )
    ( cd DataSeries && mkdir build && cd build && cmake -DCMAKE_INSTALL_PREFIX=<prefix> .. && make && make install )

Please refer to the packages' documentation for more information about
the installation process. In particular, there's more information on
required and optional `dependencies for Lintel
<https://raw.github.com/dataseries/Lintel/master/doc/dependencies.txt>`_
and `dependencies for DataSeries
<https://raw.github.com/dataseries/DataSeries/master/doc/dependencies.txt>`_.
For users on RedHat-style systems, you'll need the following::

    yum install libxml2-devel boost-devel

Compiling Bro with DataSeries Support
-------------------------------------

Once you have installed DataSeries, Bro's ``configure`` should pick it
up automatically as long as it finds it in a standard system location.
Alternatively, you can specify the DataSeries installation prefix
manually with ``--with-dataseries=<prefix>``. Keep an eye on
``configure``'s summary output, if it looks like the following, Bro
found DataSeries and will compile in the support::

    # ./configure --with-dataseries=/usr/local
    [...]
    ====================|  Bro Build Summary  |=====================
    [...]
    DataSeries:        true
    [...]
    ================================================================

Activating DataSeries
---------------------

The direct way to use DataSeries is to switch *all* log files over to
the binary format. To do that, just add ``redef
Log::default_writer=Log::WRITER_DATASERIES;`` to your ``local.bro``.
For testing, you can also just pass that on the command line::

    bro -r trace.pcap Log::default_writer=Log::WRITER_DATASERIES

With that, Bro will now write all its output into DataSeries files
``*.ds``. You can inspect these using DataSeries's set of command line
tools, which its installation process installs into ``<prefix>/bin``.
For example, to convert a file back into an ASCII representation::

    $ ds2txt conn.log
    [... We skip a bunch of metadata here ...]
    ts uid id.orig_h id.orig_p id.resp_h id.resp_p proto service duration orig_bytes resp_bytes conn_state local_orig missed_bytes history orig_pkts orig_ip_bytes resp_pkts resp_ip_bytes
    1300475167.096535 CRCC5OdDlXe 141.142.220.202 5353 224.0.0.251 5353 udp dns 0.000000 0 0 S0 F 0 D 1 73 0 0
    1300475167.097012 o7XBsfvo3U1 fe80::217:f2ff:fed7:cf65 5353 ff02::fb 5353 udp  0.000000 0 0 S0 F 0 D 1 199 0 0
    1300475167.099816 pXPi1kPMgxb 141.142.220.50 5353 224.0.0.251 5353 udp  0.000000 0 0 S0 F 0 D 1 179 0 0
    1300475168.853899 R7sOc16woCj 141.142.220.118 43927 141.142.2.2 53 udp dns 0.000435 38 89 SF F 0 Dd 1 66 1 117
    1300475168.854378 Z6dfHVmt0X7 141.142.220.118 37676 141.142.2.2 53 udp dns 0.000420 52 99 SF F 0 Dd 1 80 1 127
    1300475168.854837 k6T92WxgNAh 141.142.220.118 40526 141.142.2.2 53 udp dns 0.000392 38 183 SF F 0 Dd 1 66 1 211
    [...]

(``--skip-all`` suppresses the metadata.)

Note that the ASCII conversion is *not* equivalent to Bro's default
output format.

You can also switch only individual files over to DataSeries by adding
code like this to your ``local.bro``:

.. code:: bro

    event bro_init()
        {
        local f = Log::get_filter(Conn::LOG, "default"); # Get default filter for connection log.
        f$writer = Log::WRITER_DATASERIES;               # Change writer type.
        Log::add_filter(Conn::LOG, f);                   # Replace filter with adapted version.
        }

Bro's DataSeries writer comes with a few tuning options, see
:doc:`scripts/base/frameworks/logging/writers/dataseries`.

Working with DataSeries
=======================

Here are a few examples of using DataSeries command line tools to work
with the output files.

* Printing CSV::

    $ ds2txt --csv conn.log
    ts,uid,id.orig_h,id.orig_p,id.resp_h,id.resp_p,proto,service,duration,orig_bytes,resp_bytes,conn_state,local_orig,missed_bytes,history,orig_pkts,orig_ip_bytes,resp_pkts,resp_ip_bytes
    1258790493.773208,ZTtgbHvf4s3,192.168.1.104,137,192.168.1.255,137,udp,dns,3.748891,350,0,S0,F,0,D,7,546,0,0
    1258790451.402091,pOY6Rw7lhUd,192.168.1.106,138,192.168.1.255,138,udp,,0.000000,0,0,S0,F,0,D,1,229,0,0
    1258790493.787448,pn5IiEslca9,192.168.1.104,138,192.168.1.255,138,udp,,2.243339,348,0,S0,F,0,D,2,404,0,0
    1258790615.268111,D9slyIu3hFj,192.168.1.106,137,192.168.1.255,137,udp,dns,3.764626,350,0,S0,F,0,D,7,546,0,0
    [...]

  Add ``--separator=X`` to set a different separator.

* Extracting a subset of columns::

    $ ds2txt --select '*' ts,id.resp_h,id.resp_p --skip-all conn.log
    1258790493.773208 192.168.1.255 137
    1258790451.402091 192.168.1.255 138
    1258790493.787448 192.168.1.255 138
    1258790615.268111 192.168.1.255 137
    1258790615.289842 192.168.1.255 138
    [...]

* Filtering rows::

    $ ds2txt --where '*' 'duration > 5 && id.resp_p > 1024' --skip-all  conn.ds
    1258790631.532888 V8mV5WLITu5 192.168.1.105 55890 239.255.255.250 1900 udp  15.004568 798 0 S0 F 0 D 6 966 0 0
    1258792413.439596 tMcWVWQptvd 192.168.1.105 55890 239.255.255.250 1900 udp  15.004581 798 0 S0 F 0 D 6 966 0 0
    1258794195.346127 cQwQMRdBrKa 192.168.1.105 55890 239.255.255.250 1900 udp  15.005071 798 0 S0 F 0 D 6 966 0 0
    1258795977.253200 i8TEjhWd2W8 192.168.1.105 55890 239.255.255.250 1900 udp  15.004824 798 0 S0 F 0 D 6 966 0 0
    1258797759.160217 MsLsBA8Ia49 192.168.1.105 55890 239.255.255.250 1900 udp  15.005078 798 0 S0 F 0 D 6 966 0 0
    1258799541.068452 TsOxRWJRGwf 192.168.1.105 55890 239.255.255.250 1900 udp  15.004082 798 0 S0 F 0 D 6 966 0 0
    [...]

* Calculate some statistics:

    Mean/stddev/min/max over a column::

        $ dsstatgroupby '*' basic duration from conn.ds
        # Begin DSStatGroupByModule
        # processed 2159 rows, where clause eliminated 0 rows
        # count(*), mean(duration), stddev, min, max
        2159, 42.7938, 1858.34, 0, 86370
        [...]

    Quantiles of total connection volume::

        $ dsstatgroupby '*' quantile 'orig_bytes + resp_bytes' from conn.ds
        [...]
        2159 data points, mean 24616 +- 343295 [0,1.26615e+07]
        quantiles about every 216 data points:
        10%: 0, 124, 317, 348, 350, 350, 601, 798, 1469
        tails: 90%: 1469, 95%: 7302, 99%: 242629, 99.5%: 1226262
        [...]

The ``man`` pages for these tools show further options, and their
``-h`` option gives some more information (either can be a bit cryptic
unfortunately though).

Deficiencies
------------

Due to limitations of the DataSeries format, one cannot inspect its
files before they have been fully written. In other words, when using
DataSeries, it's currently not possible to inspect the live log
files inside the spool directory before they are rotated to their
final location. It seems that this could be fixed with some effort,
and we will work with DataSeries development team on that if the
format gains traction among Bro users.

Likewise, we're considering writing custom command line tools for
interacting with DataSeries files, making that a bit more convenient
than what the standard utilities provide.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值