Operating System - OpenVMS
1839278 Members
2831 Online
110138 Solutions
New Discussion

Re: set login/interactive question

 
SOLVED
Go to solution
Kirk Reindl
Frequent Advisor

set login/interactive question

HW--Two node cluster, both nodes Alpha Es40s
SW--Open VMS 7.3-1

Hi,

Currently our two node VMS cluster is configured to allow 64 interactive logins when the system boots. (I'm thinking this is the default)
This number isn't large enough for our user load.
As part of our manual "post reboot" tasks, someone (me) manually sets the the interactive limit to 1400 on each node. "set login/interactive=1400

This seems like something that could be easily fixed/automated.

What would be the best practice/standarized way for OpenVMS to handle this?

I was thinking of adding "set login/inter=1400 to the end of the sys$manager:systartup_vms.com
But I'm thinking most shops don't do this, and I'd like to stay as standardized as possible.

I have to believe there is a setting some where that I can change 64 to 1400.

Thanks for responses,
Kirk Reindl
18 REPLIES 18
Uwe Zessin
Honored Contributor

Re: set login/interactive question

Define the following symbol in SYS$MANAGER:SYSTARTUP_VMS.COM

$ STARTUP$INTERACTIVE_LOGINS == 64


If you do a '$ SET LOGINS/INTERACTIVE=64' you will triger the job controller to allow logins before the system is up completely.

In the past (with lots of locally attched terminals) I have used a 'trick' to allow logins for users with OPER privilege only -
I've put the following two commands early in startup:
$ SET LOGINS/INTERACTIVE=1
$ SET LOGINS/INTERACTIVE=0

That allowed me to login from a locally attached terminal while the operator console (an LA210?) was still occupied by the startup process - I am talking about VAX-11/780 here ;-)

If something during startup went wrong I could login and tried to fix it while the system was still coming up.


You know that you are still limited by the number of user licenses (unless you have an unlimited license ;-), do you?
.
Kirk Reindl
Frequent Advisor

Re: set login/interactive question

Uwe:

Iâ m following what you are saying. But forgive me, Iâ m new to OpenVMS and I have some follow up questions:

We are okay with the user licenses.

I see what you are saying about defining what Iâ d call a process logical in systartup_vms.com
$ STARTUP$INTERACTIVE_LOGINS == 1400

but⠦⠦.

What I donâ t understand is, how does VMS then in turn know how to:

$ set login/interactive=startup$interactive_logins

For some reason Iâ m thinking the set command has to be triggered somewhere.

Finally,
How does your recommendation circumvent the issue of the job controller from allowing logins before the system is completely up.

T
John Eerenberg
Valued Contributor
Solution

Re: set login/interactive question

During the system boot, the first command procedure to execute is sys$system:startup.com (as defined in sysgen/start).

Eventually, sys$systartup:vms$baseenviron-050_vms.com is executed and sets STARTUP$INTERACTIVE_LOGINS to 64.

sys$manager:systartup_vms.com executes some time after. Here you can override STARTUP$INTERACTIVE_LOGINS with 1400.
In VMS parlance it is a global symbol so make sure to use the two "="'s not just one. Logicals are different and have other uses . . .

Some time after that, sys$startup:vms$lpbegin-050_startup.com executes and it does the
$ set login/interactive
using the global symbol STARTUP$INTERACTIVE_LOGINS.

The technique used to take STARTUP$INTERACTIVE_LOGINS and use it in the Set Login/Interactive is called symbol substitution (the single quote "'" performs this operation).

I've simplified the startup because lots of things are performed before and after each one of these command procedures. NOTE: never modify them (except of course systartup_vms.com).
It is better to STQ then LDQ
Uwe Zessin
Honored Contributor

Re: set login/interactive question

Kirk,
I might have gone a little bit too much into detail, sorry.

I see that John, has already explained what goes on behind the stage with STARTUP$INTERACTIVE_LOGINS.

The job controller is triggered the first time of 'SET LOGINS /INTERACTIVE=' being executed and starts accepting logins. If you do that command yourself in SYSTARTUP_VMS.COM it will happen before the system does it anyway and users could try to get in before the system startup has completed - depending on your users that might not cause any harm - it is just that some components are not yet available.

I can not try this out, but the system might even override your '$ SET LOGINS /INTERACTIVE=1400' from SYSTARTUP_VMS.COM later with 64, when it executes '$ SET LOGINS' on its own.

John,
can you test it? It sounds like you have a GS-class system you can play with ;-)

Be careful, though! Unless VMS has changed since VAX/VMS V4.x you should not set STARTUP$INTERACTIVE_LOGINS to 0. When I wanted to 'be clever' and tried that in 1986, nobody could log in to the system, not even at the console! It was a cluster so I could easily fix it from another node, pheww..
.
Kirk Reindl
Frequent Advisor

