The EntireX Micro Focus COBOL RPC Server allows standard RPC clients to communicate with COBOL servers written with Micro Focus COBOL. It works together with the COBOL Wrapper and the IDL Extractor for COBOL.
This document covers the following topics:
The following elements are used for setting up the Micro Focus RPC Server:
The COBOL runtime, for example Micro Focus Server, has to be installed according to the Micro Focus documentation. It is not delivered with this package. Provide the location of the COBOL runtime in the Start Script.
If a COBOL runtime is not provided, the Micro Focus RPC Server cannot be started and an error message is given.
The name of the delivered example configuration file is microfocusserver.cfg provided in the config folder. The configuration file contains the configuration for the Micro Focus RPC Server. The following settings are important:
connection information such as broker ID, server address (class, name, service)
location and usage of server-side mapping container; see Usage of Server Mapping Files.
scalability parameters
trace settings
etc.
For more information see Configuring the RPC Server.
The start script for the Micro Focus RPC Server is called microfocusserver.bsh (UNIX) or microfocusserver.bat (Windows) and is provided in the bin folder of the installation directory. You may customize this file. The start script contains the following:
location of the Micro Focus COBOL runtime
paths to the called COBOL server; see Configuration Approaches
the configuration file used; see Configuration File
etc.
The following rules apply:
In the configuration file:
Comments must be on a separate line.
Comment lines can begin with '*', '/' and ';'.
Empty lines are ignored.
Headings in square brackets [<topic>] are ignored.
Keywords are not case-sensitive.
Underscored letters in a parameter indicate the minimum number of letters that can be used for an abbreviated command.
For example, in brokerid=localhost
,
brok
is the minimum number of letters that
can be used as an abbreviation, that is, the commands/parameters broker=localhost
and brok=localhost
are equivalents.
Parameter | Default | Values | Req/ Opt |
||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
brokerid |
localhost |
Broker ID used by the server. See Using the Broker ID in Applications.
Example: |
R | ||||||||||||||||||||||||
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 .
Example: |
R | ||||||||||||||||||||||||
codepage |
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). For the most popular internationalization approach, ICU Conversion, the correct codepage (locale string) must be provided. This means it must:
Default behavior depends on the operating system:
Example: |
R (UNIX) O (Windows) |
|||||||||||||||||||||||||
compresslevel |
N |
Enforce compression when data is transferred between
broker and server. See Data Compression in EntireX Broker.
Example: |
O | ||||||||||||||||||||||||
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 | ||||||||||||||||||||||||
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 | ||||||||||||||||||||||||
marshalling |
COBOL |
The Micro Focus RPC Server supports COBOL. See also Locating and Calling the Target Server.Marshalling=(LANGUAGE=COBOL,
flavor=MF) must be provided. Do not change these settings. The COBOL
servers are called directly without a server interface object. So-called server
mapping files are used to call the COBOL server correctly if one is available.
See Usage of Server Mapping Files.
|
O | ||||||||||||||||||||||||
password |
no default | Password for broker logon. Case-sensitive, up to 32
characters. For more information see broker ACI control block field
PASSWORD .
Example: |
O | ||||||||||||||||||||||||
restartcycles |
15 | Number of restart attempts if the broker is not available.
This can be used to keep the Micro Focus 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 Micro Focus 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 | ||||||||||||||||||||||||
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 | ||||||||||||||||||||||||
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 | ||||||||||||||||||||||||
ssl_file |
no default | Set the SSL parameters. See Using SSL/TLS with the RPC Server for examples and more information. | O | ||||||||||||||||||||||||
svm |
Usage and anchor of the server-side mapping container (directory or folder).
See Server-side Mapping Files in the RPC Server.
The RPC server needs write access to the server-side mapping container.
There are also client-side mapping files that do not require configuration here.
See Server Mapping Files for COBOL
Example for UNIX: Example for Windows: See also Usage of Server Mapping Files. |
O | |||||||||||||||||||||||||
timeout |
60 | 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 .
Example: |
O | ||||||||||||||||||||||||
tracedestination |
ERXTrace.nnn.log |
The name of the destination file for trace output. By default the main trace file name is
If the default is not used and a
See also Activating Tracing for the RPC Server. Example: |
O | ||||||||||||||||||||||||
tracelevel |
None |
Trace level for the server. See also Activating Tracing for the RPC Server.
tracelevel = None | Standard | Advanced | Support
Example: |
O | ||||||||||||||||||||||||
traceoption |
None |
Additional trace option if trace is active. See also Activating Tracing for the RPC Server.
Example: |
O | ||||||||||||||||||||||||
userid |
ERX-SRV |
Used to identify the server to the broker.
See broker ACI control block field USER-ID .
Case-sensitive, up to 32 characters.
Example: |
R | ||||||||||||||||||||||||
workermodel |
SCALE,1,3,slowshrink |
|
O |
The Micro Focus RPC Server is able to call standard libraries (Windows DLLs or UNIX shared objects/libraries); Micro Focus proprietary formats such as intermediate code (*.int); generated code (*.gnt); and intermediate or generated code packaged in libraries (*.lbr). See the following table:
Executable Format | File Extension | File Name | Entry Point | Notes | Configuration |
---|---|---|---|---|---|
Operating system standard library with multiple server | .so|sl (UNIX) or .dll (Windows) | IDL library | IDL program | 1,2 | 1 |
Operating system standard library with single server | .so|sl (UNIX) or .dll (Windows) | IDL program | IDL program | 1,3,4 | 2 |
Micro Focus proprietary intermediate code | .int | IDL program | 4 | 2 | |
Micro Focus proprietary generated code | .gnt | IDL program | 4 | 2 | |
Micro Focus proprietary library with multiple server | .lbr | IDL library | IDL program | 2,5 | 2 |
Micro Focus proprietary library with single server | .lbr | IDL program | IDL program | 3,4,5 | 2 |
This type of library is a standard library (UNIX shared library or Windows DLL).
This type of library may contain multiple COBOL servers. The IDL library name is used to form the operating system file name. The COBOL server names (entry points) are taken as follows:
if the COBOL Wrapper is used, by default from the IDL program names. The IDL program name can be different if it is renamed during the wrapping process, see Customize Automatically Generated Server Names
if the IDL Extractor for COBOL is used, from the COBOL program IDs. The IDL program name can be different if it is renamed during the extraction process in the COBOL Mapping Editor
If the IDL program name is different, a server mapping is required, See Usage of Server Mapping Files.
This type of library must contain one COBOL server only.
The IDL library name is not used. The COBOL server name (operating system file name and its entry point) are taken as follows:
if the COBOL Wrapper is used, by default from the IDL program name. The IDL program name can be different if it is renamed during the wrapping process, see Customize Automatically Generated Server Names
if the IDL Extractor for COBOL is used, from the COBOL program ID. The IDL program name can be different if it is renamed during the extraction process in the COBOL Mapping Editor
If the IDL program name is different, a server mapping is required, See Usage of Server Mapping Files.
Intermediate (*.int) or generated (*.gnt) code must be packaged in the library.
There are two approaches to access the COBOL server during runtime, which depend on the executable format (see table above):
The operating system's standard call mechanism is used to call libraries. Make sure your server(s) are accessible, for example:
under UNIX with the LD_LIBRARY_PATH
environment variable
under Windows with the PATH
environment
variable
The Micro Focus environment variable COBPATH
must be set before starting the RPC server. It lists all paths where a search
for COBOL servers is to be performed. See the Micro Focus documentation for
more information.
For both approaches, the start script of the Micro Focus RPC Server is an appropriate place to set the environment variables. See Start Script.
See also Scenario I: Calling an Existing COBOL Server or Scenario II: Writing a New COBOL 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.
To use SSL
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.
Specify the Broker ID, using one of the following styles:
URL Style, for example:
ssl://localhost:2010
Transport-method Style, for example:
ETB024:1609:SSL
If no port number is specified, port 1958 is used as default.
Specify SSL parameters, using one of the methods below:
As part of the Broker ID
The simplest way to specify short SSL parameter is to add them to the Broker ID.
Example with URL-style Broker ID:
ssl://localhost:2010?VERIFY_SERVER=N&TRUST_STORE=c:\\certs\\CaCert.pem
Example with transport-method-style Broker ID:
ETB024:1609:SSL?VERIFY_SERVER=N&TRUST_STORE=c:\\certs\\CaCert.pem
In the SSL file
Complex SSL parameters can be specified in a so-called SSL file, a text file containing the parameters.
Define the SSL file with the SSL parameters, for example file mySSLParms.txt with the following contents:
VERIFY_SERVER=N TRUST_STORE=c:\\certs\\CaCert.pem
Define the SSL file in the configuration file of the Micro Focus RPC Server. See parameter ssl_file
under Configuring the RPC Server. Example:
brokerid=ssl://localhost:2010 . . ssl_file=C:\mySSLdirectory\mySSLParms.txt
If the SSL client checks the validity of the SSL server only, this is known as one-way SSL. The mandatory trust_store
parameter
specifies the file name of a keystore that must contain the list of trusted certificate authorities for the certificate of
the SSL server.
By default a check is made that the certificate of the SSL server is issued for the hostname specified in the Broker ID.
The common name of the subject entry in the server's certificate is checked against the hostname. If they do not match, the
connection will be refused.
You can disable this check with SSL parameter verify_server=no
.
If the SSL server additionally checks the identity of the SSL client, this is known as two-way SSL. In this case the SSL server requests a client certificate
(the parameter verify_client=yes
is defined in the configuration of the SSL server).
Two additional SSL parameters must be specified on the SSL client side: key_store
and key_passwd
.
This keystore must contain the private key of the SSL client. The password that protects the private key is specified with
key_passwd
.
The ampersand (&) character cannot appear in the password.
SSL parameters are separated by ampersand (&). See also SSL/TLS Parameters for SSL Clients.
Make sure the SSL server to which the Micro Focus 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:
Before starting, make sure all your (customer-written) COBOL servers are accessible through the standard Windows DLL or UNIX shared library/object load mechanism. See also Locating and Calling the Target Server.
To start the Micro Focus RPC Server
Use the Start Script.
Or:
Use the following format:
rpcserver CFG=name
[-option] [brokerid] [class] [servername] [service]
Here are some sample options. See Configuring the RPC Server for full list.
-serverlog |
Defines an alternative log file. Under Windows, this is typically used by Windows Services. See Running the RPC Server as a Windows Service. |
-s[ilent] |
Run the RPC server in silent mode, that is, no terminal input will be required (for example to acknowledge error messages). The batch scripts will terminate automatically. Under UNIX, this is recommended when running in background mode. |
-TraceDestination |
Set the trace destination parameter. |
-TraceLevel None|Standard|Advanced |
Set the trace level parameter. |
Note:
The server input arguments are resolved from left to right. Parameters defined in the configuration file may be overridden
by parameters applied on the command line and vice versa. See Configuring the RPC Server for full list of options.
Or:
Under Windows you can use the Micro Focus RPC Server as a Windows Service. See Running the RPC Server as a Windows Service.
To stop the Micro Focus RPC Server
Use the command stopServer
. See Stop EntireX Broker Server Instances in Command Central's Command-line Interface.
Or:
Stop the server instance using Command Central's Graphical User Interface. See Stopping a Server Instance.
Or:
Use the command stopService
. See Stop Running EntireX Broker Services in Command Central's Command-line Interface.
Or:
Stop the service using Command Central's Graphical User Interface. See Stopping a Service.
Or:
Use the command-line utility etbcmd
. See etbcmd
under
z/OS |
UNIX |
Windows |
z/VSE |
BS2000.
Or:
Use CTRL-C
in the session where you started the RPC server instance.
Or:
Under UNIX, enter command kill -
.
process-id
See also Component Return Codes in EntireX.
For general information see Running an EntireX RPC Server as a Windows Service.
To run the Micro Focus RPC Server as a Windows Service
Customize the Start Script according to your system installation.
Note:
The script file must pass external parameters to the RPC server and use the option –silent
:
rpcserver CFG=..\config\microfocusserver.cfg -s %*
See also Starting the RPC Server.
Test your RPC server to see whether it will start if you run your script file.
Use the EntireX RPC Service Tool and install the RPCService
with some meaningful extension, for example MyServer
. If your Start Script is microfocusserver.bat, the command will be
RPCService -install -ext MyServer -script install_path
\EntireX\bin\microfocusserver.bat
The log file will be called RPCservice_MyServer.log.
In Windows Services menu (Control Panel > Administrative Tools > Services) select the service: Software AG EntireX RPC Service [MyServer]
and change the property Startup Type
from "Manual" to "Automatic".
To switch on tracing for the Micro Focus RPC Server
Set the parameters
tracelevel
,
traceoption
and
tracedestination
. See Configuring the RPC Server.
Start the Micro Focus RPC Server. See Starting the RPC Server.
To evaluate the return codes, see Component Return Codes in EntireX.
To switch off tracing
Set the tracelevel
parameter to None
.