*BSD News Article 33436


Return to BSD News archive

Newsgroups: comp.os.386bsd.development
Path: sserve!newshost.anu.edu.au!harbinger.cc.monash.edu.au!bunyip.cc.uq.oz.au!munnari.oz.au!spool.mu.edu!agate!darkstar.UCSC.EDU!news.hal.COM!olivea!decwrl!pa.dec.com!nas.nasa.gov!jude
From: jude@nas.nasa.gov (Jude George)
Message-ID: <199407300025.RAA26337@wk106.nas.nasa.gov>
Subject: Free software to display/manage networks.  Port to FreeBSD?
Date: Fri, 29 Jul 1994 17:25:28 -0700
X-Received: by usenet.pa.dec.com; id AA25717; Fri, 29 Jul 94 17:31:01 -0700
X-Received: by pobox1.pa.dec.com; id AA28682; Fri, 29 Jul 94 17:31:00 -0700
X-Received: from wk106.nas.nasa.gov by inet-gw-3.pa.dec.com (5.65/27May94)
	id AA16575; Fri, 29 Jul 94 17:27:12 -0700
X-Received: (from jude@localhost)
	by wk106.nas.nasa.gov (8.6.8.1/NAS.5.b) id RAA26337
	for comp.os.386bsd.development.usenet@decwrl.dec.com; Fri, 29 Jul 1994 17:25:28 -0700
X-To: comp.os.386bsd.development.usenet@decwrl.dec.com
Lines: 190

Would someone like to port this to FreeBSD?

A free package called HNMS, the NAS Hierarchical Network Management
System, is now available.  The software may be ftp'd from ftp.netcom.com
in the directory pub/heyjude.  (We're looking for other sites
to pick this up, as netcom is pretty bogged down -- offers are welcome).

For sample screen snapshots, try the following in your favorite
WWW viewer:
	ftp://ftp.netcom.com/pub/heyjude/SCREEN1.gif
	ftp://ftp.netcom.com/pub/heyjude/SCREEN2.gif

----------------------------------------------------------------------------

				HNMS v2.0g2

	This is the first public release of HNMS, the NAS Hierarchical
	Network Management System.  HNMS may be used to monitor status
	and generate traffic statistics for a large, routed IP network.

	Graphical displays are provided for the X11 Window System and
	make use of the Motif widget set.  HNMS is unique is that it
	can be used to graphically display routing information.  The
	GUI provides compact representations of LANs, in which the status
	of every subnet, host, and IP address can be displayed in a small
	area.  Netmask misconfigurations can be picked out immediately.
	It also correctly displays various WAN architectures, such as
	those which include multiple IP addresses per interface
	(or vice versa), or subnets which spread across multiple links.
	A custom version of HNMS was used to generate the live,
	three-dimensional representation of the cross-country ATM network
	at Supercomputing '93 in Portland, Oregon.

	Data collection is handled via SNMP, ICMP, and direct layer 2
	monitoring.  Distribution of network management information is
	done via HNMP, a new protocol which builds upon the simple,
	stateless client-server model used by SNMP.  HNMP defines
	network objects, binds SNMP variables to them, and facilitates
	higher level management operations on them.  The ASN.1
	specification of HNMP is included in this package.

	Please note that there is also a release of HNMS that we are
	distributing through COSMIC, NASA's software technology
	transfer organization.  COSMIC may (or may not) provide
	support for that distribution, but please do not ask them
	for any kind of support concerning this one.  They will not
	be able to help you.  This version of HNMS has been made
	available to you, by special dispensation, as FREE SOFTWARE
	under the GNU public licence ("copyleft").  It is distributed
	as is, with NO WARRANTY for its fitness for any purpose.
	If it is redistributed, you may not charge for it or any
	derivative work.  Please see the file "COPYING" for details
	about all this.

	Full source code is provided.  We encourage the Internet
	community to experiment with, build upon, use, port, learn from,
	add modules to, write scripts for, and expand this software
	package.  There are some areas in which it can be improved,
	especially in the areas of generality and efficiency.
	We would like to see standardized displays for various types
	of networks and monitored objects, as well as customized displays
	for specific network hardware, and have them be freely available
	to everyone.

	The authors do not have the resources to maintain this software
	outside of NAS.  Although we may continue to add enhancements,
	we are hoping that other(s) will take on the role of incorporating
	bug fixes and extensions to the code, and sending out new releases.

	We do welcome any suggestions or bug reports that you may
	have -- but there's no guarantee that we will be able to
	help you, or even have time to respond.  We are working full
	time (and then some) on other projects.  To reach us via
	email, mail to hnmsdev@nas.nasa.gov.

	This software has not been extensively tested.  Neither the authors,
	nor NASA, nor anybody at all takes any responsibility for any damage
	that HNMS may cause, directly or indirectly, to your network, your
	users, or anything.

	That said, it works pretty well for us.

	Jude George		Leslie Schlecht
	jude@nas.nasa.gov	schlecht@nas.nasa.gov

	Any opinions expressed above are a figment of your imagination,
	and should not be taken to reflect the views of NAS, NASA, CSC,
	or anybody else.

