Hi All,
I am wondering what tools are available in CentOS 5.5 that would allow me to measure incoming and outgoing network speeds? My new website seems to be getting a lot more traffic that I had anticipated off the bat and I would like to measure resource usage to ensure it is keeping up.
I know that top only measures CPU
Best, -Jason
It all depends on your requirements:
- what sort of questions would you like your solution to be able to answer? (can you give us a few?)
- what monitoring infrastructure do you already have? (SNMP, for example, could be rather useful here)
- how much level of ad-hoc reporting do you require?
- you mentioned "incoming and outgoing network speeds", which doesn't necessarily refer to any web-specific analysis; is this what you meant?
Plenty of tools out there: ntop may be a good starting point.
http://www.cyberciti.biz/faq/howto-install-ntop-on-rhel-centos-fedora-linux/
Netflow and SNMP would be my first points of call if I wanted something more.... infrastructural.
For ad-hoc use of TCP sessions, with a top-like experience, I would just break out tcptrack (there are RPMs available, but doesn't appear to be a Centos package)
On 16/01/2011, at 6:08 PM, Jason S-M wrote:
Hi All,
I am wondering what tools are available in CentOS 5.5 that would allow me to measure incoming and outgoing network speeds? My new website seems to be getting a lot more traffic that I had anticipated off the bat and I would like to measure resource usage to ensure it is keeping up.
I know that top only measures CPU
Best, -Jason _______________________________________________ CentOS mailing list CentOS@centos.org http://lists.centos.org/mailman/listinfo/centos
On Sun, 16 Jan 2011, Cameron Kerr wrote:
To: CentOS mailing list centos@centos.org From: Cameron Kerr cameron@humbledown.org Subject: Re: [CentOS] Network bandwidth tools.
It all depends on your requirements:
what sort of questions would you like your solution to be able to answer? (can you give us a few?)
what monitoring infrastructure do you already have? (SNMP, for example, could be rather useful here)
how much level of ad-hoc reporting do you require?
you mentioned "incoming and outgoing network speeds", which doesn't necessarily refer to any web-specific analysis; is this what you meant?
Plenty of tools out there: ntop may be a good starting point.
http://www.cyberciti.biz/faq/howto-install-ntop-on-rhel-centos-fedora-linux/
Netflow and SNMP would be my first points of call if I wanted something more.... infrastructural.
For ad-hoc use of TCP sessions, with a top-like experience, I would just break out tcptrack (there are RPMs available, but doesn't appear to be a Centos package)
I'm willing to build it for Centos 5.5 if that helps :)
Keith
----------------------------------------------------------------- Websites: http://www.karsites.net http://www.php-debuggers.net http://www.raised-from-the-dead.org.uk
All email addresses are challenge-response protected with TMDA [http://tmda.net] -----------------------------------------------------------------
On Sun, 16 Jan 2011, JohnS wrote:
To: CentOS mailing list centos@centos.org From: JohnS jses27@gmail.com Subject: Re: [CentOS] Network bandwidth tools. || RPM Builder
On Sun, 2011-01-16 at 15:16 +0000, Keith Roberts wrote:
I'm willing to build it for Centos 5.5 if that helps :)
Keith
Looks like another builder here? Makes 3 now?
I'm working on learning it John. MaximumRPM snapshot is my 'rpm-users-and-builders-bible'.
I installed the kernel-2.6.18-194.el5.src.rpm, and much to my shock-horror, the spec file is SEVENTEEN THOUSAND LINES long!!!
File: kernel-2.6.spec Line 17337 Col 0 834946 bytes 100%
So if I have a terminal window 30 lines high, that's 577 pages of spec file. Well, 47% of it is the changelog. So that cuts it down by half.
Keith
Ten Centos builders, sitting on the wall, and if one Centos builder should accidently fall...
----------------------------------------------------------------- Websites: http://www.karsites.net http://www.php-debuggers.net http://www.raised-from-the-dead.org.uk
All email addresses are challenge-response protected with TMDA [http://tmda.net] -----------------------------------------------------------------
On Sun, Jan 16, 2011 at 5:08 AM, Jason S-M slackmoehrle.lists@gmail.com wrote:
Hi All,
I am wondering what tools are available in CentOS 5.5 that would allow me to measure incoming and outgoing network speeds? My new website seems to be getting a lot more traffic that I had anticipated off the bat and I would like to measure resource usage to ensure it is keeping up.
I know that top only measures CPU
Best, -Jason _______________________________________________ CentOS mailing list CentOS@centos.org http://lists.centos.org/mailman/listinfo/centos
check out iptraf, bwmon, ntop, vnstat etc.
Hi All,
I am wondering what tools are available in CentOS 5.5 that would allow me to measure incoming and outgoing network speeds? My new website seems to be getting a lot more traffic that I had anticipated off the bat and I would like to measure resource usage to ensure it is keeping up.
Take a look at ntop .. there are packages available from rpmforge.
Barry
Barry Brimer wrote:
I am wondering what tools are available in CentOS 5.5 that would allow me to measure incoming and outgoing network speeds? My new website seems to be getting a lot more traffic that I had anticipated off the bat and I would like to measure resource usage to ensure it is keeping up.
Take a look at ntop .. there are packages available from rpmforge.
+1 ntop
At the risk of pissing off the list for such a long post, here are 2 useful shell-scripts for monitoring Linux system bandwidth. Although they were developed on another distro I believe (untested) they will work fine with CentOS.
The first script gets installed as a cronjob, the second is run when you want a histogram of your bandwidth. As commented in the script, changing 1 line in the second script gives you TX bandwidth instead of RX. Probably it should be an argument to the script.
logifx: ----%< cut here %<----------------------------------------------------------- #!/bin/bash # From: William Hunt wjh@prv8.net # Newsgroups: alt.os.linux.slackware # Subject: Fun with Slackware: bandwidth monitor # Date: Wed, 23 Jan 2008 02:04:05 -0800 # A script to periodically calculate the total number of bytes # sent and received on the given interface; # useful for running under cron, for example. # raw data is read from ifconfig(1); the script calculates its # output from the current reading and from data stored in a state # file by the previous run; the current values are then stored in # the state file for the next run, overwriting the previous state. # if the state file does not exist then no output is generated, but # the new STATEF file is still initialized with current data. #-------------------------------------------------------------- # this is a useful escape in case of trouble: #-------------------------------------------------------------- function PANIC () { echo PANIC: $* ; exit ; } #-------------------------------------------------------------- # syntax: logifx <interface> #-------------------------------------------------------------- [ "$1" == "" ] && PANIC interface required. IF=$1 #-------------------------------------------------------------- # FILES & DIRECTORIES: #-------------------------------------------------------------- export PATH=/usr/bin:/bin:/usr/sbin:/sbin STATED=/var/run/logifx [ -d "${STATED}" ] || mkdir -p ${STATED} || PANIC bad ${STATED} ? STATEF=${STATED}/ifxlog-${IF}.dat OUTD=/var/log OUTF=${OUTD}/ifx_${IF} #-------------------------------------------------------------- # read ifconfig and return RX and TX values: #-------------------------------------------------------------- function readif() { ifconfig ${IF} | while read LINE ; do DATA=($(echo ${LINE} | grep 'RX bytes:')) [ $? = 0 ] && echo ${DATA[1]/bytes:} ${DATA[5]/bytes:} done exit 0 } #-------------------------------------------------------------- # read the clock: #-------------------------------------------------------------- STAMP=$( date '+%Y%m%d%H%M' ) # timestamp for logfile line SEC=$( date '+%s' ) # time used for calculations #-------------------------------------------------------------- # read the data - note how an array is used to receive # two return values from the function call #-------------------------------------------------------------- CURRENT=($( readif )) || PANIC reading ifconfig CRX=${CURRENT[0]} CTX=${CURRENT[1]} #-------------------------------------------------------------- # if state file exists, read prior values and calculate output. # negative results indicate a stale state file, so reset it. # (not absolutely correct, but best guess and close enough); # then append the output to the log file: #-------------------------------------------------------------- if [ -e ${STATEF} ] ; then read PSEC PRX PTX < ${STATEF} SPAN=$(( ${SEC} - ${PSEC} )) [ $SPAN -gt 0 ] || PANIC WTF? SPAN=${SPAN} RX=$(( ${CRX} - ${PRX} )) TX=$(( ${CTX} - ${PTX} )) [ $RX -lt 0 ] && RX=${CRX} [ $TX -lt 0 ] && TX=${CTX} echo ${STAMP} ${SPAN} ${RX} ${TX} >> ${OUTF} || PANIC ${OUTF} fi #-------------------------------------------------------------- # update state file (overwrite) #-------------------------------------------------------------- echo ${SEC} ${CRX} ${CTX} > ${STATEF} || PANIC updating ${STATEF} #-------------------------------------------------------------- # the end.
# Okay? Okay! With that in /root/cron/logifx, now, the next step is # to stuff it into cron, using crontab -l of course. # # * * * * * /root/cron/logifx eth0 # * * * * * /root/cron/logifx eth1 # * * * * * /root/cron/logifx eth2 # # Note that any errors running the script are written to stdout, # which cron will mail to the owner (root). So check for that. # # Note that the output record is formatted: # 1: timestamp YYYYMMDDHHMM # 2: interval, in seconds # 3: total bytes received during interval preceeding timestamp; # 4: total bytes sent during interval preceding timestamp; ----%< cut here %<-----------------------------------------------------------
view_TX: ----%< cut here %<----------------------------------------------------------- #!/bin/awk -f # Okay? Okay! With that in /root/cron/logifx, now, the next step is # to stuff it into cron, using crontab -l of course. # # * * * * * /root/cron/logifx eth0 # * * * * * /root/cron/logifx eth1 # * * * * * /root/cron/logifx eth2 # # Note that any errors running the script are written to stdout, # which cron will mail to the owner (root). So check for that. # # Note that the output record is formatted: # 1: timestamp YYYYMMDDHHMM # 2: interval, in seconds # 3: total bytes received during interval preceeding timestamp; # 4: total bytes sent during interval preceding timestamp;
# Okay? Okay! Now comes the fun part - analyzing the data. One # could simply use a pager (ex: less) to view the accumulated # readings, but a graphical interpretation makes it so much easier # to visualize the data and observe patterns. Since I work mainly # at text consoles, I use a histogram for this. # function histo( X ) { B="" N=X^0.5 # NOTE scaling ... for (a=0;a<N;a++) {B=B"*";} return B } { Data = ($3) Size = Data / 1024 # kilobytes Rate = Data / 128 / ($2) # kilobits per second Graph = histo( Rate ) mask = "%s %5.0f KB %8.3f Kb/s %s\n" printf( mask, $1, Size, Rate, Graph ) } # the end.
# The second script i call view_TX and it is exactly the same # as view_RX except for one line: # Data = ($3) # is replaced with: # Data = ($4) # # I know i should rewrite these into one script, in such a way # that RX vs TX would be indicated by the script name, or an # argument, or whatever. But for my purpose this is good enough, # and maybe some day I'll rewrite it (again :*) # # These scripts get called something like: # # view_TX /var/log/ifx_eth0 | less # # and generate a report something like this: # # [...] # 200801222211 852 KB 113.586 Kb/s *********** # 200801222212 4445 KB 592.651 Kb/s ************************* # 200801222213 10 KB 1.337 Kb/s ** # 200801222214 505 KB 66.245 Kb/s ********* # 200801222215 1232 KB 164.312 Kb/s ************* # 200801222216 403 KB 54.646 Kb/s ******** # 200801222217 3379 KB 450.586 Kb/s ********************** # 200801222218 172 KB 22.913 Kb/s ***** # 200801222219 19 KB 2.580 Kb/s ** # 200801222220 705 KB 94.007 Kb/s ********** # [...] #
# Okay? Okay!
# The same ifx_eth0 file can also be used to calculate totals # for longer intervals, like monthly, for example. I rotate # my logs into a file tree like /var/log/YYYY/MM/DD/, so: # # cat /var/log/2007/12/*/ifx_eth0 | while read A B C D ; do # TOTRX=$(( $TOTRX + $C )) # done # echo "TOTAL RX for December, $(( $TOTRX / 1024 / 1024 )) MB." # # Okay? Okay! # # Have fun, # # -- # William Hunt, Portland Oregon USA ----%< cut here %<-----------------------------------------------------------
2011/1/16 cpolish@surewest.net:
Barry Brimer wrote: At the risk of pissing off the list for such a long post
Personally, I never get pissed off due to long mails, but I do get pissed off when people keeps changing the subject (and/or use broken mail clients)...like: "Network bandwidth tools" "Network bandwidth tools || RPM Builder" "Network bandwidth tools (long)"