Tuesday, July 15, 2008
You're In Trouble(shooting) Now!
Today, we are in trouble, troubleshooting mode that is! Juniper routers allow multiple IP addresses to be applied to a single, physical interface. What this mean is, if you issued the command set unit 100 family inet address 10.10.10.21.122/24 from the edit interfaces fe-2/0/1 hierarchy and then realized it was incorrect you would need to delete that entry before adding a new one. Otherwise, fe-2/0/1 would have two addresses when you really only wanted one!
Addresses are NOT overridden per logical unit, they are simply added to the logical unit. Here is an example of our double jeopardy:
[edit interfaces fe-2/0/1]
root@routername#show
vlan-tagging;
unit 100 {
vlan-id 100;
family inet {
address 10.10.10.21.122/24
address 10.10.10.21.122/27
}
}
In the above example, /24 is the incorrect mask and /27 is what we need. you can use the delete set unit 100 family inet address 10.10.10.21.122/24 command to correct this.
Note: you can also use the rename command like this: rename address 10.10.10.21.122/24 to address 10.10.10.21.122/27
Tuesday, July 1, 2008
Virtually Multiplicity Redux
In VRRP, a logical grouping of multiple physical routers is created to masquerade as one single device with the use of a "virtual IP" address. This virtual address will act as the gateway interface for end host devices. In this way, if there is a device failure, hosts do not see it. Routers belonging to the same VRRP group share a "virtual Media Access Control" or MAC address as well as an IP address. There is an election process that describes how ownership of the virtual interfaces takes place.
- One router in the VRRP group acts as the master router and has ownership of the virtual MAC and IP address until there is a failure. All routers in the same VRRP group share a group value ranging from 1-255
- A failure causes another router to claim ownership through a combination of a VRRP message and gratuitous Address Resolution Protocol or ARP request.
- Once a router takes ownership and becomes the new master router, it periodically sends out VRRP messages to indicate reachability.
Let's talk a bit more about some of the other properties of our VRRP router...
Configuration for VRRP is done as a logical property in [edit]. First a group value is assigned to all routers participating in the VRRP group. Then, a virtual IP address is assigned that end hosts will see as their default gateway. The VIP could be an address already belonging to a router in the group, or an address available from the LAN segment. Finally, a priority value (100 by default) can bet set to control master router elections.
Note: The router with the highest priority value becomes master for the group. If the priority values are equal, then priority is given to the highest local LAN IP. Also, while priority values range from 0-255, both zero and one are reserved. Priority 0 is "immediate release of mastership role" and 255 is used if the virtual IP is a physical interface owned by that router.
You can also track an interface's priority settings in case of interface failure to ensure reachability to upstream devices. The way this can be accomplished is to subtract a configured value from the advertised priority value.
"Whose fault is it? Default!"
VRRP has "preemption" enabled by default. What this means: Anytime a router has a higher priority value, it becomes the master router. This can cause temporary disruption of the network during the election process. You can use the no-preempt command to control that behavior.
You can show which router is the master router and other operational statistics with the show vrrp summary command.
VRRP issues:
A router that is participating in VRRP should NEVER forward packets address to the virtual IP address or addresses it becomes master for if it is not the owner according to RFC 3768. RFC is short for "Request for Comment." What this means to us is, an address used as the VIP that does not exist as an interface for routers in the VRRP group, like a valid IP address on our LAN segment could cause issues. One of those issues is being unable to ping the virtual IP address. On a Juniper router, you can use the accept-data command to allow a master router to respond to the VIP address. However, a word of caution, accept-data can cause unnecessary traffic on affected LAN segments.
In the next section, we will get our "feet wet" in interface troubleshooting.
Thursday, June 26, 2008
Virtually Multiplicity
PPP has a lot going for it in terms of a protocol. In addition to authentication and support for multiple protocol types, individual PPP links can be combined using the Multi-Link Point-to-Point protocol. RFC 1990 details the "software bundling" of multiple PPP links together as one. JUNOS allows for up to eight physical interface links to be assigned to a bundle.
In order to support MLPPP on Juniper equipment, you need a hardware PIC in the case of M/T Series routers or appropriate software support in the J-Series platform. We will discuss configuration steps next:
- Configure the pseudolink interface appropriate for your routing platform
- Our new link will have all the properties of a regular PPP interface but will have a multi-link ppp encapsulation. The links will be assigned as multiple unit numbers. In the following configuration, the bundle will be assigned to unit 0:
ls0-0/0/0{
unit 0{
encapsulation multilink-ppp;
family inet{
address 172.8.17.30/30;
}
}
}
Next we will configure the links and link service interface. Interfaces se-1/0/0 and se-1/0/1 are added to the bundle on the ls-0/0/0 interface. (Our link service logical interface.)
se1/0/0{
unit 0{
family mlppp{
bundle ls-0/0/0;
}
}
}
se-0/0/1{
unit 0{
family mlppp{
bundle ls-0/0/0.0;
}
}
}
We can verify the status of our newly created bundle with the show interfaces terse command. The link service interface will remain in the up state as long as one of our physical interfaces is up. This behaviour can be modified with the minimum-links command in the link service interface hierarchy.
While we are on the subject of protocols and their associated encapsulations, let's delve into Generic Routing Encapsulation. GRE is a "stateless" tunneling protocol. Stateless in this context refers to a connection that is created with no monitoring of the endpoint or other tunnel endpoints. It is mostly used in conjunction with Virtual Private networks or VPNs. It can also be used to establish back up links to a location or to carry non IP traffic over an IP network (Frame Relay,ATM, or Ethernet.)
In order to create a GRE tunnel, a Juniper device must be equipped with the Layer 2 services PIC (M and T-Series) or is native in the J-Series platform. When you activate the service, a pseudo interface called 'gr' is created. You need three things in terms of configuration to make our new interface useful:
- inteface must be configured with the source IP for the GRE packets (where they are originating from)
- The tunnel's destination
- Protocols that the GRE will carry (An IP address for the 'gr' interface is not required, but is good to have for management purposes.)
Note: Remember the gre interface is used by the router internally and should not be configured to be a GRE tunnel.
Here is an example of a configured gr interface for GRE:
gr-0/0/0{
unit 0
tunnel{
source 10.20.1.38;
destination 172.66.13.1
}
family inet
}
}
Now all that remains, is to map traffic for use by the GRE tunnel. You can do this with a static route with a destination next-hop address of the gr interface, or using a protocol such as OSPF(Open Shortest Path First.)
Tuesday, June 24, 2008
My Lines, My Lines!
Acronym of the Moment:
DSLAM: Digital Subscriber Line Access Multiplexer (Concentrates multiple DSL connections together)
ADSL: Asymmetrical Digital Subscriber Line
POTS: Plain Old Telephone Service
SHDSL: Symmetric High speed Digital Subscriber Line
PPPoE: Point to Point Over Ethernet
DSL is one of the most popular connection media for consumers and companies alike. DSL runs over existing POTS wiring with the use of a DSL modem. This connection feeds into a telephone company's DSLAM. Some J-Series routers have support for ADSL using PPPoE over ATM applications. The interfaces will appear to be ATM connections, but do not support native ATM, only ATM over DSL. Let's take a look at the following example:
[edit]
labuser@labrouter#show interfaces
at-6/0/0 {
encapsulation ethernet-over-atm;
atm-options {
vpi 0;
}
dsl-options {
operating-mode auto;
}
unit 0; {
encapsulation ppp-over-ether-over atm-llc;
vci 0.39;
}
}
Our J-Series Lab router has an ADSL Annex A PIM installed on slot 6. (Annex A is DSL over POTS, Annex B is DSL over ISDN respectively.) The lab router will be a client to our phone company's DSL multiplexer so that the Lab router can act as a DSL modem. As shown in the example above, we are using PPPoe over ATM for our DSL. We need configuration for the physical interface at-6/0/0. and a logical interface. You will notice in our configuration that there is a vci and vpi statement.
VPI is Virtual Path Identifier and VCI is a Virtual Channel Identifier and these must be the same as what is configured at the DSLAM. The remainder of the parameters can be learned from the DSLAM with the operating mode auto statement.
"On to Our Logical Interface...."
Now that we have our ATM interface, we now will configure an internal PPPoE interface and its' mappings. We need to map our physical interface where PPPoE will be running, the access server, and underlying requested services. See Below:
pp0{
unit 0{
pppoe-options{
underlying-interface at-6/0/0.0;
access-concentrator labisp;
service-name pppserv@labisp;
auto-reconnect 5;
}
family inet{
negotiate-address
}
}
}
}
You can verify your new connection with run show pppoe interfaces.
ISDN is a protocol designed to run over the public telephone network. Like Frame Relay, ISDN is seeing less deployment with the emergence of DSL and other broadband technologies. Just like in our previous example, ISDN on a Juniper router requires a logical interface and a physical one. Our physical interface, br which will contain the dialing number and switch type. In our lab router br-0/0/4 will be configured with a switch type of etsi for Europe NET3. Also, a dial pool we create will map our physical interface to a logical unit in our dialer interface. First we configure our physical interface:
[edit interfaces]
br-0/0/4{
isdn-options{
switch-type etsi;
}
dialer-options{
pool labpool1;
}
}
Now on to the dialer interface which contains our number we need a number to dial, an IP address, and our pool mapping our logical interface to br-0/0/4... dl0 will be our dialer interface and we will set up our "dialer filter" to establish a connection only when there is "interesting traffic" (More on this in a moment.)
dl0{
unit 0{
dialer-options{
pool labpool1;
dial-string 5559999;
}
family inet{
filter{
dialer dial_filter;
}
address 12.12.20.1/24;
}
}
}
Here is our simple dialer filter "dial_filter" that brings up our connection any time packets are destined for 12.12.20.2 using the note action. All other destinations are ignored in term b without a corresponding from statement.
[edit]
firewall{
family inet{
dialer-filter dial_filter{
term a{
from{
destination-address{
12.12.20.1/24
}
}
then note;
}
term b{
then ignore;
}
}
}
}
ISDN is commonly used as a backup link for other interfaces if they fail. To configure the ISDN as backup, the dl0 interface can be mapped to our interface requiring backup. The interface we are backing up is fe-0/0/1:
[edit interfaces fe-0/0/1 unit 0]
backup-options{
interface dl0.0;
}
Presumably, the ISDN interface would stay up even if the entire path is not reachable. It is also wise to configure a list of reachable IP networks when interfaces are working normally. In our lab example, a single network of 13.13.20.0/24 is used to verify connectivity with the use of a watch list.
dl0{
unit 0{
dialer-options{
pool labpool1;
dial-string 5559999;
watch-list{
13.13.20.0/24;
}
}
family inet{
address 13.13.20.1/24;
}
}
}
You can make calls between ISDN devices. To accept a call, an incoming dialer map can be configured on dl0:
dl0{
unit 0{
dialer-options{
pool labpool1;
incoming-map;
watch-list{
caller 384030;
}
}
family inet{
address 12.12.20.1/24;
}
}
}
You can use the show isdn and show dialer commands to verify the interface is working. show isdn will verify Layers 1-3 connectivity and switch type. show dialer will indicate per channel status.
Monday, June 23, 2008
VLAN Tagging, You're It!
- root@routername#configure
- edit interfaces fe-2/0/1
- set vlan-tagging
- Next we add a VLAN ID of 100 on our logical unit 0: root@routername#set unit 0 vlan-id 100
- show our new configuration with the show command
Caution! Juniper routers DO NOT have a default VLAN! Every VLAN must be explicitly configured. Many switches have a default VLAN of 1. Make sure to configure a vlan-id of 1 for connectivity.
It is a common "best practice" to have th einterface unit number be the same as the VLAN ID, so we change the unit number with the rename unit 0 to unit 100 command. Let's activate the change with root@routername#commit To retest for connectivity, issue run ping 10.10.20.121 count 3 When it succeeds, we can view our interface with run show interfaces terse fe-2/0/1
Now let us move on to T1 interfaces...
T1 is a very extensively used signaling method in North America. For point-to-point links on Juniper devices, the default encapsulation is PPP. This differs with many other vendor's equipment whose default encapsulation is Cisco HDLC (There is a standard HDLC protocol, but it did not have multi-protocol support. Cisco's HDLC implementation is "officially" proprietary, but the workings are well known and supported by many vendors.) Here is a configuration example for a T1 interface.
- edit interfaces t1-0/0/2
- set encapsulation cisco-hdlc
- set unit 0 family inet address 10.10.20.122/24
- commit
Acronyms of the Moment:
DTE: Data Terminal Equipment
DCE: Data-circuit Terminal Equipment
"Serial is not Breakfast!"
Serial interfaces have a variety of physical forms such as, V.35, X.21, and EIA 530. V.35 is most commonly seen in the United States and X.21 is common in Japan. All serial interfaces define their connection in terms of a DCE and a DTE. DCE devices provide clocking signals, encoding, and signal conversion to the DTE. Normally routers will default to DTE mode by default until wired up and a DCE(female cable) is detected.
Let's view our DCE status with the run show interfaces se-1/0/0 extensive find "serial media" command. The DTE/DCE detection can be found in the local mode field.
Note: Proper care must be taken to configure the correct clock mode. Without proper clocking, the link status will be considered "down."
Under the [serial-options] in the [edit interfaces] hierarchy a clocking-mode may be set. The default is internal or loop timed, and the clock rate is 8Mhz
"Serial with Frame Relay"
Frame Relay is a Layer 2 enapsulation method that allows a LAN connection via a Wide Area Network Connection (WAN) to a Frame Relay node. Frame Relay uses Permanent Virtual Circuit (PVC) tunnelling over an Internet Service Provider's infrastructure to provide the LAN's connectivity.
Acronyms of the Moment:
DSL: Digital Subscriber Line
DLCI: Data Link Circuit Identifier
With the widespread emergence of other broadband technologies such as DSL and IP networks, Frame Relay is mostly seen in rural areas as a cheap "always on" service. To establish a Frame Relay connection, the frame-relay encapsualtion is set, along with a local circuit identifier for the PVC in the form of a DLCI.
- edit interface se-1/0/0
- set unit 645 family inet address 172.17.24.130/30
- set encapsulation frame-relay
- set dlci 645
- commit
Note: No routers were harmed in the making of this blog ;-)
Friday, June 20, 2008
Logical Versus Physical
- Clocking: Aligns bits as they are transmitted out of the interface. A clock signal can be supplied by a Service Provider or by the router.
- Encapsulation: Layer 2 encapsulation used on the interface. Examples include Frame Relay, Point to Point Protocol or PPP, and Cisco Highlevel Data Link Control or HDLC
- MTU: Maximum Transmission Unit, which is the maximum size of the frame transmitted from the interface.
- Keepalives: Used to verify the operation of the interface. Most encapsulations enable keepalives by default, but they can be disabled to aid troubleshooting.
- Layer 1/2 Options: Various bit and byte settings for the interface media such as framing, flow control, and source address filters
All router interfaces sending and recieving traffic or packets require a logical unit to be configured. This way, an interface may be divided into multiple logical interfaces (subinterfaces in Cisco) This division then could be used to create multiple Virtual Local Area Networks or VLANs with their own logical unit. Note: Many router vendors do not require a subinterface or logical unit on every physical interface but a Juniper router does. Even point-to-point interfaces and non VLAN tagged interfaces need a logical unit to be configured.
In JUNOS, unit numbers MUST be configured before any other logical configuration is applied. Here are some of the common logical properties that can be configured.
- Protocol Family refers to the Layer 3 protocols that can be sent and recieved on this interface. The most common is family inet. Other protocol amilies include IPv6, Multi Protocol Label Switching or MPLS, and ISO (Intermediate System to Intermediate System IS-IS)
- Protocol Address: Layer 3 family address such as family inet (IP address)
- Virtual Circuit Address: Circuit identifier use when an interface is divided logically. Logical interfaces include VLAN IDs, Frame Relay Data Link Connection Identifier or DLCI, or ATM virtual path/Virtual Connection Identifiers (VP/VCI)
- Logical unit numbers can range from 0-16,385
- The best practice is to keep circuit address the same as the unit number for ease of toubleshooting.
- Note: If you are configuring a point to point interface the unit number MUST be zero!
"More Interface Configuration Examples"
Let's demonstrate configuring a Fast Ethernet interface in JUNOS:
Note: Remember interfaces in JUNOS are 'automatically enabled' when the physical connection is wired. So, after cabling up, we check the status of our Fast Ethernet Interface:
- root@routername> show interfaces terse fe-2/0/1
- Once we determine that the interface is up, we enter configuration mode: root@routername#configure
- We are brought to the [edit] hierarchy and now, to edit our interface: root@routername# edit interfaces fe-2/0/1
- Establish the unit: root@routername#set unit 0 family inet address 10.10.20.122/24
- JUNOS software requires a mask for every IP address in the classless CIDR notation (Classless Inter Domain Routing). This is denoted by the / (slash)
- Execute a show command: root@routername#show to verify our newly created interface
- Activate our new changes with commit: root@routername# commit-and-quit
- Let's verify our newly created interface with ping: root@routername#ping 10.10.20.121 count 3
The reason for the count command with ping is, a Juniper router will send an endless number of pings unless a number of packets is specified or you use Ctrl-C
Thursday, June 19, 2008
The shape of things to come...
For now, let's talk a bit about the way interfaces are named in the Juniper world. The convention for all JUNOS interfaces is the interface name followed by three numbers that indicate the interface's physical location. It is in the form MM-F/P/T where:
- MM: is the media type
- F: is the chassis slot number
- P: PIC slot number
- T: Port number
Listed here are a few common media types and a little bit about them:
- ae: Aggregated Ethernet which is a logical link of multiple Ethernet interfaces (IEEE 802.3ad Analogous to Etherchannel in Cisco)
- at: ATM (Asynchronous Transfer Mode) sends fixed-length 53 byte cells over the transport media. Also can be use for ATM over Digital Subscriber Lines (DSL)
- br: Integrated Services Digital Network (ISDN)
- e1: Standard digital communication over copper at 2.048Mbps (Used in Europe)
- e3: Standard digital communication over copper at 34.368Mbps (Used in Europe)
- t1: Physical layer standard used extensively in North America (Digital signal level 1) at 1.544Mbps
- t3: Physical layer standard used extensively in North America (Digital signal level 3) at 44.736Mbps
- fe: 100Mbps standard created by Xerox in the 1970s, referred to as a Local Area Network or LAN
- ge: High speed Ethernet standard at 1 or 10 Gbps
- se: Serial one bit at a time communication (EIA 530,V.35, X.21)
- ct1: T1 interface divided into 24 DS0 channels (DS0 is 56 kbps)
The 'F' in the interface name represents a chassis slot number
- On an M-Series router it is represented by a Flexible PIC Concentrator slot number, with two possible slot orientations horizontal or vertical. For the M40e and M320 are vertically mounted starting with slot 0 and counting from left to right. The smaller M7i and M10i are horizontally mounted starting with 0 and counting from top to bottom
- Note: The M7i slot 1 is reserved for the Fixed Interface Card slots
- A J-Series router has PIMs instead of PICs because the RE is implemented in software.
- For a J-Series router, all fixed ports live in slot zero, and PIM slots are numbered 1-6 from top to bottom and left to right.
The PIC slot number is represented by the letter P. In the M-Series routers four PICs can fit into one Flexible PIC concentrator slot starting at 0 and going to slot 3. The direction of PIC slot numbering is dependant on the chassis orientation whether horizontal or vertical. Let's explore this in a little more detail:
- In the vertical M-Series chassis orientation, PIC slots are counted 0.1,2,3 top to bottom
- For the horizontal M-Series like the M7i and M10i, PIC numbering is right to left 0,1,2,3
- Thing of note: For the M7i second FPC slot, only two possible slot numbers exist, one for a built-in tunnel interface or an ASM (Adaptive Services Module) and slot three is for Fixed Ethernet interfaces.
- In the J-Series there are no PIC slots so the F naming convention for interface naming is always set to zero
The last part of the interface name represented by the letter T is the physical port. There are various ways the physical ports are numbered, depending on the PIC and router model.
- For vertical chassis orientations like the M40e and M320 port numbers begin in the top right of the chassis and move from the bottom to the top and then left to right.
- For horizontal chassis orientations like the M20, M7i, and M10i port numbers begin in the bottom right of the chassis and move right to left then, bottom to top.
- Note: To avoid confusion, the port numbers are always written on the PICs themselves
- Fixed Ethernet ports in the M7i from right to left starting at zero
- For the J-Series, ALL ports are numbered left to right
Here I will list a few M-Series example interfaces to show the interface numbering more clearly:
se-1/0/0 : Serial interface FPC slot 1 , PIC slot 0, port 0
fe-0/2/1 : Fast Ethernet interface in FPC slot 0, PIC slot 2, port 2 (remember port numbering starts with 0!)
t1-1/0/1 : T1 interface in FPC slot 1, PIC slot zero, port 2
In the next section we will begin Interface Properties in JUNOS....