Putting the i(Series) in TCP/IP

General
Typography
  • Smaller Small Medium Big Bigger
  • Default Helvetica Segoe Georgia Times

IBM introduced TCP/IP protocol on the AS/400 with OS/400 V3R2. Still today, however, this protocol remains underutilized even though many iSeries TCP/IP applications have been added, including a Dynamic Host Configuration Protocol (DHCP) server and a Domain Name System (DNS) server. Today, the iSeries supports many TCP/IP applications you may not be aware of. In this article, we'll look at some of these applications and explore how to make the most of TCP/IP.

Your TCP/IP Configuration

Before we examine the TCP/IP "goodies," let's look at some of the components of your TCP/IP configuration. Navigate to the Configure TCP/IP menu by typing the command CFGTCP. Figure 1 shows the menu that is displayed.

http://www.mcpressonline.com/articles/images/2002/tcpip--091304--V400.png

Figure 1: This menu contains the options to configure TCP/IP. (Click images to enlarge.)

Option 1 displays the Work with TCP/IP Interfaces display, which is used to configure options related to each interface. When you modify interfaces through this display, you'll see the screen shown in Figure 2.

http://www.mcpressonline.com/articles/images/2002/tcpip--091304--V401.png

Figure 2: Use this screen to modify a TCP/IP interface.

On this screen, the Line Description can contain either the name of a previously created line description or special values *VIRTUALIP, *OPC, or *LOOPBACK. One unusual capability when creating a TCP/IP interface on the iSeries is that you can define two unique IP addresses to a single Ethernet adapter. This means that you can actually have your iSeries accessible to two distinct and separate subnets. Figure 3 illustrates this using the Work with TCP/IP Interfaces display.

http://www.mcpressonline.com/articles/images/2002/tcpip--091304--V402.png

Figure 3: A single iSeries Ethernet line can be assigned multiple IP addresses.

Notice that IP addresses 90.0.0.3 and 192.168.50.11 are both assigned to line ETHLINE. Based on the subnet masking shown, an IP address in the range of 90.0.0.1 through 90.254.254.254 will be able to access the system through address 90.0.0.3. Again, based on the subnet mask defined, any computer with an IP address in the range of 192.168.50.1 through 192.168.50.254 will have access to the system through IP address 192.168.50.11. Option 2 on this menu defines TCP/IP routes to other networks. If, for example, your iSeries existed on a TCP/IP network 192.168.50.0 with a subnet mask of 255.255.255.0 and you needed to give iSeries access to a network 192.168.51.0 with a subnet mask of 255.255.255.0, which is accessed through a router with an IP address of 192.168.50.254, you would use the ADDTCPRTE command to add a route for this network:

ADDTCPRTE RTEDEST('192.168.51.0')    
          SUBNETMASK('255.255.255.0')
          NEXTHOP('192.168.50.254')  

Alternatively, if the iSeries was in TCP/IP network 192.168.50.0 with a proxy server at IP address 192.168.50.1, you could configure the iSeries to allow Internet access by creating a default route using this command:

ADDTCPRTE RTEDEST('*DFTROUTE')    
          SUBNETMASK('*NONE')     
          NEXTHOP('192.168.50.1')  

TCP/IP port restrictions are defined through option 4 on the CFGTCP menu. You can use this screen to restrict access to specific TCP/IP services by user. Figure 4 shows the Work with TCP/IP Port Restrictions display.

http://www.mcpressonline.com/articles/images/2002/tcpip--091304--V403.png

Figure 4: With port restrictions, you can control access to a specific TCP/IP application.

You can specify a lower and upper port number as well as whether the application is TCP or UDP protocol. If a port restriction is created for a given port or range of ports, only the user specified will have access to the defined port or ports. In the example above, the user MFAUST will be the only one with access to ports 20 and 21, which are generally used for the FTP service. This leads us to the topic of TCP/IP applications.

iSeries TCP/IP Applications

