The EntireX z/OS CICS® RPC Server allows standard RPC clients to communicate with RPC servers on the operating system z/OS under CICS. It supports the programming languages COBOL and PL/I.
This document covers the following topics:
By default, the CICS RPC Server runs as CICS transaction ESRV
. This can be changed with parameter REPL
.
The following elements are used for setting up the CICS RPC Server:
defines a setup of the CICS RPC Server that is persistent over CICS restarts
is defined with parameters of the ERXMAIN
Macro; see column 1 in the table under Configuring the RPC Server
contains the following important settings:
the default name for the control block is ERXMAIN, but any meaningful name can be chosen.
Using this name as input parameter memory
for the RPC Online Maintenance Facility means that multiple CICS RPC Servers can be started and monitored in parallel.
See Installing Multiple EntireX RPC Servers in the same CICS (Optional).
creates an ERXMAIN
Control Block, a persistent setup of the CICS RPC Server
needs to be assembled to define a setup
is defined in Assembler program EMAINGEN
(in EXP912.SRCE) - use this for assembling; see Build the ERXMAIN Control Block under Installing the CICS RPC Server in the z/OS installation documentation
provides commands (see column 2 in the table below) to vary most of the permanently defined parameters in the ERXMAIN
Control Block currently in use.
All modifications are lost if CICS is restarted. Use ERXMAIN
Macro for permanent modifications
allows you to try out new setups of the CICS RPC Server easily without the need to reassemble the ERXMAIN
Control Block.
runs as CICS transaction ERXM
supports
starting
stopping
pinging
monitoring
activating trace
of the CICS RPC Server. See RPC Online Maintenance Facility.
Depending on the feature the CICS RPC Server needs to support (see table below) additional runtime options for IBM's Language Environment need to be set. For a full description of LE runtime options, see z/OS V1R4.0 Lang Env Prog Guide.
Feature | LE Runtime Options | Description |
---|---|---|
Trap abends of called RPC server programs | ABTERMENC(RETCODE) (1) |
Required to also trap the LE abends within a server program. |
Level of information if called RPC server program terminates by unhandled condition | TERMTHDACT(UADUMP) (1) |
Forces a U4039 system dump for abends not trapped by the server. |
Force HANDLE ABEND LABEL getting control for COBOL runtime error and others
|
USRHDLR=(CEEWUCHA) (1) |
The server traps abends using CICS HANDLE ABEND . With Enterprise COBOL for z/OS, errors resulting from the COBOL runtime (table overflow, for example) bypass the CICS abend
handler. Setting CEEWUCHA enables the CICS abend handler to also trap the COBOL runtime errors.
|
Call RPC server programs with AMODE 24 as well | ALL31(OFF),STACK(,,BELOW) |
If not specified, AMODE 31 is supported. |
Note:
(1) Set internally by the CICS RPC Server using application-specific CSECT CEEUOPT
.
The options can be changed if CEEUOPT
is replaced on CICS RPC Server load module
RPCSRVC
with IBM Linkage Editor.
There are various ways of specifying LE runtime options, for example installation-specific, region-specific
(CEEROPT
available in the DFHRPL
concatenation) or application-specific (linked CSECT CEEUOPT
) etc.
CICS Parameter | Description | Default | How to change? |
---|---|---|---|
TWASIZE |
Transaction Work Area (TWA) size may be used by target RPC programs called by the CICS RPC server. If this is the case, the TWA size set for the CICS RPC server must match the largest TWA size required by all called target RPC programs. | TWASIZE(28) This corresponds to 'Adabas Parameter List' if transport method NET is used. See Installing Adabas with TP Monitors for EntireX. |
|
The following rules apply for the ERXMAIN
Macro syntax (column 1 in table below):
keywords are given in uppercase
there are no abbreviations for keywords
The following rules apply for the RPC Online Maintenance Facility commands (column 2 in table below):
Underscored letters in a command indicate the minimum number of letters that can be used for abbreviation.
For example, in brokerid=localhost
, brok
is the
minimum number of letters that can be used as an abbreviation, that is, the commands
brokerid=localhost
and brok=localhost
are equivalents.
ERXMAIN Macro Syntax | RPC Online Maintenance Facility Commands | Default | Values | Req/ Opt |
|||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
BKRN |
brokerid |
ETB001 |
Broker ID used by the server. See Using the Broker ID in Applications.
Example: |
R | |||||||||||||||||||
CLZN |
class |
RPC |
Server class part of the server address used by the
server. The server address must be defined as a service in the broker attribute file (see Service-specific Attributes).
Case-sensitive, up to 32 characters. Corresponds to CLASS attribute of the broker attribute file.
Example: |
R | |||||||||||||||||||
SRVN |
servername |
SRV1 |
Server name part of the server address used by the server.
The server address must be defined as a service in the broker attribute file.
See Service-specific Attributes.
Case-sensitive, up to 32 characters.
Corresponds to SERVER of the broker attribute file.
Example: |
R | |||||||||||||||||||
SVCN |
service |
CALLNAT |
Service part of the server address used by the server.
The server address must be defined as a service in the broker attribute file.
See Service-specific Attributes.
Case-sensitive, up to 32 characters.
Corresponds to SERVICE attribute of the broker attribute file.
Example: |
R | |||||||||||||||||||
CODE |
codepage |
no codepage transferred |
Depending on the internationalization approach, the codepage (locale string) where incoming data is provided to the called COBOL server. Conversely, the called COBOL server must provide outgoing data in the given codepage, otherwise unpredictable results occur. See What is the Best Internationalization Approach to use? under Internationalization with EntireX for information on which internationalization approach requires a codepage (locale string). By default, no codepage is transferred to the broker. For the most popular internationalization approach, ICU Conversion, the correct codepage (locale string) must be provided. This means it must:
Example: |
O | |||||||||||||||||||
COMP |
compresslevel |
N |
Enforce compression when data is transferred between
broker and server. See Data Compression in EntireX Broker.
Example: |
O | |||||||||||||||||||
CYCL |
restartcycles |
15 |
Number of restart attempts if the broker is not available.
This can be used to keep the CICS RPC Server running while the broker is down for a short time.
A restart cycle will be repeated every 60 seconds.
Note: When the number of specified cycles is reached and a connection to the broker is not possible, the CICS RPC Server stops. Example: The server waits up to 30 minutes (30*6*10 seconds) before it terminates due to a missing broker connection. |
O | |||||||||||||||||||
DPLY |
deployment |
NO |
Activates the deployment service, see Deployment Service. Required to
use the Server Mapping Deployment Wizard. See Server Mapping Deployment Wizard in the EntireX Workbench documentation.
Example: |
O | |||||||||||||||||||
ENDW |
endworker |
TIMEOUT |
This parameter is forced to value Example: |
O | |||||||||||||||||||
MINW |
minworker |
1 |
Minimum limit of tasks active in parallel.
See also Example: |
O | |||||||||||||||||||
MAXW |
maxworker |
10 |
Upper limit of tasks active in parallel.
Example: |
O | |||||||||||||||||||
ETBL |
etblnk |
CICSETB |
Define the broker stub to be used. See Administering Broker Stubs for available stubs.
Example: |
O | |||||||||||||||||||
EXIT |
n/a | At startup, the CICS RPC Server will call the user exit to synchronize its version.
If successful, the CICS RPC Server will continue and call the user exit for the implemented events.
See User Exit COBUEX02 .
|
O | ||||||||||||||||||||
IMPS |
impersonation |
NO |
|
O | |||||||||||||||||||
LOGN |
logon |
YES |
Execute broker functions LOGON/LOGOFF in worker
threads. Must match the setting of the broker attribute
AUTOLOGON .
Reliable RPC requires logon set to YES .
See Reliable RPC.
Example: |
O | |||||||||||||||||||
n/a |
mapname |
Alias for command memory .
|
O | ||||||||||||||||||||
n/a |
memory |
Command to load an ERXMAIN Control Block.
See Modifying Parameters of the RPC Server.
|
O | ||||||||||||||||||||
OPTS |
runoption |
0 |
This parameter is for special purposes. It provides the CICS RPC Server with additional information.
The runoptions are normally set to meet the platform's requirements.
Set this parameter only if a support representive provides you with an option and asks you to do so.
Syntax: Example: |
O | |||||||||||||||||||
PSWD |
password |
Password for broker logon. Case-sensitive, up to 32
characters. For more information see broker ACI control block field
PASSWORD .
Example: |
O | ||||||||||||||||||||
PRELOAD |
preload |
YES |
Enable to call CICS RPC Server with AMODE=24
|
O | |||||||||||||||||||
REPL |
replicatename |
ESRV |
CICS transaction ID (uppercase, up to 4 characters) assigned to worker tasks
and as default for user tasks if Impersonation is set. In the START-USER event of the user exit
(see User Exit COBUEX02 ) the CICS transaction ID for user tasks
can be overridden. See also Introduction to the CICS RPC Server.
|
O | |||||||||||||||||||
SIZE |
n/a | 32768 |
Size in bytes to hold work memory for worker tasks and impersonated user tasks if impersonation is used.
Each task (worker and user) requires the same amount of memory.
The following rules apply when calculating the ERXMAIN macro parameter MAXW :
This means:
|
O | |||||||||||||||||||
SVM |
svmfile |
Usage and location of server-side mapping files.
See Server-side Mapping Files in the RPC Server.
If no SVM parameter is given, the RPC server tries to open the server-side mapping container,
using CICS file with name ERXSVM .
If this CICS file is not available, no server-side mapping files are used.
If you use server-side mapping files, the server-side mapping container must be installed and configured;
see Installing the Server-side Mapping Container for a CICS RPC Server (Optional) under Installing the EntireX RPC Servers under z/OS.
There are also client-side mapping files that do not require configuration here; see Server Mapping Files for COBOL.
Syntax:
Example: See also Usage of Server Mapping Files. |
O | ||||||||||||||||||||
SYNC |
Y |
Determines whether a CICS SYNCPOINT COMMIT command is issued.
See also Automatic Syncpoint Handling. |
O | ||||||||||||||||||||
TOUT |
timeout |
600 |
Timeout in seconds,
used by the server to wait for broker requests. See broker ACI control block field
WAIT for more information.
Also influences restartcycles and worker model SCALE .
See worker model Example: |
O | |||||||||||||||||||
TRC1 |
tracedestination |
CSSL |
Name of the destination for trace output. A valid CICS transient data queue. See also Activating Tracing for the RPC Server. | O | |||||||||||||||||||
TRLV |
tracelevel |
0 |
Trace level for the server. See also Activating Tracing for the RPC Server.
Syntax:
Example: |
O | |||||||||||||||||||
TROP |
traceoption |
none |
Additional trace option if trace is active. See also Activating Tracing for the RPC Server.
Example: |
O | |||||||||||||||||||
USER |
userid |
ERXSRV1 |
Used to identify the server to the broker.
See broker ACI control block field USER-ID .
Case-sensitive, up to 32 characters.
Example: |
R |
The IDL library and IDL program
names that come from the RPC client are used to locate the RPC server.
See library-definition
and
program-definition
.
This two-level concept (library and program) has to be mapped to the CICS RPC Server environment.
Different mechanisms are used depending on the language:
The approach used to derive the CICS program name for the RPC server depends on whether server mapping is used or not. See Usage of Server Mapping Files for an introduction.
If the RPC client sends a client-side type of server mapping with the RPC request, this server mapping is used first.
If no server mapping is available from step 1 above, and if server-side type of server mapping is used, the IDL library and IDL program names are used to form a key to locate the server mapping in the server-side mapping container. If a server mapping is found, this is then used.
If a server mapping is available from step 1 or 2 above, the CICS program name of the RPC server is derived from this mapping. In this case the IDL program name can be different to the CICS program name if it is renamed during wrapping process (see Customize Automatically Generated Server Names) or during the extraction process in the COBOL Mapping Editor.
If no server mapping is used at all, the IDL program name is used as the CICS program name of the RPC server (the IDL library name is ignored).
To use the CICS RPC Server with COBOL
Make sure that all CICS programs called as RPC servers
use an interface type supported by the CICS RPC Server for target language COBOL; see Supported Interface Types.
can be called with an EXEC CICS LINK PROGRAM
are accessible through the CICS RPL chain or accessible remotely using CICS DPL
Configure the ERXMAIN
macro parameter SVM
depending on whether server-side mapping files are used or not. See also Usage of Server Mapping Files.
See also Scenario I: Calling an Existing COBOL Server or Scenario II: Writing a New COBOL Server.
There is a simple mechanism to derive the RPC server CICS program name:
The IDL program name is used as the CICS program name.
The IDL library name is not used.
To use the CICS RPC Server with PL/I
Make sure that all CICS programs called as RPC servers
use an interface type supported by the CICS RPC Server for target language PL/I; see Supported Interface Types.
can be called with an EXEC CICS LINK PROGRAM
are accessible through the CICS RPL chain or accessible remotely using CICS DPL
See also Scenario III: Calling an Existing PL/I Server or Scenario IV: Writing a New PL/I Server.
RPC servers can use Secure Sockets Layer/Transport Layer Security (SSL/TLS) as the transport medium. The term "SSL" in this section refers to both SSL and TLS. RPC-based servers are always SSL clients. The SSL server can be either the EntireX Broker, Broker SSL Agent, or Direct RPC in webMethods Integration Server (IS inbound). For an introduction see SSL/TLS and Certificates with EntireX in the EntireX Security documentation.
SSL delivered on a z/OS mainframe will typically use the Resource Access Control Facility (RACF) as the certificate authority (CA). Certificates managed by RACF can only be accessed through the RACF keyring container. A keyring is a collection of certificates that identify a networking trust relationship (also called a trust policy). In an SSL client/server network environment, entities identify themselves using digital certificates called through a keyring. Server applications on z/OS that wish to establish network connections to other entities can use keyrings and their certificate contents to determine the trustworthiness of the client or peer entity. Note that certificates can belong to more than one keyring, and you can assign different users to the same keyring. Because of the way RACF internally references certificates, they must be uniquely identifiable by owner and label, and also unique by serial number plus data set name (DSN).
For establishing an SSL connection on z/OS, IBM's Application Transparent Transport Layer Security (AT-TLS) can be used, where the establishment of the SSL connection is pushed down the stack into the TCP layer.
With the CICS RPC Server you can use IBM's Application Transparent Transport Layer Security (AT-TLS), where the establishment of the SSL connection is pushed down the stack into the TCP layer.
Configure the AT-TLS rules for the policy agent (PAGENT) using an appropriate client and the z/OS Management Facility (z/OSMF) . Together with SSL parameters (to provide certificates stored in z/OS as RACF keyrings) define AT-TLS rules, for example by using the application job name and remote TCP port number. If the rules match, the TCP connection is turned into an SSL connection . Refer to your IBM documentation for more information, for example the IBM Redbook Communications Server for z/OS VxRy TCP/IP Implementation Volume 4: Security and Policy-Based Networking.
Client to interact with z/OS Management Facility (z/OSMF). | |
AT-TLS rules are defined with z/OSMF policy management. | |
Policy Repository with AT-TLS rules stored as z/OS files. | |
Policy Agent, MVS task PAGENT, provides AT-TLS rules through a policy enforcement point (PEP) to TCP/IP stack. | |
Application using TCP connection. | |
If AT-TLS rules match, the TCP connection is turned into an SSL connection. |
Notes:
To set up SSL with AT-TLS
To operate with SSL, certificates need to be provided and maintained. Depending on the platform, Software AG provides default certificates, but we strongly recommend that you create your own. See SSL/TLS Sample Certificates Delivered with EntireX in the EntireX Security documentation.
Set up the CICS RPC Server for a TCP/IP connection. On mainframe platforms, use Transport-method-style Broker ID. Example:
ETB024:1699:TCP
Configure AT-TLS to turn the TCP/IP connection to an SSL connection, see above.
Make sure the SSL server to which the CICS RPC Server connects is prepared for SSL connections as well. The SSL server can be EntireX Broker, Broker SSL Agent, or Direct RPC in webMethods Integration Server (IS inbound). See:
The CICS RPC Server provides a user exit COBUEX02
to influence/control the RPC logic. This section covers the following topics:
The user exit is called on the following events:
The numbers in the graphic correspond to the event numbers in the user exit.
Step | Event | Called | Description | Note |
---|---|---|---|---|
WHICH-VERSION |
During startup of RPC server. | The CICS RPC Server and the exit decide on the version to use. See field VERSION .
|
||
START-WORKER |
Before starting a worker task. | This allows you to set the CICS transaction ID of the worker task. See field CICS-TRANSID .
|
1 | |
START-USER |
Before starting a user task. | Requires Impersonation. Before an impersonated CICS transaction (user task) is started, the user exit may change the user ID, CICS transaction ID
and CICS terminal ID of the new impersonated user task. See fields USERID , CICS-TRANSID and CICS-TERMID .
|
1 | |
CALL-START |
Before calling the target CICS program. | See field RPC-SERVER . You can inspect and modify the RPC request (payload data from the RPC client to the RPC server).
|
1 | |
CALL-END |
After calling the target CICS program. | See field RPC-SERVER . You can inspect and modify the RPC reply (payload data from the RPC server to the RPC client).
|
2 |
Notes:
ERROR-CODE
and ERROR-TEXT
. The RPC request is already executed.
ERROR-CODE
and ERROR-TEXT
, this error is returned to the RPC client. The RPC request is already executed.
The Developer's Kit provides the following resources for COBOL:
User exit skeleton COBUEX02
in data set EXP912.SRCE. Copy this skeleton so you have your own user exit source for modifications. The user exit program
must comply with the EXEC CICS LINK PROGRAM COMMAREA
conventions.
Copybook COBUEX02
in data set EXP912.INCL. Please add EXP912.INCL to your COBOL compiler SYSLIB DD
chain. The copybook also contains further description and usage comments.
The parameters of COBUEX02
are described below.
Parameter | Format | I/O | Description | |||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
EXIT-FUNCTION |
PIC 9(4) BINARY |
I | Signals the event. See User Exit Events. | |||||||||||||||||||||
VERSION |
PIC 9(4) BINARY |
I/O | For event WHICH-VERSION , see User Exit Events. On input, the CICS RPC Server provides the maximum supported version; on output, the exit returns the version to be used.
Values 1-2 may be supplied. Some of the fields require a minimum version.
|
|||||||||||||||||||||
TRACE-LEVEL |
PIC 9(4) BINARY |
I | Informational. Value is 0-n . Corresponds to parameter tracelevel .
|
|||||||||||||||||||||
ERROR-CODE |
PIC 9(4) BINARY |
O | Must be set on output. Possible values:
|
|||||||||||||||||||||
ERROR-TEXT |
PIC X(256) |
O | Error text returned to RPC client if an error is supplied in field ERROR-CODE . Up to 256 characters.
|
|||||||||||||||||||||
CICS-TRANSID |
PIC X(4) |
I/O | Input defined by macro EMAINGEN . Default is ESRV . Can be modified on output. Available for the following events:
|
|||||||||||||||||||||
CICS-TERMID |
PIC X(4) |
O | Available for the following event:
|
|||||||||||||||||||||
USERID |
PIC X(32) |
I/O | Input supplied by RPC client. Available for the following event:
|
|||||||||||||||||||||
RPC-LIBRARY |
PIC X(128) |
I | IDL library name. Informational. Availability depends on event and VERSION :
|
|||||||||||||||||||||
RPC-PROGRAM |
PIC X(128) |
I | IDL program name. Informational. Availability depends on event and VERSION :
|
|||||||||||||||||||||
INTERFACE-TYPE |
PIC X |
I | Type of interface. Informational. Available for events CALL-START and CALL-END . Possible values:
|
|||||||||||||||||||||
RPC-SERVER |
PIC X(8) |
I | Target CICS program to call. Informational. Available for the following events:
|
|||||||||||||||||||||
CHANNEL-NAME |
PIC X(16) |
I | Name of CICS Channel. Informational. Applicable if field INTERFACE-TYPE is 'C' (Channel Container). Available for the following events:
|
|||||||||||||||||||||
CHAIN-COUNTER |
PIC S9(9) BINARY |
I |
|
|||||||||||||||||||||
CHAIN-POINTER |
POINTER |
I | Informational. Pointer to first element of a table (or chain of elements) describing payload data. See structure DATA-ENTRY . Available for the following events:
|
|||||||||||||||||||||
CHAIN-COUNTER-OUT |
PIC S9(9) BINARY |
I |
|
|||||||||||||||||||||
CHAIN-POINTER-OUT |
POINTER |
I | Similar to CHAIN-POINTER . Informational. See structure DATA-ENTRY . Available for the following event:
|
|||||||||||||||||||||
RPC-RETCODE |
PIC 9(9) BINARY |
I | RPC error code. Informational.
|
|||||||||||||||||||||
CICS-ABCODE |
PIC X(4) |
I | CICS abend code. Informational. | |||||||||||||||||||||
DATA-ENTRY |
I | Structure. Informational. Consists of: DATA-NAME , DATA-LENGTH , DATA-POINTER .
|
||||||||||||||||||||||
DATA-NAME |
PIC X(16) |
I |
|
|||||||||||||||||||||
DATA-LENGTH |
PIC 9(9) BINARY |
I | Length or maximum expected length: With event CALL-START and CHAIN-POINTER-OUT : the maximum length of payload data. For all other cases, the actual length of the payload data. |
|||||||||||||||||||||
DATA-POINTER |
POINTER |
I | Pointer to payload for this element. |
Apply the name of your exit routine to the EntireX RPC server ERXMAIN
macro parameter EXIT
. See Configuring the RPC Server.
At startup, the CICS RPC Server will call the named user exit to synchronize its version.
If successful, the RPC Online Maintenance Facility will display the user exit as map field "parameter opts
". See
To display the Server parameters (PF06) under RPC Online Maintenance Facility.
The CICS RPC Server will continue and call the user exit for the implemented events.
The CICS RPC Server can be started and stopped automatically during start and stop of the CICS region. For manual start/stop, see Starting the RPC Server and Stopping the RPC Server under RPC Online Maintenance Facility.
To start the CICS RPC Server during the initialization of CICS
If the COBOL source ERXSTART
of the EntireX installation library EXP912.SRCE has not been defined in the CICS CSD
data sets by the installation job $INSTALL
, define it.
Customize and compile ERXSTART
if necessary.
Add the following entry to your CICS PLTPI
table (second phase PLT program):
DFHPLT TYPE=ENTRY,PROGRAM=ERXSTART
See also Starting the EntireX RPC Server Automatically on CICS Startup (Optional) under Installing the CICS RPC Server in the z/OS Installation documentation.
To stop the CICS RPC Server during the shutdown of CICS
If the COBOL source ERXSTOP
of the EntireX installation library EXP912.SRCE has not been defined in the CICS CSD
data sets by the installation job $INSTALL
, define it.
Customize and compile ERXSTOP
if necessary.
Add the following entry to your CICS PLTSD
table (first phase PLT program):
DFHPLT TYPE=ENTRY,PROGRAM=ERXSTOP
See also Stopping the EntireX RPC Server Automatically on CICS Shutdown (Optional) under Installing the CICS RPC Server in the z/OS Installation documentation.
If you need to install multiple instances in the same CICS region, see Installing Multiple EntireX RPC Servers in the same CICS (Optional) under Installing the CICS RPC Server in the z/OS Installation documentation.