Re: set login/interactive question

I have another question:

I searched inside the file sys$startup:vms$lpbegin-050_startup.com for all instances of set login/interactive, this is what I found

$set logins/interactive='startup$interactive_logins

$set logins/interactive=8

Now you are probably wondering why isn't there an end single quote after

$set logins/interactive='startup$interactive_logins

I don't know why, but I thought to myself, good this set login/inter..... is bombing so 64 never gets overriden.

But....... how does anyone explain
$set logins/interactive=8

I'm like 99% sure the last time I booted I ran $set login immediately and login interactive limit was equal to 64.

Any ideas??? thanks again for al your help
Dale A. Marcy
Trusted Contributor

Re: set login/interactive question

Kirk,

>I have another question:

>I searched inside the file sys$startup:vms$lpbegin-050_startup.com for all instances of set login/interactive, this is what I found

>$set logins/interactive='startup$interactive_logins

>$set logins/interactive=8

>Now you are probably wondering why isn't there an end single quote after

This is a "feature" of VMS. The end quote should be there to be correct, but VMS will happily work at the present even if it is missing.

>$set logins/interactive='startup$interactive_logins

>I don't know why, but I thought to myself, good this set login/inter..... is bombing so 64 never gets overriden.

>But....... how does anyone explain
$set logins/interactive=8


You have to study the flow of the command procedure. Only one or the other of the set logins will be executed. The 8 is for minimal boots only. The startup$interactive_logins is for the normal booting of the system.

>I'm like 99% sure the last time I booted I ran $set login immediately and login interactive limit was equal to 64.

>Any ideas??? thanks again for al your help
John Eerenberg
Valued Contributor

Re: set login/interactive question

Kirk

> "Now you are probably wondering why isn't there an end single quote after . . ."
The missing single quote is not a problem.

> "I don't know why, but I thought to myself, good this set login/inter..... is bombing so 64 never gets overriden."
If one does a hard coded
$ Set login/inter=1400
in systartup_vms.com, it simply gets un-done later when vms$lpbegin-050_startup.com executes (it uses the unmodified startup$interactive_logins as defined in vms$baseenviron-050_vms.com). The default action will be to set interactive logins to 64.

> "But....... how does anyone explain
$set logins/interactive=8"
DCL is powerful and can be coded such that things are not obvious. vms$lpbegin-050_startup.com can be called with a p1 parameter of anything. So if p1 is "minimum" then the first goto concantenates the contents of p1 with "_continue" and jumps to "minimum_continue:". I presume this happens when sysgen's startup_p1 is set to "MIN" or when one does a conversational boot and sets startup_p1 to "MIN".

Uwe,
I'll try and validate some things later tonight when I can snag a test system. You've given me some ideas. :-)
It is better to STQ then LDQ
Wim Van den Wyngaert
Honored Contributor

Re: set login/interactive question

Kirk,

If you put the interactive limit on 1400, you should also put MAXPROCESSCNT on a high value such as 1500 (via autogen).

Wim
Wim
Jan van den Ende
Honored Contributor

Re: set login/interactive question

Uwe,

are you sure that with interactive logins = 0 you could NOT login? As far as I remember, even in V3, an account with OPER priv in SYSUAF was permitted login regardless; with the intro of Default & Authorized privs in V4 it HAD to be default for that effect.

And, in a V4 cluster, you could "easily" login to another node and correct things?
IMMSMW, the first few SYSMAN functionalities were only introduced with V5. It WAS possible to trick around and get batchjobs activated on another node, but before the gradual intro of the Clusterwide Queue Manager in the various V5.5 sub-versions, that certainly was not "easily done" !

Wim:
And of course, to have profit from setting MAXPROCESSCNT, so should also set BALSETCNT to that value (or at least MAXPROCESSCNT - 2)

Kirk:
what this means:
roughly speaking MAXPROCESSCNT is used at bootstrap to create 'hooks' for processes in the PAGEFILE and SWAPFILE, creating entries for process control information blocks.
As a relic from past times when internal memory was quite expensive, a similar but separate BALSETCNT specifies the number of "balance slots", being the in-memory process hooks.
If you are real tight in memory, you spare some hooks (a few kB each), at the expense of SWAPPING processes completely out of memory to the swapfile before able to get a process in (or in again from the swapfile), whenever BALSETCNT are memory-resident. Costly in CPU, I/O, and time, so if you do not VERY seriously need a few extra kB of memory, make BALSETCNT = MAXPROCESSCNT.
Well, at modern memory prices, even if there is only a VERY REMOTE chance that you MIGHT ever need more, be generous with both (say, double your expected max)!.
Even if you got a limited number of licenses, if the need should occur, you can enter an extra license, LOAD it, and start using it. On the other hand, MAXPROCESSCNT is a HARD limit, and requires a reboot (and you really should use AUTOGEN to recalculate various related params).