The iSeries has a complete set of standard TCP/IP applications, yet I'm constantly amazed by how underutilized those applications are in most iSeries shops. The following table contains a list of the standard TCP/IP applications on the iSeries. Many of these applications will look familiar. Others may not.

Service/Application
Description
FTP
File Transfer Protocol. Used to send and receive files to and from an iSeries.
TELNET
Terminal emulation protocol used to log into the iSeries or remote systems.
HTTP
Hypertext Transfer Protocol. Used by Internet browser-based applications.
DNS
Domain Name Service. Used to keep track of server names and associated IP addresses.
DHCP
Dynamic Host Configuration Protocol. Used to automatically configure TCP/IP network clients based on parameters defined on the DHCP server.
POP
Post Office Protocol. Used to retrieve email from an Internet mail server.
SNMP
Simple Network Management Protocol. Allows TCP/IP-based devices (computers, printers, routers) to be monitored using a single protocol.
SMTP
Simple Mail Transfer Protocol. Also used for email purposes, generally used to send messages to an Internet mail server.
REXEC
Remote execution command protocol. Allows commands to be issued from a client to execute on the server.
BOOTP
Bootstrap Protocol. Similar to DHCP. Used to assign IP addresses to network-connected devices.
LPD
Line Printer Daemon protocol. The TCP/IP standard for sending data to a network-connected printer within a TCP/IP network.

FTP

FTP is commonly used to download files from Internet Web sites. What you may not know is that you can also use FTP to execute commands and call programs on the iSeries. This is extremely useful when you want to create a process that will run a program on the iSeries to create a data file to be downloaded. Here's an example:

open 192.168.50.11
mfaust
secret
quot RCMD ADDLIBLE QTEMP
quot RCMD ADDLIBLE MYLIB
quot RCMD CALL BLDFTPDTA
get ftpfile.ftpmbr ftpfile.txt
quit

This sample FTP script starts by connecting to the system at IP address 192.168.50.11. The next two lines send the user name and password to be used to log into the system. Next, the FTP command QUOT is used with the ADDLIBLE command to add any required libraries to the current FTP session's library list. The QUOT FTP command allows us to run OS/400 commands from an FTP session. The FTP session works much like a Client Access 5250 session or Telnet session in that, when you log in, your session receives a default library list that is currently defined on the QFTP job description. Any libraries added to this library list (as in the example) will remain in the session library list until the session is logged out or ended. The next command in the script again uses the QUOT command to execute the command CALL BLDFTPDTA, which would be a program to build the data to be downloaded. Then, the FTP command "get ftpfile.ftpmbr ftpfile.txt" retrieves the contents of the physical file named ftpfile with the physical file member named ftpmbr into the PC file ftpfile.txt. Finally, the quit command ends the FTP session.

This technique could be modified slightly to send data to the iSeries and then run a program to process the data sent. This would be done by first replacing the "get" command with a "send ftpfile.txt ftpfile.ftpmbr" command and then moving the QUOT CALL command to after the new send command. You can execute this script from a Windows-based PC client by using the FTP command's –S option:

FTP –S c:myftpscp.scp

Telnet

Telnet protocol is used by within the Personal Communications portion of iSeries Access for Windows for terminal emulation purposes. What you may not realize is that most other terminal emulators will also allow you to access an interactive display session on the iSeries. To do this from a Windows workstation, simply go to a command prompt and type this:

TELNET 192.168.50.11

When this statement is executed, a connection will be attempted to the specified IP. Since the destination system is an iSeries, an iSeries sign-on screen will be displayed for this IP address (Figure 5).

http://www.mcpressonline.com/articles/images/2002/tcpip--091304--V404.png

Figure 5: A sign-on display from a Telnet session looks like this.

The drawback to using the Windows Telnet client for this type of connection is that the keyboard mapping does not conform to iSeries standards. This means that function keys and other control keys have to be sent using unusual key sequences. "Roll up," for example, is achieved by pressing CTRL+U, while CTRL+D is "Roll down." The current key mapping info can be viewed via the DSPVTMAP command when signed into the iSeries from a VT100 Telnet client. The following table shows the standard keyboard mappings.