----------------------------------------------------------------------------
	TO BUILD, follow the instructions in the top-level Makefile.

------>	Be forewarned that you will need to obtain the Motif libraries,
------>	ISODE-7.0 (not 8.0) and tcpdump if they do not already exist
	on your system.

	FOR COMPLETE INSTRUCTIONS on installing and using HNMS,
	please read the file docs.ps.

----------------------------------------------------------------------------
Here are some quick-start instructions for the HNMS daemon, the graphical
user interface, and the textual user interface.  The binaries are called
hnmsd, hnms, and hnmstool.

INSTALLATION

1. Untar and build the HNMS distribution.  Sources, docs, and auxiliary
   files are included.  This version of HNMS has only been tested on
   the Silicon Graphics Iris under IRIX 4.0.5.  It should work with little
   modification on SparcStations running SunOS 4.x.

1. Choose a directory to be the hnms "home", and copy the binaries
   and the background/ directory to that directory.

2. Set the $HNMS_HOME environment variable to be that directory.  You
   may want to put this in your .login.

3. Make sure tcpdump is in your path.  It's usually located in
   /usr/local/etc.  The HNMS IO module uses tcpdump to discover new
   IP addresses.

4. Make the hnmsd (and tcpdump, if necessary) setuid root.  The HNMS
   IO module, contained within hnmsd, needs root to access the ICMP
   socket.

5. Set the HNMS_PROMISCUOUS environment variable.  We are just using
   this as a flag to tell the IO module that it's okay use promiscuous
   Ethernet monitoring.

6. Start hnmsd.

RUNTIME -- GUI

The GUI binary is called "hnms".  If you are running it on a machine
different from the server, set the HNMS_SERVER environment variable
to have the server machine's name.

Start the hnms program.  Once the GUI's main window appears, choose
"Open" from the "HNMP" menu at the top center of the window.  A new
window titled "Server" will pop up.  In this window, type "public"
in the Community field, and the hostname of the server machine in the
Selection field.  Then click the Connect button. 

At this point, you can start building diagrams.  Choose "New -->
Custom Status View" from the HNMS menu on the main window.
An "EDIT" window will pop up.  Type an asterisk in the Selection
field, then click Add, then click the check mark at the top.
You will see a display of all the hosts that the server currently
knows about ("Processor" objects), along with their IP addresses
("Ipaddr" objects") and the subnets they are connected to ("Subnet
objects).  If you have just recently started up hnmsd, the objects
will appear magenta while hnmsd is ramping up.  This process
takes three minutes.  Afterwards they will change to green.
When a reachable object becomes unreachable, it changes to yellow,
then red.

Feel free to experiment with the rest of the menu items.  "Site" and
"WAN" diagrams may be built in a manner similar to the "Custom".
For WAN diagrams to be displayed properly, the sysLocation field of
your hosts should be in the format <any-string> <longitude> <latitude>.
For example, "NASA Ames Research Center -122.5 37.1".

RUNTIME -- PLAINTEXT

You may also run hnmstool.  This program takes commands on stdin and
outputs results on stdout, so it can be used effectively from within
shell scripts.  For a demonstration, we will run it interactively.

The hnmstool does not give a prompt.  After starting it, wait a minute
or two for it to get the list of HNMS objects from the server.
for the HNMS daemon to pick up a good assortment of objects from the
network.  Then type list.  You should see a list of objects scroll down
the screen.  Only hosts with SNMP agents responding to "public" will be
shown.  To pick up other hosts, type hint <hostname> <community-name>.
For example:

hint snafu.nas.nasa.gov foobar

The next time you type list, you should see                     

processor:snafu

among the objects.  To get data about an object, type
subscribe "<object>" <variable>@<interval>.  For example:

subscribe "processor:snafu" sysUpTime.0@15

This will give you a report of the value of the sysUpTime.0 variable
every 15 seconds, if the variable changes.  Since sysUpTime.0 constantly
changes, you will get an update on stdout every 15 seconds.