In order to perform certain NIM operations, the NIM master must be able to supply information necessary to configure client network interfaces. The NIM master must also be able to verify that client machines can access all the resources required to support operations. To avoid the overhead of repeatedly specifying network information for each individual client, NIM networks are used to represent the networks in a NIM environment. When NIM clients are defined, the associated network for the client must be specified. During NIM operations, the NIM master is able to use information from the client's network definition when necessary.
When the NIM master is configured, the network associated with the master is automatically defined in the NIM environment. It is necessary only to define additional NIM networks if clients reside on other local area networks or subnets. The procedures described in this guide and reference are designed to automatically define NIM networks, if necessary, when clients are added. However, this section is included to describe NIM networks in detail in case manual definition of networks and routes is required.
The supported network types are as follows:
Network boot support is provided for Ethernet, Token-Ring, and FDDI. Unlike other network adapters, ATM adapters cannot be used to boot a machine. Therefore, installing a machine over an ATM network requires special processing. See Installing to Clients on ATM Networks. The Generic network type is used to represent all other network types where network boot support is not available. For clients on Generic networks, NIM operations that require a network boot, such as bos_inst and diag, are not supported. However, nonbooting operations, such as cust and maint, are allowed. Diskless and dataless clients cannot be associated with Generic networks, because they inherently rely on network boot capability.
Networks are defined in the NIM environment using the NIM define operation. The command line syntax is as follows:
nim -o define -t NetworkType -a Attribute=Value ... MachineName
where the following attributes are required:
-a net_addr=Value | Specifies the IP address of the network being defined. If the network address is not known, see Determining a Network's IP Address. |
-a snm=Value | Specifies the subnet mask for the network. |
-t NetworkType | Specifies the type of network being defined. Valid values are atm, tok, ent, fddi, and generic. |
The following attributes are optional:
-a comments=Value | Provides comments about this network. |
-a ieee_ent=Value | Specifies IEEE 802.3 ethernet configuration. This is only valid for networks that are defined with the ent type or those that have an other_net_type attribute set to ent. |
-a other_net_type=Value | Specifies another network type that applies to this logical network. Each NIM network is used to represent one logical network that exists in the NIM environment. When the network is defined, the type of network interface used in the network must be supplied. Usually, a network is composed of only one type. However, a bridge can be used to connect different network types together to form one logical network. In that situation, NIM needs to know what the other network interface types are, and this attribute is used to specify that information. For more information on how to use the other_net_type attribute, see Defining a Heterogeneous Network. |
-a routing=Value ... | Stores NIM routing information for a network. This attribute requires
a sequence number when specified. When a new NIM route is specified, the routing attribute consists of three values:
This attribute can be used to add a default route or static route. To add a default route, specify default for Value 1. Then, specify the default gateway for the network in Value 2. Leave Value 3 blank. For more information on adding and changing routes, see NIM Routes, , and . |
-a verbose=Value | Displays information for debugging. Use verbose=5 to show maximum detail. |
It is also possible to define NIM networks automatically when client machines are defined. To do this, use the find_net and net_definition attributes when defining the client. For more information, see NIM Machines.
NIM determines a network's IP address by performing a bitwise "AND" on the binary representations of the network's subnet mask and the address of any machine's IP address on the same network. For example:
subnet mask = 255.255.254.0 client address = 129.35.58.207 In binary: subnet mask = 11111111.11111111.11111110.00000000 client address = 10000001.00100011.00111010.11001111 network address = 10000001.00100011.00111010.00000000 In decimal: network address = 129.35.58.0
Routing information is used internally by NIM to ensure that a client on one network can communicate with a server on another network. It defines the gateway to use to go from one network to the other network.
NIM provides the ability to define default or static routes. Default NIM routes provide the following advantages over static routes:
To determine the gateway used by machines on a given network, run netstat -rn on a running machine on the network to see if a default gateway is listed. You can also issue traceroute Host_Name from a running machine on the network in question, where Host_Name is the name of the master's primary network interface if determining the gateway for a client, or the name of a target client if determining the gateway used by the master. The first gateway listed is the gateway used by machines on the specified network.
Note that NIM routes are not required if the only networks defined in a NIM environment are associated with interfaces (if attributes) defined on the NIM master and if all resources will be defined on the master. If resources are served by machines other than the master to clients that do not reside on the same network as the server, NIM routes are required between those networks even if all networks are attached to interfaces belonging to the master. In this case, the master must act as a gateway (with IP-forwarding switched on), and the host name of the interface on the master should be used as a gateway.
Networks with default routes may be created automatically when NIM machines are being defined.
It may be observed that communications between networks go through several gateways. However, it is important to remember that when defining NIM routes for networks, the only gateways of interest are the first ones used by the networks to reach their destinations. Intermediate gateways between the originating and destination networks are irrelevant for NIM routing purposes.
This section describes the NIM feature that enables it to model networks consisting of different data link protocol segments. These kinds of networks use bridges to connect two segments that have different data link protocols. A network consisting of a Token-Ring and an Ethernet segment can be connected to form a single logical network, as shown in the following figure.
Because a single NIM network object is used to represent one network, the other_net_type attribute is reserved for a different type of interface that can exist in a network. The other_net_type attribute can be added to the definition of a network object. When present in a network definition, the other_net_type attribute tells NIM that this logical network uses a bridge to connect the other network type to the network type that was specified when the object was defined.
When you define a machine object to be connected to a network object, NIM checks to see if the network has any other_net_type attributes. If so, NIM requires that the fourth field, which is usually optional, in the if attribute, be specified. This field specifies the logical name of the client's network adapter. The following example defines a network object that has a bridge joining a Token-Ring and an Ethernet segment:
nim -o define -t tok -a net_addr=129.35.129.0 \ -a snm=255.255.240.0 -a other_net_type1=ent b905net lsnim -l b905net class = network type = tok net_addr = 129.35.128.0 snm = 255.255.240.0 other_net_type1 = ent Nstate = ready for use prev_state = information is missing from this object's def>
Note that the other_net_type attribute requires a sequence number. Because a network could be composed of all three types of interfaces linked by bridges.
When you define a client's interface that is physically connected to an Ethernet segment joined with a Token-Ring network using a bridge (with master being on the Token-Ring side), you must supply the fourth field:
nim -o define -t standalone -a if1='find_net mymac 08005ac9430c \ ent' -a cable_type1=bnc mymac
To define a NIM network, enter:
nim -o change -a other_net_typeSequenceNumber=NetworkType NetworkName
For example, to change a Token-Ring network called network1 to also support Ethernet and FDDI, enter:
nim -o change -a other_net_type1=ent -a other_net_type2=fddi network1