The more you see and use this sort of thing, the more you will learn to appreciate the consistency and elegance of VMS! (never mind the grumbling of the old dogs about the many points that still can be improved, even the best thing is not yet perfect)

so:

get involved, and ENJOY!

hth,

Jan


Don't rust yours pelled jacker to fine doll missed aches.
Uwe Zessin
Honored Contributor

Re: set login/interactive question

Jan,
Yes! Yes! Yes! It was my first VMS upgrade and I tried to 'be clever'.
It was not a privilege problem - I simply didn't get a 'Username:' prompt,
not even on OPA0:!

I thought I wrote that I had fixed it from another cluster member ;-)

The cluster-wide queue manager was there in V4. I am sure that
SYSMAN came with V5.0, but I skipped to V5.1. Cluster-wide process
services came with V5.2.

I always just set MAXPROCESSCNT (good hint, Wim!) and let AUTOGEN calculate
BALSETCNT. Invalid setting can make a system fail during bootstrap -
at least on VAX.
.
Ian Miller.
Honored Contributor

Re: set login/interactive question

$ STARTUP$INTERACTIVE_LOGINS == 1400
creates a global symbol which is evaluated by STARTUP.COM
____________________
Purely Personal Opinion
Kirk Reindl
Frequent Advisor

Re: set login/interactive question

Thanks for all the informative responses; this opened up good discussion.

I have enough to accomplish my task.

Kirk Reindl
John Eerenberg
Valued Contributor

Re: set login/interactive question

fwiw - a hardcoded $ set log/int=1400 in systartup_vms.com gets reset to 64 later in the boot. A $ set log/int=0 in systartup_vms.com only allows users with oper priv to login until later in the boot. A minimum boot ignores startup$interactive_logins and later in the boot does a $set log/int=8. A $ set log/int=0 as well as defining startup$interactive_logins could aid debugging a system boot (don't know, but it may make my life easier).
OPA0 was fine in all cases.

A piece of advice on BALSETCNT:
If this is a high availabilty cluster, maxprocesscnt needs to be much higher then 1,400 interactive users + system processes + padding (after all, you do want some number of users from a failed node to login and continue on the surviving node, yes?). With a fairly hefty wsmax, balsetcnt will run out of system space (physical memory has almost nothing to do with this limitation); autogen corrects for this, but balsetcnt could be too low for decent system performance. Of course there is VBS, etc. that helps. SYSGEN tuning helps, etc. And on and on . . .

Kirk, I guess you got much more from us then you bargined for?
Enjoy!!!
john
It is better to STQ then LDQ
Uwe Zessin
Honored Contributor

Re: set login/interactive question

Thanks for the update, John. It looks like VMS has evolved in almost every corner - on the other hand: one less challenge left ;-)

I agree: it is amazing what a loosely coupled cluster of brains can accomplish.
.
Wim Van den Wyngaert
Honored Contributor

Re: set login/interactive question

I also let autogen calculate all max processcnt related settings.
But I monitor the number of processes, the number of users, balance set slots etc and when it reaches e.g. 90% I get an alarm.

This allows you to investigate why there are that many processes or users. I once had a decwindows user that simply openened a decterm each time he needed a window.

Btw : it is good practice to monitor quotas too.
Wim
Jan van den Ende
Honored Contributor

Re: set login/interactive question

John,

about the WSMAX * BALSETCNT limitation:
(the product must fit within 32 bits minus status bits minus 8 bits for byte-per-page, iirc leaving 20 bits);
I am not absolutely sure and do not have de means to check right now, but I think I remember a bootcamp session where these limitations were mentioned as being addressed (in 7.3-2 or in 8.x).
Maybe some-one at engeneering could prove my memory wrong, or can confirm this and give the true value for the version number?

I DO remember that even 10 years ago it was a real nusance: it was not possible to have dozens of relatively small processes on ONE machine together with a (graphical rendition) process that needed a real LARGE WS.
Only solution then was an extra machine, with a rather rigorously different setup, and a lot of extra managent effort to control what ran where.

Jan
Don't rust yours pelled jacker to fine doll missed aches.
Jan van den Ende
Honored Contributor

Re: set login/interactive question


--- I found the info about WSMAX * BALSETCNT restriction being lifted:
It is as of V7.3-2

Jan
Don't rust yours pelled jacker to fine doll missed aches.
Ian Miller.
Honored Contributor

Re: set login/interactive question

restriction lifted due to moveing of various structures futher up in virtual memory (P2 space, PT space etc) so not constrained to fit in 32bit 4Gb VA range any more - hurrah for 64 bit VMS!
____________________
Purely Personal Opinion