MCP-CMS: Difference between revisions
No edit summary |
No edit summary |
||
Line 79: | Line 79: | ||
</blockquote> | </blockquote> | ||
<button type="button" class="collapsible"><div id="tldrDet">tl;dr</div></button> | <button type="button" class="collapsible"><div id="tldrDet">tl;dr</div></button> | ||
<hr width=80%> | |||
<div class="content"> | <div class="content"> | ||
<blockquote> | <blockquote> |
Revision as of 23:36, 4 November 2023
mcpcms
master control program
CMS MCS shell
launch — a shell on a MCP node, ¹ provisioned per your current SSO context. ²
Devops Roadmap
- 0.3.0 c. 4721-04-17 Stable told tl;dr story.¹
- 0.9.0 c. 47yy-00-00 BaselineOfDomainSpace.
- 1.0.0 c. 47yy-00-00 BaselineOfKEE.
- 1.1.0 c. 47yy-00-00 Provisions generic base cluster, working geonode budding, shown tl;dr story. All public pre MCP hosts migrated.
- 1.2.0 c. 47yy-00-00 First dependent SKUs made GA.
- 2.0.0 c. 47yy-00-00 First working WFL workframe, a UI for job edit and debug with visual execution.
- 3.0.0 c. 47yy-00-00 Mature DDD/KEE product.
¹ This page and About DCP are specifying stories, describing the system as seen from the outside. I don't divulge the cog arch internals, everything else is source accessible by devops users. Stable just means broadly, not immutable.
MCPCMS presents the operator display terminal CONTROLLER for MCP ops and the default or "CANDE" MCS³.
Restricted to AKPERSONs (see Entitlements), and whitelisted stations .
A running SPO counts against launch limits.
ABORTED, ACTIVE, COMPLETEDOK, or STOPPED are completion codes for launch job but in the wild it's not run.
Launch code ABORTED implies additional info in your home profile DS control blocks.
¹ Resource limits are dynamically set except for F class which always gets the system limit if there is one.
² MCP nodes must have sub-millisecond ping. Set parameters for your own AWS or Linode accounts or your manually provisioned hosts in the Remote Inventory DS block in your home profile.
³ MCS: a message control subsystem of a MCP.
CANDE MCS
MCP 3.3 CANDE Reference Card In Burroughs MCP, the CANDE MCS was used ubiquitously. I recall using a full screen editor which i think fed CANDE. The text edit functions are obsolete and not part of the mcpcms MCS. Some other commands do map to the new system context though and they are developed in a similar fashion to WFL with an additional shell mode command cande like the lang specific subshells in the next §, which invokes the MCS command processor at a mcpcms prompt.
The command processor is also available as a pane in the WebKEE legacy SPA and the CANDE MCS is the default ubiquitous DCP/MCP MCS. CANDE is used in current Unisys MCP but neither it nor the MCS have their former prominence when the OS runs under Windows.mcpcms
is derived from zsh for MCP and the shell variant set for it in /etc/shells. In an authenticated session, the launch link normally results in a WebSSH session with this shell. Aside from the modification for the MCP machine model, it is otherwise just zsh however the following (mode) commands are available to establish different shell behaviour in support of the KEE:
- shcl (common lisp nature)
- shhs (HsShellScript, haskell nature)
- upsh (prolog nature)
Lisp and prolog implementations are variable, and multiple can be combined but shcl and upsh themselves use sbcl and swipl, respectively. mcpcms can be accessed with ssh using the following script. Using the FQDSAgentName syntax is equivalent to what the launch link does in an AKPERSONs session.
#!/usr/bin/bash # save as <fileName> and invoke with <fileName> <connect-spec> where # # <connect-spec0>::= 'skip' <FQDSAgentName> | <connect-spec> # <connect-spec> ::= <ipV6Address>:<port> | <ipV4Address>:<port> # FQDSAgentName ::= <agentId>@<domain>[:<port>] # # and the values manually supplied from control blocks in the DCMS account profile where connect attempt results will also be available. # if [ -z $2 ] then ssh $1 exit fi # # Try a connect based on just the FQDSA assuming an eligible station. # FQDSA=getmcpcms.ai-integration.biz/?FQDSA=$2 PARMS=$(curl -L $FQDSA) ssh $PARMSmcpcms is implemented for Linux first then MacOS. The intent is to support mainframe OSes after that, specifically the Hercules version of IBM and the Windows based version of Unisys MCP. Core Domain Space uses either AWS or Linode to dynamically provision whole hosts as MCP nodes and nodes may also be created as composed containers on an existing host.
WFL
is inspired by the MCP 12 WFL job control model, runs underneath mcpcms and serves as the physical base of MCP/DCP elements.
Unisys WFL is just a point of departure to our WFL. In Burroughs systems, WFL didn have as high a profile as IBM JCL, the main punch of the overall system, in an industry installation, would be its system of transactions and these ran from a database which the Burroughs architecture delivered seamlessly without WFL to terminals as a special db stack. Our WFL is the central driver and basis of our MCP architecture
- is built for the MCP machine model
- which is a prime driver for the development of that model
- with code blocks containing text of other supported langs
As far as the elaboration of JCL statements and so forth WFL is developed in a bottom up prototyping style without any spec other than the mainframe reference and the DCP/MCP concept, so there will be no documentation for some time other than the text of actual jobs. № 3 above is implemented by variants for the SUBROUTINE statement, with the same attachment of BEGIN and END bounded blocks:
Subroutine Declarator Language Intrinsic CL Common Lisp No HS Haskell No LP LogTalk No PL Prolog No SUBROUTINE WFL (JCL) Yes System Internal MINT MINT 3 Yes PROC A60 Yes UNIT A68 Yes MCP Block TypesIntrinsic means the lang is native to MCP/WFL and doesn't require COMPILE or BIND to produce an executable job title.
MAKE binds job titles to files executable by the cande MCS with the START or SCHEDULE commands.WFL(JCL) job streams are translated from source text to A60/C, A68, and MINT then compiled and linked to the Barton machine, or interpreted by genie or MINT, respectively. WFL(JCL) is A60 translated to C, compiled and bound, interspersed with the JCL statements interpreted by the B machine. Non-intrinsic code forms unified code trees in the DGUI and is maintained there under the control of the governing build statements and commands. Thus, a general WFL job orchestrates an application divided into system part executed by the B machine and application parts executed in the OS image extended from the base OS by the B machine.
'WFL' used without the JCL qualifier or 'WFL workframe' refers to general source processing framework of the high level part of the DCP. Build statements and commands refers to COMPILE/BIND/MAKE.
The namestyles are a homage to MCP and VM/CMS mainframe OSes, both still in use and Unisys WFL (Work Flow Language). The machine thus defined will be ported to other cloud vendors (Google, Azure, et. al.) after workout in Akamai (linode) and AWS.