A Study on the Cacti-Based Network Traffic Monitoring System Using Libpcap

Total Page:16

File Type:pdf, Size:1020Kb

A Study on the Cacti-Based Network Traffic Monitoring System Using Libpcap M.E Thesis A Study on the Cacti-based Network Traffic Monitoring System Using Libpcap December, 2011 Graduate School of the PaiChai University Department of Computer Engineering Major of Multimedia Information Engineering Xiao Huang A Study on the Cacti-based Network Traffic Monitoring System Using Libpcap Principal Advisor Hoe-Kyung Jung December, 2011 Graduate School of PaiChai University Department of Computer Engineering Major of Multimedia Information Engineering Xiao Huang The undersigned have examined the dissertation entitled: “A Study on the Cacti-based Network Traffic Monitoring System Using Libpcap” presented by “Xiao Huang” , a candidate for the degree of Master of Computer Engineering and hereby certify that in their judgment it is worthy of acceptance. December, 2011 In-June Jo, PH.D Professor Department of Computer Engineering Graduate School of PaiChai University December, 2011 Dong-Kun Noh, PH.D Professor Department of Computer Engineering Graduate School of PaiChai University December, 2011 Hoe-Kyung Jung, PH.D Professor Department of Computer Engineering Graduate School of PaiChai University A Study on the Cacti-based Network Traffic Monitoring System Using Libpcap Xiao Huang Department of Computer Engineering Graduate from PaiChai University Daejeon, Korea (Supervised by Professor Hoe-Kyung Jung) ABSTRACT Networks are growing rapidly in size and make the networks more complex than before. In LAN(Local Area Network), network congestion, slow-speed and the servers is often attacked and even be paralyzed. In order to keeping our networks quick, reliable, secure and efficient, we need a network traffic monitoring. Recently, a smart phone can be bound with an email address. We can receive email at hand immediately. Cacti is an open source and freeware monitoring tool and has lots of alarming email plugins. Libpcap is also an open source library that provides a low level interface to network packet capture systems. Making a Sniffer by Libpcap to capture packets from NIC(Network Interface Card) and I analyze those packets and to store in DB. Cacti get those data by Perl scripts and use these data to graph and sent emails in special case. In this thesis, we unite them together and design a system to monitor our network traffic in real time. Executing these programming, our system can get a few choppy continuous graphs and log files and even receive alarming emails by mobile phone. These results indicate that it is possible to unit Cacti and Libpcap together to monitor our network traffic and this system can achieve our desired goal and it is effective, quick, accurate and real-time. II Contents Abstract...................................................................................................I Contents.................................................................................................III Figures Listed........................................................................................V Table Listed...........................................................................................VI I. Introduction .......................................................................................... 1 II. Related Work ...................................................................................... 4 2.1 RRDTool ........................................................................................ 4 2.1.1 the Concept of RRDTool ........................................................ 4 2.1.2 the Features of RRDTool ....................................................... 4 2.2 Cacti .............................................................................................5 2.2.1 the Concept of Cacti .............................................................. 5 2.2.2 the Features of Cacti ............................................................. 6 2.2.3 Work Principle ........................................................................ 6 2.2.4 How to Use Cacti ................................................................... 7 2.2.5 Add PIA (Plugin Architecture) ............................................... 9 2.2.6 Installing Setting Plugin and Thold Plugin .......................... 10 2.3 Libpcap ........................................................................................ 12 2.3.1 the Concept of Libpcap ........................................................ 12 2.4 Sniffer .........................................................................................13 2.4.1 the Concept of Sniffer ......................................................... 13 2.4.2 Work Principle ...................................................................... 13 2.4.3 How to Make a Sniffer ......................................................... 15 2.4.4 Things should be taken into account .................................. 18 2.4.4.1 Data Link Type .................................................... 18 III 2.4.4.2 Network Layer Protocol ...................................... 20 2.4.4.3 Transport Layer Protocol ................................... 20 2.4.4.4 Application Layer Protocol ................................. 21 2.4.4.5 Filtering Packets .................................................. 21 2.4.4.6 Setting a Filter ..................................................... 22 III. Design System ................................................................................. 26 3.1 Development Environment ......................................................... 26 3.2 System Structure ........................................................................ 27 3.2.1 Capture Packets Block ........................................................ 27 3.2.1.1 Design Ethernet Networks Structure ................. 28 3.2.1.2 Design a Callback Function ................................. 30 3.2.1.3 Start a Sniffer Application ................................... 32 3.2.2 Counter Block....................................................................... 32 3.2.3 Inquiry Block ........................................................................ 34 3.2.4 Connect with Cacti Block .................................................... 35 3.2.4.1 Design a Program to Update a DB table ............ 35 3.2.4.2 Design a Perl Programming ................................ 36 3.2.4.3 Create a graph from a Perl Script ...................... 37 3.2.5 Set Alarm Block ................................................................... 38 3.2.5.1 Set Threshold Plugins ......................................... 38 3.2.5.2 Creating a Threshold Templates ........................ 40 3.3 Results ......................................................................................... 42 IV. Result and Analysis ......................................................................... 45 4.1 Make a Test ................................................................................ 45 4.1.1 Test by TCP ......................................................................... 45 4.1.2 TEST by ICMP ..................................................................... 48 IV 4.2 Analysis ....................................................................................... 52 V. Conclusions and Future Works ........................................................ 53 5.1 Conclusions ................................................................................. 53 5.2 Future Works .............................................................................. 54 References ...........................................................................................55 Acknowledgement ................................................................................57 V Figures Listed Figure 1. Cacti Work Principle ........................................................ 7 Figure 2. Cacti Login Window ......................................................... 8 Figure 3. Thold Plugin ................................................................... 11 Figure 4. Setting Plugin ................................................................. 12 Figure 5. Elements Involved in the Capture Process .................. 15 Figure 6. System Design Flow-Process Diagram ........................ 26 Figure 7. Structure of System ....................................................... 27 Figure 8. Data Encapsulation in Ethernet Network ..................... 28 Figure 9. Callback Function ........................................................... 30 Figure 10. Start Grabbing Packets ................................................ 32 Figure 11. Information Recorded in File ....................................... 33 Figure 12. the Structure of Table ................................................. 36 Figure 13. Perl Connect to DB ...................................................... 37 Figure 14. Create Graph for ARP .................................................. 38 Figure 15. Default Alerting Options .............................................. 39 Figure 16. Emailing Options .......................................................... 39 Figure 17. Cacti Setting(Mail/DNS) .............................................. 39 Figure 18. SMTP Options .............................................................. 39 Figure 19. Test Message ............................................................... 40 Figure 20. Receive a Email by a Phone ........................................ 40 Figure 21. Setting Threshold Template ....................................... 41 Figure 22. High/Low Settings ......................................................
Recommended publications
  • Platform RTM User Guide
    Platform RTM User Guide Platform RTM Version 2.0 Release date: March 2009 Copyright © 1994-2009 Platform Computing Inc. Although the information in this document has been carefully reviewed, Platform Computing Corporation (“Platform”) does not warrant it to be free of errors or omissions. Platform reserves the right to make corrections, updates, revisions or changes to the information in this document. UNLESS OTHERWISE EXPRESSLY STATED BY PLATFORM, THE PROGRAM DESCRIBED IN THIS DOCUMENT IS PROVIDED “AS IS” AND WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT WILL PLATFORM COMPUTING BE LIABLE TO ANYONE FOR SPECIAL, COLLATERAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING WITHOUT LIMITATION ANY LOST PROFITS, DATA, OR SAVINGS, ARISING OUT OF THE USE OF OR INABILITY TO USE THIS PROGRAM. We'd like to hear You can help us make this document better by telling us what you think of the content, organization, and usefulness of the information. from you If you find an error, or just want to make a suggestion for improving this document, please address your comments to [email protected]. Your comments should pertain only to Platform documentation. For product support, contact [email protected]. Document This document is protected by copyright and you may not redistribute or translate it into another language, in part or in whole. redistribution and translation Internal You may only redistribute this document internally within your organization (for example, on an intranet) provided that you continue redistribution to check the Platform Web site for updates and update your version of the documentation.
    [Show full text]
  • Observing the Clouds: a Survey and Taxonomy of Cloud Monitoring Jonathan Stuart Ward† and Adam Barker*†
    Ward and Barker Journal of Cloud Computing: Advances, Systems and Applications (2014) 3:24 DOI 10.1186/s13677-014-0024-2 RESEARCH Open Access Observing the clouds: a survey and taxonomy of cloud monitoring Jonathan Stuart Ward† and Adam Barker*† Abstract Monitoring is an important aspect of designing and maintaining large-scale systems. Cloud computing presents a unique set of challenges to monitoring including: on-demand infrastructure, unprecedented scalability, rapid elasticity and performance uncertainty. There are a wide range of monitoring tools originating from cluster and high-performance computing, grid computing and enterprise computing, as well as a series of newer bespoke tools, which have been designed exclusively for cloud monitoring. These tools express a number of common elements and designs, which address the demands of cloud monitoring to various degrees. This paper performs an exhaustive survey of contemporary monitoring tools from which we derive a taxonomy, which examines how effectively existing tools and designs meet the challenges of cloud monitoring. We conclude by examining the socio-technical aspects of monitoring, and investigate the engineering challenges and practices behind implementing monitoring strategies for cloud computing. Keywords: Cloud computing; Monitoring Introduction most accepted description of the general properties of Monitoring large-scale distributed systems is challeng- cloud computing comes from the US based National Insti- ing and plays a crucial role in virtually every aspect of tution of Standards and Technology (NIST) and other a software orientated organisation. It requires substantial contributors [3,4]: engineering effort to identify pertinent information and to • obtain, store and process that information in order for it On-demand self service: A consumer is able to to become useful.
    [Show full text]
  • Install Cacti (Network Monitoring) on RHEL/Centos 7.X
    Install Cacti (Network Monitoring) on RHEL/CentOS 7.x Cacti tool is an open source web based network monitoring and system monitoring graphing solution for IT business. Cacti enables a user to poll services at regular intervals to create graphs on resulting data using RRDtool. Generally, it is used to graph time-series data of metrics such as network bandwidth utilization, CPU load, running processes, disk space etc. Cacti Required Packages: The Cacti required following packages to be installed on your Linux operating systems like RHEL / CentOS . Apache: A Web server to display network graphs created by PHP and RRDTool. MySQL: A Database server to store cacti information. PHP: A script module to create graphs using RRDTool. PHP-SNMP: A PHP extension for SNMP to access data. NET-SNMP: A SNMP (Simple Network Management Protocol) is used to manage network. RRDTool: A database tool to manage and retrieve time series data like CPU load, Network Bandwidth etc. Installing Cacti Required Packages on RHEL/CentOS First, we need to install following dependency packages one-by-one using YUM package manager tool. Here, you need to install and enable EPEL Repository. [root@ns1 ~]# yum install epel-release Install httpd server: # yum -y install httpd httpd-devel Start and enable httpd server # systemctl enable httpd # systemctl start httpd Check status of httpd server to make sure it’s running [root@ns1 ~]# systemctl status httpd ● httpd.service - The Apache HTTP Server Loaded: loaded (/usr/lib/systemd/system/httpd.service; enabled; vendor preset: disabled)
    [Show full text]
  • The Cacti Manual.Pdf
    The Cacti Manual Ian Berry Tony Roman Larry Adams J.P. Pasnak Jimmy Conner Reinhard Scheck Andreas Braun The Cacti Manual by Ian Berry, Tony Roman, Larry Adams, J.P. Pasnak, Jimmy Conner, Reinhard Scheck, and Andreas Braun Published 2017 Copyright © 2017 The Cacti Group This project is licensed under the terms of the GPL. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. All product names are property of their respective owners. Such names are used for identification purposes only and are not indicative of endorsement by or of any company, organization, product, or platform. Table of Contents I. Installation...................................................................................................................................................................................1 1. Requirements.....................................................................................................................................................................1 2. Installing Under Unix.......................................................................................................................................................2
    [Show full text]
  • Percona Monitoring Plugins Documentation Release 1.1.6
    Percona Monitoring Plugins Documentation Release 1.1.6 January 11, 2016 CONTENTS 1 Plugins for Nagios 3 1.1 Percona Monitoring Plugins for Nagios.................................3 1.2 System Requirements..........................................3 1.3 Installation Instructions.........................................4 1.4 Configuration Best Practices.......................................4 1.5 Support Options.............................................4 1.6 List of Plugins..............................................5 2 Templates for Cacti 23 2.1 Percona Monitoring Plugins for Cacti.................................. 23 2.2 Frequently Asked Questions on Cacti Templates............................ 24 2.3 Installing Percona Monitoring Plugins for Cacti............................. 24 2.4 Customizing Percona Monitoring Plugins for Cacti........................... 29 2.5 Percona MySQL Monitoring Template for Cacti............................ 31 2.6 Percona Galera/MySQL Monitoring Template for Cacti........................ 52 2.7 Installing SSH-Based Templates..................................... 55 2.8 Percona Apache Monitoring Template for Cacti............................. 79 2.9 Percona JMX Monitoring Template for Cacti.............................. 82 2.10 Percona Linux Monitoring Template for Cacti............................. 84 2.11 Percona Memcached Monitoring Template for Cacti.......................... 92 2.12 Percona MongoDB Monitoring Template for Cacti........................... 95 2.13 Percona Nginx Monitoring Template for Cacti............................
    [Show full text]
  • Lucas Nussbaum [email protected]
    Supervision - Monitoring Lucas Nussbaum [email protected] Licence professionnelle ASRALL Administration de systèmes, réseaux et applications à base de logiciels libres Lucas Nussbaum Supervision - Monitoring 1 / 51 Administrative stuff I Yes, this course is in English I will speak in French though Goal: get you used to reading technical documentation in English I This module: 6 slots of 3 hours Evaluation: practical work (TPs) + possibly exam Goals: F General knowledge of infrastructure monitoring F Master standard tools of the field F Know about the current trends in this field (e.g. impact of cloud and elasticity) I The other part of this module (Supervision - Annuaire) is totally independent (and with a different tutor: Fabien Pascale) Lucas Nussbaum Supervision - Monitoring 2 / 51 Introduction I Success criteria for sysadmins: infrastructure that just works Avoid incidents if possible If not possible, minimize downtime I How? Well-designed infrastructure Choose reliable technologies and software Add HA (high-availability), failover, redundancy, etc. I Not enough: Murphy’s law (Anything that can go wrong will go wrong) I Monitoring: Collect information about the state of the infrastructure Detect problems (before users have to report them) Predict problems Usual components: ; Probes to acquire data Database to store all measurements Dashboard to show results Notification system (email, SMS, etc.) Lucas Nussbaum Supervision - Monitoring 3 / 51 Example: Icinga https://nagios.debian.org/icinga/ – login: dsa-guest / password: dsa-guest Lucas Nussbaum Supervision - Monitoring 4 / 51 Example: graph from Munin I Disk usage on a server Lucas Nussbaum Supervision - Monitoring 5 / 51 Two sides of the same coin: Metrology Goal: collect lots of metrics about how the system behaves to track performance of the system over time telemetry I Example: collect statistics about; network traffic, HTTP req/s, disk I/Os, ..
    [Show full text]
  • Instalación De Cacti
    Instalación de Cacti Marco Antonio Álvarez Iglesias Índice de contenido Monitorización de Redes con Cacti......................................................................................................3 ¿Qué es Cacti?.................................................................................................................................3 ¿Dónde Conseguirlo?.......................................................................................................................3 Instalación Previa.............................................................................................................................3 Instalación Apache......................................................................................................................3 Instalación PHP4.........................................................................................................................3 Instalación libapache-mod-PHP4................................................................................................3 Instalación Mysql-Server............................................................................................................3 Instalación Php4-Mysql..............................................................................................................3 Instalación RRDTOOL...............................................................................................................4 Instalación Net-SNMP................................................................................................................4
    [Show full text]
  • Network Monitoring & Management Using Cacti
    Network Monitoring & Management Using Cacti Network Startup Resource Center www.nsrc.org These materials are licensed under the Creative Commons Attribution-NonCommercial 4.0 International license (http://creativecommons.org/licenses/by-nc/4.0/) Introduction Network Monitoring Tools Availability Reliability Performance Cacti monitors the performance and usage of devices. Introduction Cacti: Uses RRDtool, PHP and stores data in MySQL. It supports the use of SNMP and graphics with RRDtool. “Cacti is a complete frontend to RRDTool, it stores all of the necessary information to create graphs and populate them with data in a MySQL database. The frontend is completely PHP driven. Along with being able to maintain Graphs, Data Sources, and Round Robin Archives in a database, cacti handles the data gathering. There is also SNMP support for those used to creating traffic graphs with MRTG.” Introduction • A tool to monitor, store and present network and system/server statistics • Designed around RRDTool with a special emphasis on the graphical interface • Almost all of Cacti's functionality can be configured via the Web. • You can find Cacti here: http://www.cacti.net/ Getting RRDtool • Round Robin Database for time series data storage • Command line based • From the author of MRTG • Made to be faster and more flexible • Includes CGI and Graphing tools, plus APIs • Solves the Historical Trends and Simple Interface problems as well as storage issues Find RRDtool here: http://oss.oetiker.ch/rrdtool/ RRDtool Database Format General Description 1. Cacti is written as a group of PHP scripts. 2. The key script is “poller.php”, which runs every 5 minutes (by default).
    [Show full text]
  • SYN Attacks and Their Effects on a Network Infrastructure
    Faculty of Electrical Engineering, Mathematics and Computer Science Network Architectures and Services A Study On TCP{SYN Attacks And Their Effects on A Network Infrastructure Cliff Nyangasi Maregeli June 23, 2010 A thesis submitted in partial fulfillment of the requirements for the degree of Master of Science prof.dr.ir. P. Van Mieghem: Chairman dr.ir. F. Kuipers: Member dr.ir. E. Onur: Member dr.ir. T. Kleiberg: Supervisor ir. J. Omic: Supervisor Date of Defense: July 8, 2010 Thesis no: PVM-2010-063 A Study On TCP{SYN Attacks And Their Effects on A Network Infrastructure Master's Thesis in Computer Engineering Network Architectures and Services Faculty of Electrical Engineering, Mathematics and Computer Science Delft University of Technology Mekelweg 4, 2628 CD Delft, The Netherlands Cliff Nyangasi Maregeli June 23, 2010 ii Copyright c 2010 by Cliff N. Maregeli. All rights reserved. No part of the material protected by this copyright may be reproduced or utilized in any form or by any means, electronic or mechanical, including photocopying, recording or by any information storage and retrieval system, without the permission from the author and Delft University of Technology. Dedication In memory of my father, Frank G.S. Maregeli. To my mother, Peris To my wife, Flora and our daughter Nora. Abstract Over the years, the Internet has evolved from a tool for the research com- munity to an indispensable network connecting over a billion nodes world wide. There are many security threats existing on the Internet, one of them is the denial-of-service attack (DoS). In this thesis, we study effect of denial-of-service attacks arising from TCP SYN flooding.
    [Show full text]
  • Network and Server Statistics Using Cacti
    Network Management & Monitoring Network and Server Statistics Using Cacti These materials are licensed under the Creative Commons Attribution-Noncommercial 3.0 Unported license (http://creativecommons.org/licenses/by-nc/3.0/) Introduction Network Monitoring Tools Availability Reliability Performance Cacti monitors the performance and usage of devices. Introduction • A tool to monitor, store and present network and system/server statistics • Designed around RRDTool with a special emphasis on the graphical interface • Almost all of Cacti's functionality can be configured via the Web. • You can find Cacti here: http://www.cacti.net/ Introduction Cacti: Uses RRDtool, PHP and stores data in MySQL. It supports the use of SNMP and graphics with MRTG. “Cacti is a complete frontend to RRDTool, it stores all of the necessary information to create graphs and populate them with data in a MySQL database. The frontend is completely PHP driven. Along with being able to maintain Graphs, Data Sources, and Round Robin Archives in a database, cacti handles the data gathering. There is also SNMP support for those used to creating traffic graphs with MRTG.” General Description 1. Cacti is written as a group of PHP scripts. 2. The key script is “poller.php”, which runs every 5 minutes (by default). It resides in /usr/share/cacti/site. 3. To work poller.php needs to be in /etc/cron.d/cacti like this: MAILTO=root */5 * * * * www-data php /usr/share/cacti/site/poller.php >/dev/null 2>/var/log/cacti/poller-error.log 4. Cacti uses RRDtool to create graphs for each device and data that is collected about that device.
    [Show full text]
  • The Open-‐Source Monitoring Landscape
    The Open-Source Monitoring Landscape Michael Merideth Sr. Director of IT, VictorOps [email protected], @vo_mike My History and Background • Working in IT since the mid 90’s • Mostly at startups in the Colorado Front Range area • Along for the ride during the “dot com boom” • Build my career using open-source tools Since the 90’s now, there’s been a sharp division in tools and methodology between the enterprise space and the startup and small business communi;es. Obviously, smaller businesses, especially in the tech sector, were early and eager adopters of open- source technology, and much quicker to learn to rely on open-source tool chains in business-cri;cal applica;ons. Up at the enterprise level, at the public companies, they’re only now fully-embracing Linux as a business-cri;cal tool, and I think that’s largely because “the enterprise” is star;ng to be defined by companies that either came up in the dot com era, like Google, or built the dot com era, like Sun, or Dell, or let’s say RedHat. So, the “enterprise” had their toolchain, built on commercial solu;ons like HPUX and OpenView and so on, and the startup community, the “dot com” community had a completely different toolchain, based on Linux, based on open standards and protocols, built with open-source components like GNU, and Apache, and ISC Bind and so on. I’m lucky enough that I’ve been able to spend my career in the startup sphere, working with that open-source toolchain. I started working in IT in the mid 90’s in the Colorado front range, and I’ve spent my ;me since then working for and consul;ng at early-stage startups and other “non enterprise” shops.
    [Show full text]
  • Using Open Source Software in Daily Isp Operations
    USING OPEN SOURCE SOFTWARE IN DAILY ISP OPERATIONS Yaman Hakmi Systems Engineer [email protected] v3.0 October 29, 2009 Agenda Introduction ISP Operational Background ISP Operational Challenges Open-source Solution Components Summary Introduction This presentation reflects the various stages an ISP in Saudi Arabia went through to implement open-source software and tools for enhancing daily operations This includes implementing the following: Network graphing tool System and network monitoring Customer relationship management ISP Operational Background 5 major POPs in the region ATM and IP-based network backbone 200+ network devices to manage 1000+ customer records Various last mile access Dhahran solutions (Microwave links, digital UAE LL, DSL, WiMax, etc.) Riyadh Jeddah A plethora of data center systems & applications to manage (web hosting, mail, DNS, LDAP, etc.) HQ Multi-tiered support groups POP ISP Operational Background ISP operated based on the following high-level workflow for customer data/internet activation: Baseline services for Support and link status Limited capacity planning Separate records, documents, etc Limited link monitoring service ISP Operational Challenges Main challenges: Limited ability to monitor system and network devices Lack of monitoring, trending, historical graphs, logs, etc. Little visibility into device health check Lack of a central repository for customer records, such as: service dates, activation requests, network diagrams and contact details As customer list grows, new tools for network operation & management are needed! Modus Operandi had to change from fire-fighting to planned service activation and proactive network monitoring and trending ISP Operational Challenges Tools used in the past: Network Network Customer Graphing Monitoring Records -Excel sheets -MRTG -WhatsUp - MS-Word - Cricket - HPOV NNM docs -MySQL DB Drawbacks: -No roadmap -Basic features (WUP) -Manual records -Limited SW support -Incr.
    [Show full text]