Standard Keyboard Mappings
5250 Function
VT Key(s)
5250 Function
VT Key(s)
5250 Attention
CTRL-A or ESC+A
Redraw Screen
CTRL-L or ESC+L
5250 Help
CTRL-? Or ESC+H
F1
ESC-1 or F1
Page Down (Roll Up)
CTRL-D or CTRL-F
F2
ESC-2 or F2
Page Up (Roll Down)
CTRL-B or CTRL-U
F3
ESC-3 or F3
System Request
CTRL-C or ESC+S
F4
ESC-4 or F4
Insert
ESC+I or ESC+DEL or INSERT
F5
ESC-5
Delete
DEL
F6
ESC-6
Enter
RETURN
F7
ESC-7
Backspace
BACKSPC
F8
ESC-8
Duplicate
ESC+D
F9
ESC-9
Erase Input
CTRL-E
F10
ESC-0
Error Reset
CTRL-R or ESC+R
F11
ESC--
Field Exit
CTRL-K or CTRL-X or ESC+X
F12
ESC-=
Field Minus
ESC+M
F13
ESC-!
Home
CTRL-O
F14
ESC-@
New Line
ESC+Line Feed
F15
ESC-#
Print
CTRL-P or ESC+P
F16
ESC-$
Field Advance
TAB
F17
ESC-%
Field Backspace
ESC+TAB
F18
ESC-^
Cursor Up
Up arrow
F19
ESC-&
Cursor Down
Down Arroe
F20
ESC-*
Cursor Left
Left Arrow
F21
ESC-(
Cursor Right
Right Arrow
F22
ESC-)
Clear Screen
ESC+C
F23
ESC-_
Test Request
CTRL-T
F24
ESC-+
Toggle Indicator Lights
ESC+T



Despite the keyboard mapping issue, this can be useful when you need to access the iSeries from a PC that doesn't have iSeries Access for Windows installed. Since most "non-Windows" operating systems include a Telnet client, this can also be an option for accessing an iSeries from a machine running Linux or UNIX.

HTTP

HTTP is used by WebSphere and the other iSeries Web server options (Apache, Tomcat, etc.). This has become one of the more commonly used iSeries TCP/IP components, and with good reason. The universal appeal of Web browser interfaces in addition to the multitude of options now available for developing HTTP browser-based applications on the iSeries make this a great alternative for developing iSeries applications. Conveniently, the iSeries includes an administrative console that is (ironically enough) browser-based. You can access this application from your Web browser through port 2001 by navigating to http://xxx.xxx.xxx.xxx:2001/, where xxx.xxx.xxx.xxx represents the IP address of your iSeries. Figure 6 shows the browser-based admin tool for the iSeries Web server.

http://www.mcpressonline.com/articles/images/2002/tcpip--091304--V405.png

Figure 6: This is the browser-based HTTP admin console.

From this console, you can configure Web servers as well as start and stop individual server instances.

LPD

LPD servers not only allow iSeries printers to be accessed from a TCP/IP client, but also allow the iSeries to access any network-connected, TCP/IP-enabled printer, including printers connected through general-purpose interface boxes like the HP Jetdirect printer server boxes. When configuring these devices, you have two separate options: creating a *LAN device description for the printer or creating a remote output queue. To configure a device description as *LAN, the print server must support either IBM or HP Printer Job Languages (PJL) by defining the System Driver Program (SYSDRVPGM) parameter as either *IBMPJLDRV or *HPPJLDRV on the CRTDEVPRT command. Here's an example:

CRTDEVPRT DEVD(LDPPRT01) DEVCLS(*LAN) TYPE(3812) MODEL(1)    
     LANATTACH(*IP) PORT(9100) FONT(11)                  
     TRANSFORM(*YES) MFRTYPMDL(*HPPCL6) 
     RMTLOCNAME('192.168.50.1')    

This command creates a printer device description for a LAN-attached HP/PCL6-compatible IP printer named LPDPRT01 at IP address 192.168.50.1. Older print server devices that do not support either of these options can also be used for iSeries printing by using the CRTOUTQ command:

