配置CICS
Forked from http://gejoin.com/2016/01/02/CICS-management-tips.html
配置 CICS REGION:
cicscp -v start sfs_server SFS_NAME
cicscp -v create region REGION_NAME DefaultFileServer=
配置 RD:
cicsupdate -c rd -r REGION_NAME XPRecvTimeout=300
cicsupdate -c rd -r REGION_NAME MinServer=30
cicsupdate -c rd -r REGION_NAME MaxServer=80
cicsupdate -c rd -r REGION_NAME MaxRegionPool=62914560
cicsupdate -c rd -r REGION_NAME MaxTaskPrivatePool=20971520
cicsupdate -c rd -r REGION_NAME MaxTSHPool=41943040
cicsupdate -c rd -r REGION_NAME TraceFlagMaster=on
cicsupdate -c rd -r REGION_NAME TraceFlagSystem=on
cicsupdate -c rd -r REGION_NAME TraceFlagUser=on AllowDebugging=yes
其中 REGION_NAME 需更改为您的 CICS REGION 名称。
配置 LD:
cicsadd -c ld -r REGION_NAME LD1 TCPAddress="backend_server" TCPService="tran-host" SNAServerTransport=TCP
其中 backend_server 是后端服务器的 IP 地址。
添加以下行以编辑 /etc/services
文件:
tran-host port_number/tcp
其中 port_number
是端口号。请确保此端口号与 /etc/services
文件中的其他端口号不冲突。
配置环境变量:
添加以下行,编辑/var/cics_regions/REGION_NAME/environment
COBPATH=/user/bin:/usr/lpp/cobol/bin:/etc:/usr/sbin:/usr/ucb:$HOME/bin:/usr/bin/X11
CICS_PROGRAM_PATH=/home/cbod/cbodload/load:/usr/lpp/cics/lib:.
DB2INSTANCE=db2inst1
COB_CPM_SIZE_MAX=0
EXTSHM=ON
DB2NOEXITLIST=ON
配置 WD:
cicsupdate -c wd -r REGION_NAME MDCL Permanent=no RecoverTerminal=no
cicsupdate -c wd -r REGION_NAME MDCI Permanent=no RecoverTerminal=no 配置WD
配置 TD:
cicsadd -c td -r REGION_NAME TCCZ ProgName="DFHMIRS" Timeout=5 TWASize=32767
cicsadd -c td -r REGION_NAME INQY ProgName="GCCBINQY" Timeout=5 TWASize=32767
cicsadd -c td -r REGION_NAME TCCA ProgName="GCCBMMN" Timeout=5 TWASize=32767 TWASize 大小不能忽略。
配置 PD:
cicsadd -c pd -r REGION_NAME GCCBMMN PathName="GCCBMMN" RSLKey=public
cicsadd -c pd -r REGION_NAME GCCBINQY PathName="GCCBINQY" RSLKey=public
cicsadd -c pd -r REGION_NAME GCCBCOP PathName="GCCBCOP" RSLKey=public 添加PD 查看和删除PD方法类似。
配置 XAD
cicsadd -c xad -r REGION_NAME cicsdb2 SwitchLoadFile="/usr/lpp/cics/bin/db21pc" XAOpen="DBNAME,USER_ID,PASSWORD"
其中 REGION_NAME、DBNAME、USER_ID 和 PASSWORD 需相应地替换为您环境中的信息。
配置 CTG:
要配置 ctg.ini 文件,请在 /opt/IBM/cicstg/bin/ctg.ini
文件中添加以下行:
SECTION SERVER = REGION_name
UPPERCASESECURITY=N
PROTOCOL=TCPIP
NETNAME=IP_address
PORT=port_number
CONNECTTIMEOUT=0
TCPKEEPALIVE=N
ENDSECTION
- 其中 REGION_name、IP_address 和 port_number 需相应地替换为您环境中的信息。
- 使用 root 用户帐户完成以下步骤以重新启动 CTG:
- 运行 cicscli -s 命令以启动 CTG。
- 可选: 要验证是否已成功启动 CTG,请运行 cicscli -l 命令。
停启CICS
cicscp -v stop region REGION_name
cicscp -v start region REGION_name StartType=cold
--------
IPC支持
EXTSHM=ON
DB2NOEXITLIST=ON
Db2中出现的超时产生core : Transaction 'CPMI', Abend 'A147', at '???'.
以及对于一些莫名产生core信息只能看到数据库断开信息如:
IOT/Abort trap in pthread_kill at 0xd0540a14
0xd0540a14 (pthread_kill+0xb4) 80410014 lwz r2,0x14(r1)
pthread_kill(??, ??) at 0xd0540a14
_p_raise(??) at 0xd053fe64
raise.raise(??) at 0xd0120c20
SupOS_CicsCOREDump() at 0xdc9eedb4
SupOS_TurnSignalToException(??, ??, ??) at 0xdc9ed5dc
sqleUCdisconnect(??) at 0xd86743b0
sqleUCtermAllCtx(??, ??) at 0xd8673ef0
sqleterm(char,sqlca*)(??, ??) at 0xd8cec01c
sqle_ctx_exit_function()() at 0xd88f1e7c
sqle_myexitlist_function()() at 0xd88f1cf0
sqleExitApplicationEnvironment(unsigned int)(??) at 0xd88f12d0
sqloipdc.sqlo_execute_list@AF34_4(??) at 0xd8804858
sqlo_execute_list() at 0xd88047ac
exit(??) at 0xd017cf70
bde_thread_TaskExit(??) at 0xdc323b18
bde_Exit(??) at 0xdc333dc4
SupOS_Exit(??) at 0xdc9ed494
....
可以尝试添加环境变量 DB2NOEXITLIST=ON
有两种方法可以达到这个目的:
1. Set the environment variable DB2NOEXITLIST=ON for the DB2 client environment on the system with the TXSeries region.
a) db2set DB2NOEXITLIST=ON
b) db2 terminate
c) re-start CICS region
2. Set DB2NOEXITLIST=ON in the region's environment and re-start the region.
Refer to DB2 manual for more information on the DB2NOEXITLIST environment variable.
设置成yes似乎也可以,未验证...
Set the environment variable DB2NOEXITLIST=yes in DB2 client env.
1.Set db2set DB2NOEXITLIST=yes.
2.Terminate DB2 and restart the region.
Set DB2NOEXITLIST=yes in region's environment
一些错误分析:
LINK和START调用的主要返回值解释如下:
1、LINK错误码分析
INVREQ(请求非法)
交易状态不对(有无SYNCONRETURN混用)
TRANSID全空
LENGERR
DATALENGTH选项为负值
DATALENGTH选项比LENGTH选项长
NOTAUTH
权限问题
使用了SYSID选项,但是RSLCheck没有设置为NONE
PGMIDERR
PD不存在
PD被disabled.
ROLLEDBACK
被LINK的程序无法执行syncpoint
SYSIDERR
CD不存在或错误
对方域不存在或已经宕机
网络不通
在本地TD:timeout时,远端交易还在队列
通信错误码:15a00002/15a00102
TERMERR
会话失败,TRANSID不存在
在本地TD:timeout时,远端交易还在运行。通信错误码:15a00007/a0000100
RD:MaxTClassLim引起的Reject。通信错误码:15a00007/84b6031
2、START错误码分析
INVREQ(请求非法)
Hours超范围
Minutes超范围
Seconds超范围
指定REQID但是该TSQ已经存在(在Pool不足时可能出现)
IOERR
SFS满
ISCINVREQ
ISC失败
LENGERR
使用LENGTH(0).
NOTAUTH
权限不足
使用了SYSID选项,但是RSLCheck没有设置为NONE
SYSIDERR
CD不存在或错误
对方域不存在或已经宕机
网络不通
通信错误码:15a00002/15a00102
TERMIDERR
TERMID选项非法
TRANSIDERR
TRANSID选项非法
when ('NORMAL') return ('0');
when ('ERROR') return ('1');
when ('RDATT') return ('2');
when ('WRBRK') return ('3');
when ('EOF') return ('4');
when ('EODS') return ('5');
when ('EOC') return ('6');
when ('INBFMH') return ('7');
when ('ENDINPT') return ('8');
when ('NONVAL') return ('9');
when ('NOSTART') return ('10');
when ('TERMIDERR') return ('11');
when ('DSIDERR') return ('12');
when ('FILENOTFOUND') return ('12');
when ('NOTFND') return ('13');
when ('DUPREC') return ('14');
when ('DUPKEY') return ('15');
when ('INVREQ') return ('16');
when ('IOERR') return ('17');
when ('NOSPACE') return ('18');
when ('NOTOPEN') return ('19');
when ('ENDFILE') return ('20');
when ('ILLOGIC') return ('21');
when ('LENGERR') return ('22');
when ('QZERO') return ('23');
when ('SIGNAL') return ('24');
when ('QBUSY') return ('25');
when ('ITEMERR') return ('26');
when ('PGMIDERR') return ('27');
when ('TRANSIDERR') return ('28');
when ('ENDDATA') return ('29');
when ('INVTSREQ') return ('30');
when ('EXPIRED') return ('31');
when ('RETPAGE') return ('32');
when ('RTEFAIL') return ('33');
when ('RTESOME') return ('34');
when ('TSIOERR') return ('35');
when ('MAPFAIL') return ('36');
when ('INVERRTERM') return ('37');
when ('INVMPSZ') return ('38');
when ('IGREQID') return ('39');
when ('OVERFLOW') return ('40');
when ('INVLDC') return ('41');
when ('NOSTG') return ('42');
when ('JIDERR') return ('43');
when ('QIDERR') return ('44');
when ('NOJBUFSP') return ('45');
when ('DSSTAT') return ('46');
when ('SELNERR') return ('47');
when ('FUNCERR') return ('48');
when ('UNEXPIN') return ('49');
when ('NOPASSBKRD') return ('50');
when ('NOPASSBKWR') return ('51');
when ('SYSIDERR') return ('53');
when ('ISCINVREQ') return ('54');
when ('ENQBUSY') return ('55');
when ('ENVDEFERR') return ('56');
when ('IGREQCD') return ('57');
when ('SESSIONERR') return ('58');
when ('SYSBUSY') return ('59');
when ('SESSBUSY') return ('60');
when ('NOTALLOC') return ('61');
when ('CBIDERR') return ('62');
when ('INVEXITREQ') return ('63');
when ('INVPARTNSET') return ('64');
when ('INVPARTN') return ('65');
when ('PARTNFAIL') return ('66');
when ('USERIDERR') return ('69');
when ('NOTAUTH') return ('70');
when ('VOLIDERR') return ('71');
when ('SUPPRESSED') return ('72');
when ('WRONGSTAT') return ('73');
when ('NAMEERROR') return ('74');
when ('CCERROR') return ('76');
when ('NOSPOOL') return ('80');
when ('TERMERR') return ('81');
when ('ROLLEDBACK') return ('82');
when ('END') return ('83');
when ('DISABLED') return ('84');
when ('ALLOCERR') return ('85');
when ('STRELERR') return ('86');
when ('OPENERR') return ('87');
when ('SPOLBUSY') return ('88');
when ('SPOLERR') return ('89');
when ('NODEIDERR') return ('90');
when ('TASKIDERR') return ('91');
when ('CONTAINERERR') return ('110');
when ('TOKENERR') return ('112');
when ('CHANNELERR') return ('122');
when ('CCSIDERR') return ('123');