The EntireX RPC Server under IBM i enables you to call programs as servers, using ILE (Integrated Language Environment).
Note:
The EntireX RPC server installation also includes sample programs
that demonstrate how to build and use an RPC client environment on IBM i. For
details, see Installation Verification and Using the COBOL Wrapper.
This document describes how to install the RPC server under IBM i.
It covers the following topics:
See Platform Coverage for full platform information.
The implementation under IBM i is based on the UNIX code, therefore, use the UNIX parameters for the IBM i environment, see Setting up Broker Instances. However, some features provided under UNIX are not supported under IBM i, see Features Currently not Supported.
Secure Sockets Layer (SSL) is currently not supported.
Note:
vrsp stands for the current version,
release, service pack, and optionally a patch level.
Installation comprises the following steps:
A successful Broker ACI installation on your IBM i machine is a prerequisite to install the RPC server. Software AG recommends you to keep the RPC server environment in the library EXX, in which your Broker ACI was installed.
If this library does not yet exist, create it with the command
CRTLIB EXX
.
The product is delivered in a data set with the name ../OS400/EXPvrsp on your EntireX installation DVD.
To copy the installation file to your IBM i disk
Use the command CRTSAVF
to create an empty IBM i *SAVF
file,
named EXP vrsp, on your IBM i
machine in a library of your choice.
Use FTP to transfer the unzipped PC file EXP vrsp to the corresponding IBM i save file using the FTP option "binary".
To verify the contents of the *SAVF
file
EXPvrsp
Use the IBM i command DSPSAVF
. The command should display the
following objects:
To restore the *SAVF file
Use the command RSTLIB
:
RSTLIB SAVLIB(EXPvrsp) DEV(*SAVF) SAVF(yoursavlib/EXPvrsp) RSTLIB(EXX)
where yoursavlib denotes the library into which you transferred the save file during Step 2.
In addition to the Broker ACI installation, the product library EXX should now contain the objects listed in Step 3.
Software AG recommends you not having user objects in this library. Copy modified samples to the user libraries. Source samples mentioned here may change, therefore check all associated program objects for the latest version.
The EntireX RPC server for IBM i is now installed and ready to use.
The verification is based on the EntireX RPC calculation example CALC in the IDL file example.idl, which is common for all platforms. The IBM i library EXAMPLE provides programs that allow you to test a COBOL RPC client and to run the RPC server with a COBOL or a C application service.
The verification comprises the following steps:
Note:
RPG source examples are currently not provided for the installation
verification.
Prerequisite for all verifications:
The service program EXA (type *SRVPGM, the Broker ACI/stub) must be available in your library list. You can accomplish this task by adding EXX, where the Broker ACI and the RPC server are usually installed, to your library list.
Before you can begin the verification, you must restore the IBM i library EXAMPLE from the save file EXAMPLE that you downloaded to library EXX during Step 3.
To restore the *SAVF example file, use the command RSTLIB
:
RSTLIB SAVLIB(EXAMPLE) DEV(*SAVF) SAVF(EXX/EXAMPLE) RSTLIB(EXAMPLE)
The newly created library EXAMPLE should contain the following objects:
Object | Type | Used by example | Description | ||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
CALC |
*PGM |
COBOL server, see Step 3: Verify the RPC Server using COBOL | COBOL server calculation engine (created with
BIND_CALC ).
|
||||||||||||||||
CALC_RPG |
*PGM |
RPC server | RPG Server calculation engine (created with BIND_RCALC ).
|
||||||||||||||||
CALCCLIENT |
*PGM |
COBOL client, see Step 2: Verify the RPC COBOL Client | COBOL client calculation dialog (created with BINDCCALC ). Contains the modules CCALCMAIN , CCALCMENU , CCALC and RPCSRVI .
|
||||||||||||||||
CRT_CBLMOD |
*PGM |
all COBOL | Procedure to compile/create COBOL modules. | ||||||||||||||||
CRT_C_SRV |
*PGM |
all C | Procedure to create modules and service programs of DEXAMPLE
and EXAMPLE for the C Server.
|
||||||||||||||||
BIND_CALC |
*PGM |
COBOL server, see Step 3: Verify the RPC Server using COBOL | Procedure to compile and bind the COBOL server. | ||||||||||||||||
BIND_CCALC |
*PGM |
COBOL client, see Step 2: Verify the RPC COBOL Client | Procedure to compile and bind the COBOL client. | ||||||||||||||||
BIND_RCALC |
*PGM |
RPG Server | Procedure to compile and bind the RPG Server. | ||||||||||||||||
STR_RPCSRV |
*PGM |
all Server | Procedure to start the EntireX RPC server. | ||||||||||||||||
X_DEXAMPLE |
*SRVPGM |
C Server, see COBOL client, see Step 4: Verify the RPC Server using C | C Server generated stub service. To use it, rename to
DEXAMPLE .
|
||||||||||||||||
X_EXAMPLE |
*SRVPGM |
C Server, see COBOL client, see Step 4: Verify the RPC Server using C | C Server implementation file. This service contains the application logic of the programs CALC ,
HELLO and POWER . To use it, rename to EXAMPLE .
|
||||||||||||||||
CCALCMENU |
*FILE (DSPF) |
COBOL client, see Step 2: Verify the RPC COBOL Client | COBOL client dialog screen. | ||||||||||||||||
CALC |
*MODULE |
COBOL client, see Step 2: Verify the RPC COBOL Client | COBOL server calculation engine. | ||||||||||||||||
QCBLLESRC |
*FILE (PF-SRC) |
all COBOL |
|
||||||||||||||||
*FILE (PF-SRC) |
all |
|
|||||||||||||||||
QCSRC |
*FILE (PF-SRC) |
all C |
|
||||||||||||||||
H |
*FILE (PF-SRC) |
all C | C header files. It contains the generated stub header
CEXAMPLE.h .
|
||||||||||||||||
QRPGLESRC |
*FILE (PF-SRC) |
all RPG |
|
In your EntireX network environment, the RPC server program CALC
must
be available for calculating figures. Examples of a CALC
server program are
provided in C and in
COBOL.
You can also access the sample CALC
programs installed on your IBM i computer
as described in
Step 3 and
Step 4 below.
To verify the COBOL client
Add the sample library EXAMPLE to your library list.
Call program CALCCLIENT
.
A menu similar to the following will be displayed:
Calculator Menu ----------------------------------------------------- Operation: + (type + - * / to calculate or type . to terminate) Operand 1: _____ Operand 2: _____ Result: ___________ Broker-ID: localhost:1971 Server: SRV1
Specify the ID of the remote Broker and the name of the server that
provides the CALC
program. Specify the figures you want to compute and press
. If the Broker connection fails, you will receive an appropriate error
message.
The following modules/files are bound to program CALCCLIENT
:
Object | Description |
---|---|
CCALCMAIN |
The main program logic. |
CCALCMENU |
The menu display file. |
CCALC |
The client stub derived from CobolClient1.tpl. |
RPCSRVI |
The client runtime derived from CobolClient2.tpl. |
ERXCOMM |
RPC communication area copybook. |
EXA |
The Broker ACI (stub). |
All sources are located in the file EXAMPLE/QCBLLESRC.
Use the procedure BIND_CCALC
to recompile and rebind the modules.
Note:
Program CALCCLIENT
expects the server program CALC
to be located in
a library named EXAMPLE (as specified in the client stub CCALC). If your CALC
program is located in a different library, you must adjust member
EXAMPLE/QCBLLESRC(CCALC)
. Modify all occurrences of the string "EXAMPLE" to
your library name and adapt the associated string length. Then compile and
rebind the CALCCLIENT
program.
To verify the RPC server under IBM i, you can use the COBOL server
program CALC
located in library EXAMPLE. When requested by a client process, it
provides the four basic arithmetic operations addition, subtraction,
multiplication and devision.
To verify the Server sample written in COBOL
Edit the RPC server configuration file
EXAMPLE/QCLSRC(RPCSRV_CFG)
.
You must at least modify the BrokerID=Localhost:1971
of the remote Broker where you want
to register your server and the ServerName=SRV1
that identifies your service.
Start the procedure EXAMPLE/STR_RPCSRV
. It will submit the RPC
server named XSERVER
to a batch queue.
If you want to extend the SBMJOB
parameters, you can
modify/recompile the procedure EXAMPLE/QCLSRC(STR_RPCSRV)
.
Note:
The RPC server can only be started as a batch job for
multithreading reasons. ALWMLTTHD=*YES
is a very important parameter for
allowing multiple threads. The configuration file RPCSRV_CFG
described in the
previous step will be passed to the XSERVER
.
Using the IBM i command WRKACTJOB
, you should find a job named
RPCSERVER
in your active-job list.
Use a calculator client process to send a request to your server. As
remote client you can run a Java test generated from the Workbench
example.idl. Or run the IBM i sample CALCCLIENT
from your
IBM i machine as described in Step 2: Verify the RPC COBOL Client.
The RPC server will find and access the COBOL based sample program CALC in your library EXAMPLE and pass the computed result back to the client. Server stubs are not required for application servers written in COBOL and RPG.
For more details on the server access logic, see Administering the EntireX RPC Server.
To verify the server sample written in C
Edit the RPC server configuration file
EXAMPLE/QCLSRC(RPCSRV_CFG)
.
You must at least modify the
BrokerID=Localhost:1971
of the remote Broker where
you want to register your server and the
ServerName=SRV1
that identifies your service.
Start the procedure EXAMPLE/STR_RPCSRV
. It will submit the RPC
server named XSERVER
to a batch queue.
If you want to extend the SBMJOB parameters, you can
modify/recompile the procedure EXAMPLE/QCLSRC(STR_RPCSRV)
.
Note:
The RPC server can only be started as a batch job for
multithreading reasons. ALWMLTTHD=*YES
is a very important parameter for
allowing multiple threads. The configuration file RPCSRV_CFG described in the
previous step will be passed to the XSERVER
.
Using the IBM i command WRKACTJOB
, you should find a job named
"RPCSERVER
" in your active-job list.
Rename the C stub X_DEXAMPLE
to DEXAMPLE
and the C application
X_EXAMPLE
to EXAMPLE
.
Note:
under IBM i, a service program of type *SRVPGM
is equivalent to
the UNIX term "shared library".
For more details on the naming convention of servers and stubs written in C, see Using the C Wrapper.
Use a calculator client process to send a request to your server. As remote client you can run a Java test program generated from the Workbench example.idl.
The RPC server will search for the shared libraries Dlibrary (the server stub) and library which contains the program functions, e.g. CALC. In our sample case, library denotes EXAMPLE.
The section Administration of the EntireX RPC Server under IBM i describes in detail how the RPC server distinguishes between a shared library and a stubless COBOL or RPG program.