CRTOUTQ OUTQ(RMTQUENAME) RMTSYS(*INTNETADR) RMTPRTQ(PR1)  
        CNNTYPE(*IP) DESTTYPE(*OTHER) MFRTYPMDL(*HPLJIII)     
        INTNETADR('192.168.50.99')

Replace RMTQUENAME with a name identifying your printer and replace 192.168.50.99 with the IP address of your printer. You can also use the MFRTYPMDL parameter to define the manufacturer type and model number of the printer being defined. And you can use the RMTPRTQ option to define the name of the specific port to which the printer is connected in the case of multi-port printer servers. With this option, you can also specify a shared printer name when connecting to a printer on an iSeries or Windows printer server. This is where using the iSeries as a TCP/IP printer server comes into play. For example, you can send a text file from a Windows-based PC to an iSeries printer using this LPR command:

LPR MYFILE.TXT –S xxx.xxx.xxx.xxx –P prtdevname

Here, xxx.xxx.xxx.xxx represents the iSeries IP address and prtdevname represents the printer device description on the iSeries. You can also create an LPR port that points to an iSeries printer from a Windows-based PC. To add a generic text printer using this method, go to the Windows control panel and select Add Printer. When the wizard is displayed, click Next and identify that you are installing a local printer. (This may not make sense, but Windows looks at an LPR printer device as a local printer port, not a network printer.) Then, select the Create a New Port radio button and choose the LPR Port option from the drop-down box. You'll see the dialog shown in Figure 7.

http://www.mcpressonline.com/articles/images/2002/tcpip--091304--V406.png

Figure 7: Use this dialog when adding an LPR port to the iSeries in Windows.

On this dialog, the first box defines the IP address of your iSeries. The second box identifies the name of the device description for the corresponding iSeries printer. Click OK, and the wizard will prompt you for the device manufacturer's name and model. After you select the appropriate printer from the provided list, your new printer will be installed.

SMTP

The iSeries also has the ability to send Internet email messages using SMTP. The configuration requirements are minimal and begin with using the CHGSMTPA command:

CHGSMTPA MAILROUTER('192.168.50.3')

The IP address shown represents the IP address of the server used to relay Internet email messages on your network. Next, use the ADDDIRE command to create a gateway for sending messages to the mail server:

ADDDIRE USRID(INTERNET GATEWAY) USRD('Context switching entry')  SYSNAME(TCPIP) MSFSRVLVL(*USRIDX) PREFADR(NETUSRID *IBM ATCONTXT)

Finally, use the CHGDSTA command to define the route to your SMTP server:

CHGDSTA SMTPRTE(INTERNET GATEWAY)

This command uses the previously created directory entry as the route for any SMTP email messages. Once you've made these configuration changes, you can send messages using the SNDDST command:

SNDDST TYPE(*LMSG) TOINTNET((This email address is being protected from spambots. You need JavaScript enabled to view it.')) 
       DSTD('Test SMTP Message')                             
       LONGMSG('This is a test message to illustrate how easy 
                it is to configure the iSeries for sending  
                SMTP Internet mail messages.')               

After you replace the sample email address with a valid Internet email address, the message is sent to the desired recipient.

For more information on using the iSeries for SMTP, see The iSeries and AS/400 Programmer's Guide to Cool Things.

These are just a few examples of the powerful TCP/IP-based applications available. In addition to these canned applications, you can create your own custom IP-enabled applications using the iSeries Socket APIs. When you consider all of the IP options available, it's easy to see why IBM put the i(Series) in TCP/IP.

Mike Faust is an Application Programmer for Fidelity Integrated Financial Solutions in Maitland, Florida. Mike is also the author of the books The iSeries and AS/400 Programmer's Guide to Cool Things and Active Server Pages Primer. You can contact Mike at This email address is being protected from spambots. You need JavaScript enabled to view it..


BLOG COMMENTS POWERED BY DISQUS

LATEST COMMENTS

Support MC Press Online

$0.00 Raised:
$