Planning the installation
Planning the installation
The following information is required during the Zowe installation process. Software and hardware prerequisites are covered in the next section.
- The zFS directory where you will install the Zowe runtime files and folders. For more details of setting up and configuring the UNIX Systems Services (USS) environment, see UNIX System Services considerations for Zowe. 
- A HLQ that the installation can create a load library and samplib containing load modules and JCL samples required to run Zowe. 
- Multiple instances of Zowe can be started from the same Zowe z/OS runtime. Each launch of Zowe has its own configuration, usually mentioned as Zowe YAML configuration file or zowe.yaml, and zFS directory that is known as a workspace directory. 
- For Zowe in a high availability configuration, there will be only one workspace directory which must be created on a shared file system (zFS directory) where all LPARs in a Sysplex can access. 
- (If not using containerization) Zowe optionally uses a zFS directory to contain its northbound certificate keys as well as a truststore for its southbound keys if the administrator chooses to use PKCS#12 keystore for certificate storage. Northbound keys are one presented to clients of the Zowe desktop or Zowe API Gateway, and southbound keys are for servers that the Zowe API gateway connects to. The certificate directory is not part of the Zowe runtime so that it can be shared between multiple Zowe runtimes and have its permissions secured independently. 
- Zowe has the following started tasks: - ZWESISTCis a cross memory server that the Zowe desktop uses to perform APF-authorized code. More details on the cross memory server are described in Configuring the Zowe cross memory server.
- ZWESASTCis a cross memory Auxiliary server that is used under some situations in support of a Zowe extension. Auxiliary server is started, controlled, and stopped by the cross memory server, so no need to start it manually. More details are described in Zowe auxiliary service
- ZWESLSTCbrings up other parts of the Zowe runtime on z/OS as requested. This may include Desktop, API mediation layer, ZSS, and more, but when using containerization likely only ZSS will be used here. It can be used for a single Zowe instance deployment and can also be used for Zowe high availability deployment in Sysplex. It brings up and stops Zowe instances, or specific Zowe components without restarting the entire Zowe instances.- In order for above started tasks to run correctly, security manager configuration needs to be performed. This is documented in Configuring the z/OS system for Zowe and a sample JCL member - ZWESECURis shipped with Zowe that contains commands for RACF, TopSecret, and ACF2 security managers.
 - Notes: - To start the API Mediation Layer as a standalone component, see API Mediation Layer as a standalone component. 
- If you plan to use API ML with basic authentication and JSON web token authentication, you need to run only - ZWESLSTC. No need to run- ZWESISTCand- ZWESASTC.
- If you plan to use API ML with x509 client-side certificate authentication, you need to run - ZWESISTCand- ZWESLSTC.
 
