Post-Install Optimizations: Difference between revisions

From Try-AS/400
Jump to navigation Jump to search
(→‎Misc: QCCSID)
(→‎Change Program Defaults: This help that logs go where they belong by default when using wrkjobscde option 10)
 
(40 intermediate revisions by 2 users not shown)
Line 17: Line 17:
* *NETSVR
* *NETSVR
* *SLP
* *SLP
=== Change uninstalled programs to not run ===
If you did not install the Ultimedia package, you can remove the pre started job from the QSYSWRK subsystem description to make it not generate an error message at IPL time.
RMVPJE SBSD(QSYSWRK) PGM(QUMEDIA/QUMBPJTC)
If you did not install the Directory Services package (aka LDAP), you can remove the auto started jobs from the QSYSWRK subsystem description to make them not generate an error message at IPL time.
RMVAJE SBSD(QSYSWRK) JOB(QGLDPUBA)
RMVAJE SBSD(QSYSWRK) JOB(QGLDPUBE)
Both is valid and tested for V4R5. Note that newer releases moved the background jobs to the base OS so there is no error message when starting them. I have not tested if they're required to run, though.
If you did not install the performance tools, you don't need trying to start the performance data collector:
RMVAJE SBSD(QCTL) JOB(QPFRCOL)
I can't remember if the latter is valid for V4R5. It's valid for V3R2, though.


=== Cleanup unneeded stuff ===
=== Cleanup unneeded stuff ===
Line 42: Line 57:


=== System Control ===
=== System Control ===
* Change work environment to separate subsystems for different kind of jobs.
* Change work environment to separate subsystems for different kind of jobs. This also makes it easy to introduce your own subsystems.
  CHGSYSVAL SYSVAL(QCTLSBSD) VALUE('QCTL QSYS')
  CHGSYSVAL SYSVAL(QCTLSBSD) VALUE('QCTL QSYS')
* Set automatic DST adjustment, and UTC offset. This value is valid for Central Europe (Berlin, Paris, …) and not available in V4R5.
* Set automatic DST adjustment, and UTC offset. This value is valid for Central Europe (Berlin, Paris, …) '''Note!''' This variable is not available in V4R5. See [[#Weblinks|Weblinks]] below.
  CHGSYSVAL SYSVAL(QTIMZON) VALUE('QP0100CET2')
  CHGSYSVAL SYSVAL(QTIMZON) VALUE('QP0100CET2')
* Lessen time to automatically end disconnected interactive jobs (sessions).
* Adjust time to automatically end disconnected interactive jobs (sessions) to one day.
  CHGSYSVAL SYSVAL(QDSCJOBITV) VALUE('60')
  CHGSYSVAL SYSVAL(QDSCJOBITV) VALUE('1440')


=== (Memory) Allocation ===
=== (Memory) Allocation ===
* Adjust automatic performance values only at runtime, not at IPL.<ref>If you change the mount of memory for the machine, could be wise to adjust the value to '1', make the memory change and then change the value back to '3'.</ref>
* Adjust automatic performance values only at runtime, not at IPL.<ref>If you change the amount of memory for the machine, temporarily adjust the value to '2', make the memory change and then change the value back to '3' — no further IPL needed.</ref> This allows the system to automatically adjust memory allocations and activity levels to minimize paging (disk I/O).
CHGSYSVAL  SYSVAL(QPFRADJ) VALUE('3')
  CHGSYSVAL SYSVAL(QPFRADJ) VALUE('3')
* Make sure, database tasks can use system resources as needed.
* Allow memory pools to self adjust the paging block size depending on jobs running. This is called ''Expert Cache''. You can adjust the maximum active jobs per pool in the <code>WRKSHRPOOL</code> display.<ref>Press <code>F21</code> to switch to view 2 or 3 to have adjustment possibilities.</ref>
  CHGSYSVAL SYSVAL(QQRYDEGREE) VALUE(*OPTIMIZE)
* Match jobs running in total with reservations at IPL time. See <code>WRKACTJOB</code> and set to slightly more than the ''Active Jobs'' value to be seen there.
CHGSYSVAL  SYSVAL(QTOTJOB) VALUE(80)
* Allow memory pools to self adjust depending on jobs running. You can adjust the maximum active jobs per pool in the <code>WRKSHRPOOL</code> display.<ref>Press <code>F21</code> to switch to view 2 or 3 to have adjustment possibilities.</ref>
  CHGSHRPOOL POOL(*BASE) PAGING(*CALC)
  CHGSHRPOOL POOL(*BASE) PAGING(*CALC)
  CHGSHRPOOL POOL(*INTERACT) PAGING(*CALC)
  CHGSHRPOOL POOL(*INTERACT) PAGING(*CALC)
  CHGSHRPOOL POOL(*SPOOL) PAGING(*CALC)
  CHGSHRPOOL POOL(*SPOOL) PAGING(*CALC)
* Reservations for job related data structures at IPL time. See <code>DSPSYSSTS</code> and set to slightly more than the ''Jobs in System'' value to be seen there when the system is working "normal".<ref>Press <code>F21</code> to switch to view 2 or 3 to see the overall job count.</ref>
CHGSYSVAL SYSVAL(QTOTJOB) VALUE(100)
* Reservations for job related data structures at IPL time. See <code>WRKACTJOB</code> and set to slightly more than the ''Active Jobs'' value to be seen there when the system is working "normal".
CHGSYSVAL SYSVAL(QACTJOB) VALUE(95)
* Maximize TCP buffers for maximum performance, especially on faster links.
CHGTCPA TCPRCVBUF(8388608) TCPSNDBUF(8388608)
* Make sure, database tasks can use system resources as needed.
CHGSYSVAL SYSVAL(QQRYDEGREE) VALUE(*OPTIMIZE)
* When interactive jobs require more CPU time than being allowed by default (2 seconds),<ref>This is set in *CLS objects.</ref> to finish a block of processing, allow that memory to be taken from the *BASE pool. Advantage: The QINTER subsystem pool will not be subject to auto adjustment because of jobs which are supposed to run in batch.
CHGSYSVAL SYSVAL(QTSEPOOL) VALUE(*BASE)


=== Message-and-Logging ===
=== Message-and-Logging ===
* Allow immediate deletion of problem reports.
* Allow immediate deletion of problem reports.
  CHGSYSVAL SYSVAL(QPRBHLDITV) VALUE(0)
  CHGSYSVAL SYSVAL(QPRBHLDITV) VALUE(0)
* Do not log software errors. We can't do much about these anyway, seen from a hobbyist viewpoint.
* Do not log software errors. We can't do much about these anyway, seen from a hobbyist viewpoint.
  CHGSYSVAL SYSVAL(QSFWERRLOG) VALUE(*NOLOG)
  CHGSYSVAL SYSVAL(QSFWERRLOG) VALUE(*NOLOG)
* Maximize Central Syslog (viewable with <code>DSPLOG</code> size to lessen rotation frequency. Depending on OS version only ''VALUE(32767)'' may be valid.
* Maximize Central Syslog (viewable with <code>DSPLOG</code> size to lessen rotation frequency. Depending on OS version only ''VALUE(32767)'' may be valid.
  CHGSYSVAL SYSVAL(QHSTLOGSIZ) VALUE(*DAILY)
  CHGSYSVAL SYSVAL(QHSTLOGSIZ) VALUE(*DAILY)
* Raise allowed unsuccessful sign on tries before taking action.
* Raise allowed unsuccessful sign on tries before taking action.
  CHGSYSVAL SYSVAL(QMAXSIGN) VALUE('15')
  CHGSYSVAL SYSVAL(QMAXSIGN) VALUE('15')
* Minimize logging for sessions disconnected beause of device errors.
* Minimize logging for sessions disconnected beause of device errors.
  CHGSYSVAL SYSVAL(QDEVRCYACN) VALUE(*ENDJOBNOLIST)
  CHGSYSVAL SYSVAL(QDEVRCYACN) VALUE(*ENDJOBNOLIST)


=== Security System Values ===
=== Security System Values ===
* Unrestrict automatic creation of system objects triggered by external (network) requests.
* Unrestrict automatic creation of system objects triggered by external (network) requests.
  CHGSYSVAL SYSVAL(QAUTOVRT) VALUE(*NOMAX)
  CHGSYSVAL SYSVAL(QAUTOVRT) VALUE(*NOMAX)
* Allow restore with all security relevant flags.
* Allow restore with all security relevant flags.
  CHGSYSVAL SYSVAL(QALWOBJRST) VALUE(*ALL)
  CHGSYSVAL SYSVAL(QALWOBJRST) VALUE(*ALL)
* For TCP connections to work, we need encrypted passwords.
CHGDDMTCPA PWDRQD(*ENCRYPTED)
* Allow ''QSYSOPR'' signon to all devices.
* Allow ''QSYSOPR'' signon to all devices.
  CHGSYSVAL SYSVAL(QLMTSECOFR) VALUE('0')
  CHGSYSVAL SYSVAL(QLMTSECOFR) VALUE('0')
* Raise maximum password length to maximum value.<ref>In newer OS versions, an additional variable ''QPWDLVL'' allows even longer passwords.</ref>
* Raise maximum password length to maximum value.<ref>In newer OS versions, an additional variable ''QPWDLVL'' allows even longer passwords.</ref>
  CHGSYSVAL SYSVAL(QPWDMAXLEN) VALUE(10)
  CHGSYSVAL SYSVAL(QPWDMAXLEN) VALUE(10)
* Raise minimum  passsword length for security reasons.
* Raise minimum  passsword length for security reasons.
  CHGSYSVAL SYSVAL(QPWDMINLEN) VALUE(8)
  CHGSYSVAL SYSVAL(QPWDMINLEN) VALUE(8)


=== Misc ===
=== Misc ===
* PTF install shall be done on unattended IPL time.
* PTF install shall be done on unattended IPL time, and don't try to report problems to IBM directly.<ref>Needs prior setup for ''Electronic Customer Support''.</ref>
  CHGSRVA PTFINSTYP(*DLYALL)
  CHGSRVA PTFINSTYP(*DLYALL) RPTPRBAUTO(*NO)
* Provide European style formatting.
* Provide European style formatting.
  CHGSYSVAL SYSVAL(QCURSYM) VALUE('€')
  CHGSYSVAL SYSVAL(QCURSYM) VALUE('€')
  CHGSYSVAL SYSVAL(QDECFMT) VALUE('J')
  CHGSYSVAL SYSVAL(QDECFMT) VALUE('J')
  CHGSYSVAL SYSVAL(QSRTSEQ) VALUE(*LANGIDUNQ)<ref>This value isn't available with V4R5. You can use ''*LANGIDSHR'' there.</ref>
  CHGSYSVAL SYSVAL(QSRTSEQ) VALUE(*LANGIDUNQ)<ref>This value isn't available with V4R5. You can use ''*LANGIDSHR'' there.</ref>
CHGSYSVAL SYSVAL(QDATFMT) VALUE('DMY')<ref>Default value for 2924 (US English) is MDY.</ref>
* Allow background compiling in PDM as ordinary user, and submitting batch jobs in general.
* Allow background compiling in PDM as ordinary user, and submitting batch jobs in general.
  GRTOBJAUT OBJ(QGPL/QBATCH) OBJTYPE(*JOBD) USER(*PUBLIC) AUT(*USE)
  GRTOBJAUT OBJ(QGPL/QBATCH) OBJTYPE(*JOBD) USER(*PUBLIC) AUT(*USE)
* Tweaking automatic cleanup (like ''logrotate'').
* Tweaking automatic cleanup (like ''logrotate'').
  CHGCLNUP   ALWCLNUP(*YES) STRTIME('02:22:22') USRMSG(7) SYSMSG(3) SYSPRT(7) SYSLOG(14) CALITM(*KEEP)
  CHGCLNUP ALWCLNUP(*YES) STRTIME('02:22:22') USRMSG(7) SYSMSG(3) SYSPRT(7) SYSLOG(14) CALITM(*KEEP)
* Change general SNA networking attributes.  This is one '''long''' line. Take care to get it completely.
* Change general SNA networking attributes.  This is one '''long''' line. Take care to get it completely.
  CHGNETA   ALRSTS(*ON) ALRLOGSTS(*LOCAL) ALRPRIFP(*NO)  ALRDFTFP(*NO) ALRBCKFP(*NONE) ALRRQSFP(*NONE) ALRCTLD(*NONE) ALRHLDCNT(0) ALRFTR(*NONE) JOBACN(*SEARCH) VRTAUTODEV(254) MDMCNTRYID(DE)
  CHGNETA JOBACN(*SEARCH) VRTAUTODEV(254) MDMCNTRYID(DE)


In addition, OS/400 has a default value of 65535 for <code>QCCSID</code>. It should be set to a value being dependent on the installed language, to enable automatic translation of data on disk to the display device, and back. For Germany, the correct value is 237, and for US, it's 37. A good hint is to check your 5250 emulator program for possible values.
=== Charset Conversion ===
In addition, OS/400 has a default value of 65535 for <code>QCCSID</code>. It should be set to a value being dependent on the installed language, to enable automatic translation of data on disk to the display device, and back. For Germany, the correct value is 273, and for US, it's 37. A good hint is to check your 5250 emulator program for possible values.


== IPL Customization ==
== IPL Customization ==
Line 105: Line 130:
  RTVCLSRC  PGM(QSTRUP) SRCFILE(QCLSRC)
  RTVCLSRC  PGM(QSTRUP) SRCFILE(QCLSRC)
  WRKMBRPDM  FILE(QCLSRC) MBR(QSTRUP) MBRTYPE(CLP)
  WRKMBRPDM  FILE(QCLSRC) MBR(QSTRUP) MBRTYPE(CLP)
  CRTCLPGM  PGM(QSYS/QSTRUP)
  CRTCLPGM  PGM(QGPL/QSTRUP)
 
To activate your changes, run <code>WRKSYSVAL SYSVAL(QSTRUPPGM)</code> and change the values to reflect the new program object in QGPL. '''Note''': On a used system's install, the previous owner might have already done a customized QSTRUP. See <code>DSPSYSVAL QSTRUPPGM</code> which one is the currently set startup program before accidentally overwriting!
 
Notable use cases for changing <code>QSTRUP</code> would be to make SNA Distribution Services, and TCP/IP (on older releases than V4R5) start at IPL time.
 
New entries must be located after the ''IF COND'' statement and ''DONE:'' label. Always put a ''MONMSG MSGID(CPF0000)'' after each statement. Failing to do so will not ignore any errors but make the IPL script terminate abnormally in case of an error and possibly leave you with an inaccessible system.
 
Examples:
* Start TCP/IP:
QSYS/STRTCP
MONMSG MSGID(CPF0000)
<blockquote>'''Note:''' TCP/IP on V4R5 and later is by IBM provided default automatically started with an appropriate autostart entry <code>struptcpip</code> in the <code>qsyswrk</code> subsystem description. No action is necessary in the startup CL!</blockquote>
 
* Start SNADS:
QSYS/STRSBS SBSD(QSNADS)
MONMSG MSGID(CPF0000)


== Change Program Defaults ==
== Change Program Defaults ==
* File creation and change defaults.
This establishes different default behavior of some programs which makes life somewhat easier.<ref>Some people highly oppose against changing default values because the default values have been provided for a reason. But then, the <code>CHGCMDDFT</code> also has been provided for a reason.</ref> At least noting down the changed programs and their former values is recommended, for example in <code>QGPL/QTXTSRC.CMDDFT</code>.
<blockquote>'''Note:''' CL applications might run a command with the changed default values, in turn combining (new) defaults and submitted parameters into an invalid combination of parameters which might lead to run-time errors. As far as I'm aware, my proposed changes are compatible with such situations.</blockquote>
 
* File creation and change defaults:
** Enforce immediate return to program error handling instead of make programs seem to hang (<code>wait…</code>),
** Enforce reusing deleted record space,<ref>If there is no access path defined, sequentially read records are no longer guaranteed to *be in timely order (FIFO)!</ref>
** Remove sizing restrictions,<ref>A runaway process filling the disks to 100&thinsp;% is not stopped prior!</ref>
** Use a smaller access path size for probably increased performance,
** Allow automatic LF rebuild when running <code>chgpf</code>.
  CHGCMDDFT  CMD(CRTPF) NEWDFT('SIZE(*NOMAX *N *N) WAITFILE(*IMMED) WAITRCD(*IMMED) REUSEDLT(*YES)')
  CHGCMDDFT  CMD(CRTPF) NEWDFT('SIZE(*NOMAX *N *N) WAITFILE(*IMMED) WAITRCD(*IMMED) REUSEDLT(*YES)')
CHGCMDDFT  CMD(CRTSRCPF) NEWDFT('SIZE(*NOMAX *N *N) ACCPTHSIZ(*MAX4GB)')
  CHGCMDDFT  CMD(CHGPF) NEWDFT('DLTDEPLF(*YES) SIZE(*NOMAX *N *N) WAITFILE(*IMMED) WAITRCD(*IMMED) REUSEDLT(*YES)')
  CHGCMDDFT  CMD(CHGPF) NEWDFT('DLTDEPLF(*YES) SIZE(*NOMAX *N *N) WAITFILE(*IMMED) WAITRCD(*IMMED) REUSEDLT(*YES)')
  CHGCMDDFT  CMD(CRTLF) NEWDFT('WAITFILE(*IMMED) WAITRCD(*IMMED)')
  CHGCMDDFT  CMD(CRTLF) NEWDFT('WAITFILE(*IMMED) WAITRCD(*IMMED) ACCPTHSIZ(*MAX4GB)')
  CHGCMDDFT  CMD(CHGLF) NEWDFT('WAITFILE(*IMMED) WAITRCD(*IMMED)')
  CHGCMDDFT  CMD(CHGLF) NEWDFT('WAITFILE(*IMMED) WAITRCD(*IMMED) ACCPTHSIZ(*MAX4GB)')
* Menus usually go into the library with the application's other objects. Change current library to there, so applications can find their objects.<ref>It might be beneficial to individually use <code>CURLIB(*NOCHG)</code> for higher level menu objects being put into libraries which are part of the default library search list (''*LIBL'') — such as ''QGPL'' — to not needlessly change the default library in a for some users unexpected way.</ref>
CHGCMDDFT  CMD(CRTMNU) NEWDFT('CURLIB(*MNULIB)')
* No unnecessary wait for power down. <code>CONFIRM(*NO)</code> can be added for newer releases to suppress prompting.
* No unnecessary wait for power down. <code>CONFIRM(*NO)</code> can be added for newer releases to suppress prompting.
  CHGCMDDFT  CMD(PWRDWNSYS) NEWDFT('OPTION(*IMMED) ENDSBSOPT(*NOJOBLOG)')
  CHGCMDDFT  CMD(PWRDWNSYS) NEWDFT('OPTION(*IMMED) ENDSBSOPT(*NOJOBLOG)')
* Don't waste time displaying a not so very much interesting screen prior to connection.
CHGCMDDFT CMD(STRPASTHR) NEWDFT('PASTHRSCN(*NO)')
* Send spooled output to what's defined in the job description instead of what's currently defined.
CHGCMDDFT CMD(SBMJOB) NEWDFT('PRTDEV(*JOBD) OUTQ(*JOBD)')
Be aware that reinstalls, or applying PTFs can overwrite command objects and thus their changed default values.


== Regular Cleanup jobs ==
== Regular Cleanup jobs ==
Line 122: Line 180:
  ADDJOBSCDE JOB(RTVDSKINF) CMD(RTVDSKINF) FRQ(*MONTHLY) SCDDATE(*MONTHSTR) SCDDAY(*NONE) SCDTIME('13:34:00') MSGQ(*LIBL/QSYSOPR) TEXT('Retrieve disk space stats')
  ADDJOBSCDE JOB(RTVDSKINF) CMD(RTVDSKINF) FRQ(*MONTHLY) SCDDATE(*MONTHSTR) SCDDAY(*NONE) SCDTIME('13:34:00') MSGQ(*LIBL/QSYSOPR) TEXT('Retrieve disk space stats')
  ADDJOBSCDE JOB(QPGMRCLR) CMD(CLRMSGQ MSGQ(QPGMR) CLEAR(*KEEPUNANS)) FRQ(*WEEKLY) SCDDATE(*NONE) SCDDAY(*ALL) SCDTIME('07:07:07') RCYACN(*NOSBM) MSGQ(*NONE) TEXT('Delete uninteresting messages')
  ADDJOBSCDE JOB(QPGMRCLR) CMD(CLRMSGQ MSGQ(QPGMR) CLEAR(*KEEPUNANS)) FRQ(*WEEKLY) SCDDATE(*NONE) SCDDAY(*ALL) SCDTIME('07:07:07') RCYACN(*NOSBM) MSGQ(*NONE) TEXT('Delete uninteresting messages')
== Re-Enable InfoSeeker ==
Only necessary for newer V4R4 and newer. If the command isn't known, don't bother: Then your release is so new that it's gone entirely.
See also: [[Reviving InfoSeeker]]
CRTDTAARA DTAARA(QUSRSYS/QBMGINFSKR) TYPE(*CHAR) LEN(8)<ref>Works in V4R5. The <code>STRINFSKR</code> command is not included anymore in IBM i 7.1, and probably earlier releases.</ref>
== Additional Steps tested with V7R2 ==
After trying to enter SST, one gets the message that the password has expired. But the password cannot be changed. Re-IPL '''in manual mode''', do not IPL but enter DST, and change password as directed.
* Choose ''5. Work with DST environment'' and ''3. Service tools user IDs''.
** Disable the "backdoor" profile ''11111111'',
** ''Change password'' for ''QSECOFR'', ''Set password to expired'' to ''2=No''.
* Press F12 and choose ''6. Service tools security data''.
** Enter 0 into the field ''8. Password expiration interval in days'', 8 into the ''Selection'' field, and press return.
** Enter a high number (like 12) into the field ''9. Maximum sign-on attempts allowed'', 9 into the ''Selection'' field, and press return.
** Enter 0 into the field ''10. Duplicate password control'', 10 into the ''Selection'' field, and press return.
Now exit DST.
You may choose to enter SST, enter 7 for ''Work with system security'', and set ''Allow a service tools user ID with a default and expired password to change its own password'' to ''1=Yes''. Since we changed password expiry to ''never'', this step is entirely optional.


== See also ==
== See also ==
* [[Change Command Defaults for File-Commands]]
* [[Change Command Defaults for File-Commands]]
* [[How to properly shut down your AS/400]]
* [[How to properly shut down your AS/400]]
== Weblinks ==
* [https://archive.midrange.com/midrange-l/199912/msg01738.html STRINFSKR], Midrange Mailing-List
* [https://github.com/PoC-dev/as400-autodst as400-autodst], GitHub


== Footnotes ==
== Footnotes ==

Latest revision as of 22:10, 20 October 2025

OS/400 provides a lot of default values for variables (affecting the run-time environment) and program options. Some of these make sense, some of them are kept consistent with earlier versions of the OS because of compatibility reasons by IBM.

Some of these recommendations might not be appropriate for you by various reasons. Don't apply blindly. Know what you do, use the online help to retrieve background information on the topic in question.

The findings below are based on V4R5 with annotated exceptions for newer releases.

Housekeeping

These are settings and scheduled jobs to keep your system uncluttered.

Change unneeded programs to not run

We most likely don't need to run lpd and smtpd to run per default.

CHGLPDA    AUTOSTART(*NO)
CHGSMTPA   AUTOSTART(*NO)

You can easily check all settings at once by using STRDFU OPTION(5) on the file QUSRSYS/QATOCSTART. These are not needed in general. Depending on OS version, not all entries may be available.

  • *DIRSRV
  • *NETSVR
  • *SLP

Change uninstalled programs to not run

If you did not install the Ultimedia package, you can remove the pre started job from the QSYSWRK subsystem description to make it not generate an error message at IPL time.

RMVPJE SBSD(QSYSWRK) PGM(QUMEDIA/QUMBPJTC)

If you did not install the Directory Services package (aka LDAP), you can remove the auto started jobs from the QSYSWRK subsystem description to make them not generate an error message at IPL time.

RMVAJE SBSD(QSYSWRK) JOB(QGLDPUBA)
RMVAJE SBSD(QSYSWRK) JOB(QGLDPUBE)

Both is valid and tested for V4R5. Note that newer releases moved the background jobs to the base OS so there is no error message when starting them. I have not tested if they're required to run, though.

If you did not install the performance tools, you don't need trying to start the performance data collector:

RMVAJE SBSD(QCTL) JOB(QPFRCOL)

I can't remember if the latter is valid for V4R5. It's valid for V3R2, though.

Cleanup unneeded stuff

These objects come by default at OS install time, are not needed to my knowledge, and thus can be safely deleted:

DLTOUTQ    OUTQ(QDKT)
DLTOUTQ    OUTQ(QPFROUTQ)
DLTOUTQ    OUTQ(QPRINTS)
DLTF       FILE(QPRINTS)
DLTOUTQ    OUTQ(QPRINT2)
DLTF       FILE(QPRINT2)
DLTOUTQ    OUTQ(QTPPPOUTQ)
DLTDEVD    DEVD(QESPAP)
DLTDEVD    DEVD(QIADSP)
DLTDEVD    DEVD(QIAPRT)
DLTDEVD    DEVD(QQAHOST)
DLTDEVD    DEVD(QTIDA)
DLTDEVD    DEVD(QTIDA2)
DLTCTLD    CTLD(QESCTL)
DLTCTLD    CTLD(QTICTL)
DLTLIND    LIND(QESLINE)
DLTLIND    LIND(QTILINE)

System Values

System values are like environment variables as known from common operating systems. They influence system operation. I recommend the following changes.

System Control

  • Change work environment to separate subsystems for different kind of jobs. This also makes it easy to introduce your own subsystems.
CHGSYSVAL SYSVAL(QCTLSBSD) VALUE('QCTL QSYS')
  • Set automatic DST adjustment, and UTC offset. This value is valid for Central Europe (Berlin, Paris, …) Note! This variable is not available in V4R5. See Weblinks below.
CHGSYSVAL SYSVAL(QTIMZON) VALUE('QP0100CET2')
  • Adjust time to automatically end disconnected interactive jobs (sessions) to one day.
CHGSYSVAL SYSVAL(QDSCJOBITV) VALUE('1440')

(Memory) Allocation

  • Adjust automatic performance values only at runtime, not at IPL.[1] This allows the system to automatically adjust memory allocations and activity levels to minimize paging (disk I/O).
CHGSYSVAL SYSVAL(QPFRADJ) VALUE('3')
  • Allow memory pools to self adjust the paging block size depending on jobs running. This is called Expert Cache. You can adjust the maximum active jobs per pool in the WRKSHRPOOL display.[2]
CHGSHRPOOL POOL(*BASE) PAGING(*CALC)
CHGSHRPOOL POOL(*INTERACT) PAGING(*CALC)
CHGSHRPOOL POOL(*SPOOL) PAGING(*CALC)
  • Reservations for job related data structures at IPL time. See DSPSYSSTS and set to slightly more than the Jobs in System value to be seen there when the system is working "normal".[3]
CHGSYSVAL SYSVAL(QTOTJOB) VALUE(100)
  • Reservations for job related data structures at IPL time. See WRKACTJOB and set to slightly more than the Active Jobs value to be seen there when the system is working "normal".
CHGSYSVAL SYSVAL(QACTJOB) VALUE(95)
  • Maximize TCP buffers for maximum performance, especially on faster links.
CHGTCPA TCPRCVBUF(8388608) TCPSNDBUF(8388608)
  • Make sure, database tasks can use system resources as needed.
CHGSYSVAL SYSVAL(QQRYDEGREE) VALUE(*OPTIMIZE)
  • When interactive jobs require more CPU time than being allowed by default (2 seconds),[4] to finish a block of processing, allow that memory to be taken from the *BASE pool. Advantage: The QINTER subsystem pool will not be subject to auto adjustment because of jobs which are supposed to run in batch.
CHGSYSVAL SYSVAL(QTSEPOOL) VALUE(*BASE)

Message-and-Logging

  • Allow immediate deletion of problem reports.
CHGSYSVAL SYSVAL(QPRBHLDITV) VALUE(0)
  • Do not log software errors. We can't do much about these anyway, seen from a hobbyist viewpoint.
CHGSYSVAL SYSVAL(QSFWERRLOG) VALUE(*NOLOG)
  • Maximize Central Syslog (viewable with DSPLOG size to lessen rotation frequency. Depending on OS version only VALUE(32767) may be valid.
CHGSYSVAL SYSVAL(QHSTLOGSIZ) VALUE(*DAILY)
  • Raise allowed unsuccessful sign on tries before taking action.
CHGSYSVAL SYSVAL(QMAXSIGN) VALUE('15')
  • Minimize logging for sessions disconnected beause of device errors.
CHGSYSVAL SYSVAL(QDEVRCYACN) VALUE(*ENDJOBNOLIST)

Security System Values

  • Unrestrict automatic creation of system objects triggered by external (network) requests.
CHGSYSVAL SYSVAL(QAUTOVRT) VALUE(*NOMAX)
  • Allow restore with all security relevant flags.
CHGSYSVAL SYSVAL(QALWOBJRST) VALUE(*ALL)
  • For TCP connections to work, we need encrypted passwords.
CHGDDMTCPA PWDRQD(*ENCRYPTED)
  • Allow QSYSOPR signon to all devices.
CHGSYSVAL SYSVAL(QLMTSECOFR) VALUE('0')
  • Raise maximum password length to maximum value.[5]
CHGSYSVAL SYSVAL(QPWDMAXLEN) VALUE(10)
  • Raise minimum passsword length for security reasons.
CHGSYSVAL SYSVAL(QPWDMINLEN) VALUE(8)

Misc

  • PTF install shall be done on unattended IPL time, and don't try to report problems to IBM directly.[6]
CHGSRVA PTFINSTYP(*DLYALL) RPTPRBAUTO(*NO)
  • Provide European style formatting.
CHGSYSVAL SYSVAL(QCURSYM) VALUE('€')
CHGSYSVAL SYSVAL(QDECFMT) VALUE('J')
CHGSYSVAL SYSVAL(QSRTSEQ) VALUE(*LANGIDUNQ)[7]
CHGSYSVAL SYSVAL(QDATFMT) VALUE('DMY')[8]
  • Allow background compiling in PDM as ordinary user, and submitting batch jobs in general.
GRTOBJAUT OBJ(QGPL/QBATCH) OBJTYPE(*JOBD) USER(*PUBLIC) AUT(*USE)
  • Tweaking automatic cleanup (like logrotate).
CHGCLNUP  ALWCLNUP(*YES) STRTIME('02:22:22') USRMSG(7) SYSMSG(3) SYSPRT(7) SYSLOG(14) CALITM(*KEEP)
  • Change general SNA networking attributes. This is one long line. Take care to get it completely.
CHGNETA JOBACN(*SEARCH) VRTAUTODEV(254) MDMCNTRYID(DE)

Charset Conversion

In addition, OS/400 has a default value of 65535 for QCCSID. It should be set to a value being dependent on the installed language, to enable automatic translation of data on disk to the display device, and back. For Germany, the correct value is 273, and for US, it's 37. A good hint is to check your 5250 emulator program for possible values.

IPL Customization

With this procedure, the current startup program for the OS can be retrieved for easy customization.

RTVCLSRC   PGM(QSTRUP) SRCFILE(QCLSRC)
WRKMBRPDM  FILE(QCLSRC) MBR(QSTRUP) MBRTYPE(CLP)
CRTCLPGM   PGM(QGPL/QSTRUP)

To activate your changes, run WRKSYSVAL SYSVAL(QSTRUPPGM) and change the values to reflect the new program object in QGPL. Note: On a used system's install, the previous owner might have already done a customized QSTRUP. See DSPSYSVAL QSTRUPPGM which one is the currently set startup program before accidentally overwriting!

Notable use cases for changing QSTRUP would be to make SNA Distribution Services, and TCP/IP (on older releases than V4R5) start at IPL time.

New entries must be located after the IF COND statement and DONE: label. Always put a MONMSG MSGID(CPF0000) after each statement. Failing to do so will not ignore any errors but make the IPL script terminate abnormally in case of an error and possibly leave you with an inaccessible system.

Examples:

  • Start TCP/IP:
QSYS/STRTCP
MONMSG MSGID(CPF0000)

Note: TCP/IP on V4R5 and later is by IBM provided default automatically started with an appropriate autostart entry struptcpip in the qsyswrk subsystem description. No action is necessary in the startup CL!

  • Start SNADS:
QSYS/STRSBS SBSD(QSNADS)
MONMSG MSGID(CPF0000)

Change Program Defaults

This establishes different default behavior of some programs which makes life somewhat easier.[9] At least noting down the changed programs and their former values is recommended, for example in QGPL/QTXTSRC.CMDDFT.

Note: CL applications might run a command with the changed default values, in turn combining (new) defaults and submitted parameters into an invalid combination of parameters which might lead to run-time errors. As far as I'm aware, my proposed changes are compatible with such situations.

  • File creation and change defaults:
    • Enforce immediate return to program error handling instead of make programs seem to hang (wait…),
    • Enforce reusing deleted record space,[10]
    • Remove sizing restrictions,[11]
    • Use a smaller access path size for probably increased performance,
    • Allow automatic LF rebuild when running chgpf.
CHGCMDDFT  CMD(CRTPF) NEWDFT('SIZE(*NOMAX *N *N) WAITFILE(*IMMED) WAITRCD(*IMMED) REUSEDLT(*YES)')
CHGCMDDFT  CMD(CRTSRCPF) NEWDFT('SIZE(*NOMAX *N *N) ACCPTHSIZ(*MAX4GB)')
CHGCMDDFT  CMD(CHGPF) NEWDFT('DLTDEPLF(*YES) SIZE(*NOMAX *N *N) WAITFILE(*IMMED) WAITRCD(*IMMED) REUSEDLT(*YES)')
CHGCMDDFT  CMD(CRTLF) NEWDFT('WAITFILE(*IMMED) WAITRCD(*IMMED) ACCPTHSIZ(*MAX4GB)')
CHGCMDDFT  CMD(CHGLF) NEWDFT('WAITFILE(*IMMED) WAITRCD(*IMMED) ACCPTHSIZ(*MAX4GB)')
  • Menus usually go into the library with the application's other objects. Change current library to there, so applications can find their objects.[12]
CHGCMDDFT  CMD(CRTMNU) NEWDFT('CURLIB(*MNULIB)')
  • No unnecessary wait for power down. CONFIRM(*NO) can be added for newer releases to suppress prompting.
CHGCMDDFT  CMD(PWRDWNSYS) NEWDFT('OPTION(*IMMED) ENDSBSOPT(*NOJOBLOG)')
  • Don't waste time displaying a not so very much interesting screen prior to connection.
CHGCMDDFT CMD(STRPASTHR) NEWDFT('PASTHRSCN(*NO)')
  • Send spooled output to what's defined in the job description instead of what's currently defined.
CHGCMDDFT CMD(SBMJOB) NEWDFT('PRTDEV(*JOBD) OUTQ(*JOBD)')

Be aware that reinstalls, or applying PTFs can overwrite command objects and thus their changed default values.

Regular Cleanup jobs

See job comment TEXT for details. These are long lines. Take care to get it completely.

ADDJOBSCDE JOB(PRGPRB) CMD(DLTPRB STATUS(*CLOSED)) FRQ(*WEEKLY) SCDDATE(*NONE) SCDDAY(*ALL) SCDTIME('13:22:00') MSGQ(*LIBL/QSYSOPR) TEXT('Purge closed and deletable problem entries')
ADDJOBSCDE JOB(RCLTMPSTG) CMD(RCLTMPSTG DAYS(30)) FRQ(*MONTHLY) SCDDATE(*MONTHSTR) SCDDAY(*NONE) SCDTIME('13:24:00') MSGQ(*LIBL/QSYSOPR) TEXT('Reclaim temporary storage')
ADDJOBSCDE JOB(RTVDSKINF) CMD(RTVDSKINF) FRQ(*MONTHLY) SCDDATE(*MONTHSTR) SCDDAY(*NONE) SCDTIME('13:34:00') MSGQ(*LIBL/QSYSOPR) TEXT('Retrieve disk space stats')
ADDJOBSCDE JOB(QPGMRCLR) CMD(CLRMSGQ MSGQ(QPGMR) CLEAR(*KEEPUNANS)) FRQ(*WEEKLY) SCDDATE(*NONE) SCDDAY(*ALL) SCDTIME('07:07:07') RCYACN(*NOSBM) MSGQ(*NONE) TEXT('Delete uninteresting messages')

Re-Enable InfoSeeker

Only necessary for newer V4R4 and newer. If the command isn't known, don't bother: Then your release is so new that it's gone entirely.

See also: Reviving InfoSeeker

CRTDTAARA DTAARA(QUSRSYS/QBMGINFSKR) TYPE(*CHAR) LEN(8)[13]

Additional Steps tested with V7R2

After trying to enter SST, one gets the message that the password has expired. But the password cannot be changed. Re-IPL in manual mode, do not IPL but enter DST, and change password as directed.

  • Choose 5. Work with DST environment and 3. Service tools user IDs.
    • Disable the "backdoor" profile 11111111,
    • Change password for QSECOFR, Set password to expired to 2=No.
  • Press F12 and choose 6. Service tools security data.
    • Enter 0 into the field 8. Password expiration interval in days, 8 into the Selection field, and press return.
    • Enter a high number (like 12) into the field 9. Maximum sign-on attempts allowed, 9 into the Selection field, and press return.
    • Enter 0 into the field 10. Duplicate password control, 10 into the Selection field, and press return.

Now exit DST.

You may choose to enter SST, enter 7 for Work with system security, and set Allow a service tools user ID with a default and expired password to change its own password to 1=Yes. Since we changed password expiry to never, this step is entirely optional.

See also

Weblinks

Footnotes

  1. If you change the amount of memory for the machine, temporarily adjust the value to '2', make the memory change and then change the value back to '3' — no further IPL needed.
  2. Press F21 to switch to view 2 or 3 to have adjustment possibilities.
  3. Press F21 to switch to view 2 or 3 to see the overall job count.
  4. This is set in *CLS objects.
  5. In newer OS versions, an additional variable QPWDLVL allows even longer passwords.
  6. Needs prior setup for Electronic Customer Support.
  7. This value isn't available with V4R5. You can use *LANGIDSHR there.
  8. Default value for 2924 (US English) is MDY.
  9. Some people highly oppose against changing default values because the default values have been provided for a reason. But then, the CHGCMDDFT also has been provided for a reason.
  10. If there is no access path defined, sequentially read records are no longer guaranteed to *be in timely order (FIFO)!
  11. A runaway process filling the disks to 100 % is not stopped prior!
  12. It might be beneficial to individually use CURLIB(*NOCHG) for higher level menu objects being put into libraries which are part of the default library search list (*LIBL) — such as QGPL — to not needlessly change the default library in a for some users unexpected way.
  13. Works in V4R5. The STRINFSKR command is not included anymore in IBM i 7.1, and probably earlier releases.