Topology of the Zowe z/OS launch process#
Runtime directory#
The runtime directory contains the binaries and executable files. You can create a runtime directory in one of the following ways:
- Create a directory and extract Zowe convenience build into it.
- Installing the Zowe SMP/E FMID AZWE002 using the JCL members in the REL4 member.
- Executing the z/OSMF worklow script ZWERF01contained in the SMP/E FMID AZWE002.
During execution of Zowe, the runtime directory contents are not modified. Maintenance or APAR release for Zowe replaces the contents of the runtime directory and are rollup PTFs.
A typical Zowe runtime directory looks like this:
โโโ bin/                             - Zowe launch scriptsโ   โโโ commands/                    - Sub-commands of zwe server commandโ   โ   โโโ **/*/index.shโ   โโโ libs/                        - Common shell function libraryโ   โโโ utils/                       - Miscellaneous utilitiesโ   โโโ zwe                          - zwe server commandโ   โโโ README.md                    - Information on zwe server commandโโโ components/                      - Zowe core components runtimeโ   โโโ api-catalog/                 - Zowe core component - API Catalog as exampleโ   โ   โโโ bin/โ   โ   โโโ manifest.yaml            - Zowe component manifest fileโ   โโโ ...โ   โโโ zss/โโโ files/                           - Other support files to setup, configure and start Zoweโ   โโโ SZWEEXEC/                    - USS copy of <prefix>.SZWEEXEC data setโ   โโโ SZWESAMP/                    - USS copy of <prefix>.SZWESAMP data setโ   โโโ workflows/                   - Files to install and configure Zowe with z/OSMF workflowโ       โโโ **/*.xmlโโโ fingerprint/                     - Zowe runtime fingerprints contains hashes of all files in runtime directoryโโโ licenses/                        - Zowe license noticeโโโ DEVELOPERS.md                    - Information for Zowe developersโโโ example-zowe.yaml                - Example Zowe configuration fileโโโ manifest.json                    - Zowe manifest which contains definition of this build and current versionโโโ README.md                        - Quick introduction of Zowe and quick start guidezwe server command#
The zwe command is provided in the <RUNTIME_DIR>/bin directory. You can use this command and sub-commands to initialize Zowe, manage Zowe instances and fulfill common tasks.
The zwe command has built in help that can be retrieved with the -h suffix. For example, type zwe -h to display all of the supported commands. These are broken down into a number of sub-commands.  
zwe -h ...Available sub-command(s):  - certificate  - components  - init  - install  - internal  - sample  - start  - stop  - versionOther useful global parameters are:
- --debugor- -vto enable verbose mode.
- --traceor- -vvto enable trace mode for current command.
- --log-diror- -lto also write output to log files.
Add the zwe command to your PATH#
You can add this Zowe bin directory to your PATH environment variable so you can execute the zwe command without having to fully qualify its location. To update your PATH, run the following command:
export PATH=${PATH}:<RUNTIME_DIR>/binThis will update the PATH for the current shell. To make this update persistent, you can add the line to your ~/.profile file, or the ~/.bashProfile file if you are using a bash shell. To make this update system wide, you can update the /etc/.profile file. Once the PATH is updated, you can execute the zwe command from any USS directory. For the remainder of the documentation when zwe command is referenced, it is assumed that it has been added to your PATH. 
z/OS Data sets used by Zowe#
After Zowe is properly installed, you should have these data sets created on z/OS under the prefix you defined:
- <prefix>.SZWEAUTHcontains few Zowe component programs to start Zowe and ZSS.
- <prefix>.SZWEEXECcontains few utility executables will be used by Zowe.
- <prefix>.SZWESAMPcontains sample JCLs to help you configure or start Zowe.
If you install Zowe with convenience build, these data sets will be created by zwe install command. If you install Zowe with SMPE or equivalent methods, these data sets will be created during install and you are not required to run zwe install command. The above data sets will be overwritten during upgrade process.
Zowe configuration and runtime also use few other data sets to store customization. These data sets will not be overwritten during upgrade.
- zowe.setup.datasets.parmlibdefined in Zowe configuration, which contains user customized PARMLIB members.
- zowe.setup.datasets.jcllibdefined in Zowe configuration, which contains user customized JCLs or JCLs generated by- zwe initcommand.
- zowe.setup.datasets.authLoadlibdefined in Zowe configuration is optional. If the user choose to copy out load libraries from- <prefix>.SZWEAUTH, they will be placed here. With this option, you have better control on what will be APF authorized other than authorize whole- <prefix>.SZWEAUTH.
- zowe.setup.datasets.authPluginLibdefined in Zowe configuration contains extra load libraries used by ZIS plugins.
Zowe configuration file#
Zowe uses a YAML format configuration. If you store the configuration on USS, this file is usually referred as zowe.yaml.
This configuration file can be placed on a location with these requirements:
- Zowe runtime user, usually referred as ZWESVUSR, must have read permission to this file.
- If you plan to run Zowe in Sysplex, all Zowe high availability instances must share the same configuration file. That means this configuration file should be placed in a shared file system (zFS directory) where all LPARs in a Sysplex can access.
- Zowe configuration file may contain sensitive configuration information so it should be protected against malicious accessing.
To create this configuration, you can copy from example-zowe.yaml located in Zowe runtime directory. Please be aware of the zowe.runtimeDirectory definition in the configuration file, it should match the Zowe runtime directory mentioned above.
To learn more about this configuration, please check Zowe YAML configuration file reference.
When you execute the zwe command, the --config or -c argument is used to pass the location of a zowe.yaml file.
tip
To avoid passing --config or -c to every zwe commands, you can define ZWE_CLI_PARAMETER_CONFIG environment variable points to location of zowe.yaml.
For example, after defining export ZWE_CLI_PARAMETER_CONFIG=/path/to/my/zowe.yaml, you can simply type zwe start instead of full command zwe start -c /path/to/my/zowe.yaml.
tip
If you are new to the example-zowe.yaml configuration file, you can start with entries that are marked with COMMONLY_CUSTOMIZED. It highlights most of the common configurations, such as directories, host and domain name, service ports, certificate setup, and z/OSMF, which are critical for standing a new Zowe instance.
Workspace directory#
The workspace directory is required to launch Zowe. It is automatically created when you start Zowe. More than one workspace directory can be created and used to launch multiple instances of Zowe sharing the same runtime directory. It's not recommended to create workspace directory manually in order to avoid permission conflicts.
Zowe instances are started by running the server command zwe start. This creates a started task with the PROCLIB member ZWESLSTC that is provided with the samplib SZWESAMP created during the installation of Zowe. The JCL member ZWESLSTC starts Zowe launcher under which it launches Zowe components address spaces.  
Zowe enables read and write permission to both Zowe runtime user (ZWESVUSR by default) and Zowe admin group (ZWEADMIN by default) for Zowe workspace directory.
If you plan to run Zowe in Sysplex, all Zowe high availability instances must share the same workspace directory, which means it should be placed in a shared file system (zFS directory) where all LPARs in a Sysplex can access.
The workspace directory should be defined in your Zowe configuration file as zowe.workspaceDirectory.
Log directory#
Some Zowe components will write logs to file system. The directory will be created automatically when you start Zowe and the content will be automatically managed by Zowe components. It's not recommended to create log directory manually in order to avoid permission conflicts.
Multiple Zowe instances can define different log directories, they are not necessary to be shared in Sysplex deployment like workspace directory.
The log directory should be defined in your Zowe configuration file as zowe.logDirectory.
Keystore directory#
Zowe uses certificates to enable transport layer security. The system administrator can choose to use z/OS Keyring or PKCS#12 keystore for certificate storage. A keystore directory will be created and used if PKCS#12 keystore is chosen.
A typical PKCS#12 keystore directory looks like:
โโโ local_ca/                             - Zowe generated certificate authorityโ   โโโ local_ca.cer                      - Zowe CA certificate in PEM formatโ   โโโ local_ca.keystore.p12             - Zowe CA (both certificate and private key) in PKCS#12 formatโโโ localhost/                            - Zowe generated certificates    โโโ local_ca.cer                      - Zowe CA certificate in PEM format    โโโ localhost.cer                     - Default Zowe certificate in PEM format    โโโ localhost.key                     - Default Zowe certificate private key in PEM format    โโโ localhost.keystore.p12            - Zowe certificates in PKCS#12 format    โโโ localhost.truststore.p12          - Zowe trusted certificate authorities in PKCS#12 formatTo generate keystore directory, you need proper zowe.setup.certificate configuration defined in Zowe configuration file and then execute server command zwe init certificate. To learn more about this command, check Reference of zwe init certificate.
Extension directory#
Zowe allows server extensions to expand its core functionalities. The extensions are required to be installed in a central location so Zowe runtime can find and recognize them.
Similar to Zowe runtime directory, this extension directory should be created by the administrators perform Zowe installation and configuration task. Zowe runtime user, typically ZWESVUSR requires read-only permission to this directory.
The extension directory should be created by system administrator and defined in your Zowe configuration file as zowe.extensionDirectory.
Zowe uses zwe components install command to install Zowe server extensions. This command will create sub-directories or symbolic links under the extension directory.