GemStone/S 64 Bitâ„¢ 3.7.2 is a new version of the GemStone/S 64 Bit object server. Version 3.7.2 includes feature enhancements, and bug fixes, including significant fixes affecting Gem out of memory issues.
These Release Notes include changes between the previous version of GemStone/S 64 Bit, v3.7.1, and v3.7.2. v3.7.1.1-v3.7.1.4 were limited distribution releases; all changes in these versions are included in these Release Notes. If you are upgrading from a version prior to 3.7.1, review the release notes for each intermediate release to see the full set of changes.
For details about installing GemStone/S 64 Bit 3.7.2 or upgrading from earlier versions of GemStone/S 64 Bit, see the GemStone/S 64 Bit Installation Guide for v3.7 for your platform.
GemStone/S 64 Bit version 3.7.2 is supported on the following platforms:
Note that GemStone/S 64 Bit v3.7 and later on Linux are built using machine instructions that are not available on older x86_64 CPUs (more than about 10 years old); v3.7.2 will not run on these CPUs, regardless of the Linux OS version.
For more information and detailed requirements for each supported platforms, please refer to the GemStone/S 64 Bit v3.7 Installation Guide for that platform.
The following versions of GBS are supported with GemStone/S 64 Bit version 3.7.2:
The GemStone/S 64 Bit v3.7.2 distribution includes VSD version 5.6.1. This is the same version of VSD that was included with the previous release, v3.7.1.
VSD 5.6.1 is included with the GemStone distribution, and can also be downloaded as a separate product from https://gemtalksystems.com/vsd/
You must use the concurrently released GemBuilder for Java (GBJ) v3.2 with GemStone/S 64 Bit v3.7.2; GBJ versions 3.1.3 and earlier are not supported. GBJ v3.2 is provided for Linux only, and does not support clients on other platforms; please contact GemTalk Technical Support if you require other platforms.
There are a number of infrastructure changes in GBJ v3.2; see the Release Notes for GemBuilder for Java v3.2 for more information.
GBJ installation now requires that the Stone’s TimeZone match the OS TimeZone.
The v3.7.2 distribution includes the shared libraries that support GBJ 3.2 on Linux:
libgbjlnk320-3.7.2-64.so
libgbjts320-3.7.2-64.so
Both GemConnect v2.4 and v2.5 are supported with GemStone/S 64 Bit 3.7.2, on Linux only.
On some recent platforms, there are OS library changes needed:
The GemStone/S 64 Bit v3.7.2 distribution includes the shared library that supports GemConnect v2.4. To use GemConnect v2.5, you may use make to link with the 3.7.2 release, or contact GemTalk Technical Support.
the configuregs script has been added to making basic configuration of simple systems easier; for example, setup of the /opt/gemstone/locks and logs directories. This avoids the need to use installgs, or to manually configure these files.
This script writes answers to an answers file, which can be edited and reused.
A new script, createNewGemStoneRepository has been added, to make setting up a simple Data-conf configured repository simple. A data-conf repository is created with extents and other files in a repository other than $GEMSTONE/data, and uses the -E argument and a copy of the gemstone_data.conf configuration file.
Chapter 1 of the Installation Guide for v3.7.2 has been extensively updated.
GemStone 3.7.2 documentation now includes support for upgrade directly from 3.3.x. This was tested and supported for earlier 3.7.x versions, but not documented.
The RPM installation process has been reviewed and improved.
Previously, RPM installation was documented to use rpm -i. RPM installation more correctly should be done using dnf (or yum on older OS versions). The previous RPM distribution’s package name for GemStone, however, was GemStone64.x86_64. Since this was the same for all GemStone versions, installing a new version using dnf/yum would override any earlier RPM versions. (#51189)
With v3.7.2, the RPM package is named GemStone64-3.7.2.x86_64, and dnf/yum is safe.
On earlier versions of GemStone, you should continue to use rpm -i.
RPM installations could have failed in v3.7 and later with spurious dependency errors.
In addition, on minimal systems in which Perl was not installed, RPM installations could have failed due to Perl dependencies. Now, the RPM installation using dnf/yum will install a number of required Perl packages if they are not already present. On earlier GemStone versions, with rpm -i, you should include the flag --nodeps. (#50965).
On a system in which /opt/gemstone/locks and /opt/gemstone/log directories were not already defined, the permissions of the newly created directories were not correct. (#50966)
The GemStone distribution extent has the TimeZone of America/Los_Angeles, so most new installations will need to update the TimeZone. Previously, this was done by editing and executing the $GEMSTONE/upgrade/installtimezone script.
Now, this can be done from the image, using the new methods. These methods must be executed as SystemUser.
TimeZone class >> installNamedZone: zonenameString
Install the named timezone, from the GemStone distribution Olson zoneinfo database in $GEMSTONE/pub/timezone. The new TimeZone is made the default/current. The existing default TimeZone is sent become: with the new TimeZone, so existing references to the old TimeZone automatically now refer to the new TimeZone.
TimeZone class >> installOsTimeZone
Install a TimeZone based on the OS time zone settings for the host on which the Gem executing this command is running. This uses /etc/localtime which is correct for Linux and Mac. The new TimeZone is made the default/current. The existing default TimeZone is sent become: with the new TimeZone, so existing references to the old TimeZone automatically now refer to the new TimeZone.
In earlier versions, there was a file descriptor leak in GsHostProcess. This bug has been fixed, which results in an apparent behavior change in GsSocket >> readWillNotBlock; see File descriptor leak in GsHostProcess.
The "leaked" file descriptor was the Gem process's writing end of the stdout and stderr pipes, and the read end of the stdin pipe. After the child was forked, the Gem previously failed to close its stdout/sterr write file descriptor, and this socket is inherited by the child. When the child process exited, it closed its own write file descriptor, but the Gem's was still open (although there was no way for data to appear on this socket).
As a result, in previous releases GsSocket >> read:* operations from the Gem to the child process, after the child process had exited, hung waiting for data to appear on the still-open socket.
With the fix for #47630, GsSocket >> read:* operations from the Gem to the child process after the child process had exited now correctly see the EOF and return 0.
However, GsSocket >> readWillNotBlock also now (correctly) returns true in the case when the child has exited. Since the read:* operation on this socket will return an EOF without blocking, this is intended behavior, although it was not visible in earlier releases since the socket was not actually closed.
If existing code does not also check for read:* returning 0, and only checks the result of readWillNotBlock, then it may fail to recognize when the child has exited. Applications that are upgrading should check their application code to ensure the correct loop checks are done when communicating with the child process in GsHostProcess.
In general, readWillNotBlock is not a reliable way to detect child status, although it is useful to avoid a read:* call waiting indefinitely for data to appear. For instance, there can be a false answer if the child process has not started writing or if it pauses in its writing.
Provided that your code can handle the GsProcess blocking until the child process has sent some data or closed its end of the pipe, there is no need to invoke readWillNotBlock.
With v3.7.2, GemStone/S 64 Bit does not support 32-bit Linux. The directories /bin32 and /lib32 are no longer included in the distribution.
Likewise, GBS/VW with 32-bit VisualWorks is no longer supported on Linux.
The Windows client does include 32-bit libraries and GBS is supported with 32-bit client Smalltalk on Windows.
If GemStone server processes are terminated uncleanly, such as a SEGV or an OS shutdown, they may leave their lock files behind in /opt/gemstone/locks/. These can normally be cleaned up using gslist -c. However, if the OS is rebooted and some process running as a different UNIX user gets the process ID contained in one of the stale .LCK files, then GemStone code cannot safely delete the stale .LCK file.
It is recommended to clear out all .LCK files in /opt/gemstone/locks/ on reboot. An example has been added to demonstrate this:
$GEMSTONE/examples/admin/systemd/gemstone-clean-locks.service
The example services for the Stone and NetLDI, gemstone.service and netldi.service, have been updated to use gemstone-clean-locks.service.
The Gem log header includes a section specific to the Gem’s login, in addition to the header information by the NetLDI that spawned it. This now includes an additional line providing the NRS from the Gem’s environment, since this may be different from that used by the NetLDI.
Issues were found in which the C code supporting multithreaded scans was not sufficiently protected by mutexes when moving to a new phase of the operation, which could result in unexpected errors or missing results (#50904, #50929). This code has been adjusted to include the appropriate mutexes, and there is now a hard limit of 128 on the number of threads used in a multithreaded scan.
Methods that fetch the current settings for mtMaxThreads, mtThreadsLimit, and mtPercentCpuActiveLimit previously required both SessionAccess and SystemControl privileges; now, only SessionAccess is required. SystemControl is still required to modify these settings.
Previously, the ReclaimGem provided the parameter #reclaimMinFreeSpaceMb, which was designed to suspend reclaim under low free space conditions, to avoid excessive extent file growth before any of the newly reclaimed pages became available. This parameter was not checked at the correct point and was thus ineffective, with the risk of runaway extent growth during reclaim. (#51260, #51258, also here)
However, pausing reclaim has risk of reclaim becoming stuck and the repository remaining in a state of low free space, since reclaim is the way pages are made available again.
To avoid the risk of either stuck reclaim or runaway growth, the Reclaim Gem’s parameter #reclaimMinFreeSpaceMb has been removed. Reclaim now is suspended when free space is below the Stone’s STN_FREE_SPACE_THRESHOLD. Under low space conditions, reclaim will proceed slowly until pages become available.
The ReclaimGem’s SessionStat29, #FreeSpaceLowCount, will report the number of times reclaim was paused due to low free space.
In 32-Bit GemStone/S before v5.0, SequenceableCollection>>+ was used to combine collections and strings; this was made obsolete in version 5.0, but has remained in the image to support customers who have progressively upgraded from very old versions.
This method creates issues with Pharo compatibility, and has been removed in this version.
This should not affect customers who have used the deprecation mechanism to remove dependence on deprecated methods. SequenceableCollection >>+ has been deprecated using GemStone’s deprecation mechanism since that mechanism was introduced in v3.0 (2011).
The primitive invoked by Array >> fillFrom:resizeTo:with: and KeyValueDictionary >> fillFrom:resizeTo:with: was subject to out of memory errors (see Memory issues from fillFrom:resizeTo:with:).
The use of this method in KeyValueDictionary table resize was unnecessary; resetting the collection is just as efficient. (#50990). This method has been removed from the image.
Array >> fillFrom:resizeTo:with: remains in the image to allow detection using the deprecation mechanism, but is obsolete and signals an error.
The method Array >> fillFrom:to:with: has been added, as a replacement for filling an Array. Note that code that previously used fillFrom:resizeTo:with: will need modification, since the Array sizing must be done separately.
Array >> fillFrom: startIdx to: endIdx with: anObject
Store anObject into instVars startIdx..endIdx of the receiver. The receiver will be grown if necessary. Attempts to grow the receiver beyond 2034 total instance variables (named and unnamed) signals an error.
Characters with codepoints in the range 16rD800..16rDFFF are not valid for Unicode. Characters with these codepoints are disallowed in UnicodeStrings.
Now, they are also disallowed from DoubleByteString and QuadByteString instances, to avoid the problem conversion of DoubleByteString and QuadByteString instances to Unicode16, Unicode32, or a UTF class. Strings containing codePoints in this range are inherently unusable for any string-related purpose.
A number of bugs have been fixed and feature requests implemented, related to RC collections. In addition to the changes listed here, see specific bugs under Conflict handling in Reduced-conflict collections.
When reduced conflict (RC) collections encounter what would normally be conflicts with other sessions, the conflict is resolved using RC replay. Previously, the Gems sent a set of replay objects to the Stone, which kept a queue of reduced-conflict transactions to resolve (the RcTransQueue). On a busy system, this queue backed up and the application would see commits involving RC collections take longer.
Now, reduced-conflict commit resolution is done by the Gem itself, while it holds the commit token. This ensures that each Gem will succeed in resolving the RC conflict, rather than resolving it only to fail again. The Gems no longer send an RcReadSet to the Stone, and the Stone no longer keeps a queue of reduced-conflict transactions to resolve.
This is a variant of RcKeyValueDictionary that does not automatically execute rebuildTable:. This allows more concurrency in the RC replay of additions. You must ensure that the table size is adequate for the number of key/value pairs.
The method RcIdentityBag >> maxSessionId previously returned the size of the internal components structure. Since there are two entries per sessionId, this was incorrect. maxSessionId now returns the highest sessionId represented in the internal structure.
The following methods have been added to RcIdentityBag:
RcIdentityBag >> maxSessionId: aSessionId
Force the receiver to include component bags for Ids up to aSessionId. This method is not reduced conflict and should not be used while other sessions are modifying the collection.
RcIdentityBag >> removeOneObject
Remove and return one object from the receiver. An object that was added by the current session is returned, if possible, otherwise an object added by another session, otherwise nil if the receiver is empty.
Sending #keys to instances of following classes previously returned instances of IdentitySet, although the dictionary is not identity-based. For these classes, sending #keys now returns an instance of Set:
KeyValueDictionary
IntegerKeyValueDictionary
KeySoftValueDictionary
StringKeyValueDictionary
RcKeyValueDictionary
TreeDictionary/TreeSet are kinds of Dictionary/Set optimized to avoid performance variability in adding elements. These classes were added in v3.7.1. There have been a number of optimizations in the supporting code in v3.7.2. In addition, the following bugs have been fixed:
To support OpenSSH keys, and allow conversion between RSA and PEM format keys, the classes GsSshPublicKey and GsSshPrivateKey have been added.
GsSshPrivateKey encapsulates an OpenSSH private key.
The following instance creation methods create new instances of the receiver based on an OpenSSH base64 string, or a file containing an OpenSSH base64 string, and optional a passPhrase string or a file containing a passPhrase.
The following OpenSSH key types are supported: ecdsa, ed25519, and rsa (dsa keys are no longer supported by libssh).
GsSshPrivateKey class >> newFromOpenSshString: aBase64String withPassphraseFile: aPfFile
GsSshPrivateKey class >> newFromOpenSshString: aBase64String withPassphrase: aPf
GsSshPrivateKey class >> newFromOpenSshFile: fileNameString withPassphraseFile: aPfFile
GsSshPrivateKey class >> newFromOpenSshFile: fileNameString withPassphrase: aPf
GsSshPrivateKey class >> newFromOpenSshFile: fileNameString
GsSshPrivateKey class >> newFromOpenSshString: aBase64String
GsSshPublicKey encapsulates an OpenSSH public key.
The following instance creation methods create new instances of the receiver based on an OpenSSH base64 string, or a file containing an OpenSSH base64 string.
The following OpenSSH key types are supported: ecdsa, ed25519, and rsa (dsa keys are no longer supported by libssh).
The following methods have been added for use by concrete subclasses (GsTlsPrivateKey, GsTlsPublicKey, GsSshPrivateKey, GsSshPublicKey, and Gs5509Certificate). Note that libssh does not support importing public keys from OpenSSL PEM format, so conversions are not supported for GsTlsPublicKey.
GsTlsCredential >> asOpenSshKey
Return an GsSsh*Key, either public or private to match the class of the receiver. Disallowed for GsTlsPublicKey.
GsTlsCredential >> asOpenSshString
Returns a String representing the receiver in OpenSSH base 64 format, either public or private depending on the class of the receiver. For private keys, base64 text lines are limited to 70 characters. Disallowed for GsTlsPublicKey.
GsTlsCredential >> asOpenSshStringOneLine
Returns a String representing the receiver in OpenSSH base 64 format, either public or private depending on the class of the receiver. Base64 text is placed on a single line. Disallowed for GsTlsPublicKey.
GsTlsCredential >> asOpenSslKey
Return an GsTls*Key, either public or private to match the class of the receiver.
The following added methods are supported by all kinds of GsTlsCredential
GsTlsCredential >> isDsa
GsTlsCredential >> isEllipticCurve
GsTlsCredential >> isRsa
GsTlsCredential >> isOpenSshKey
GsTlsCredential >> isOpenSslKey
GsTlsCredential >> class isOpenSshClass
GsTlsCredential >> class isOpenSslClass
The following examples and support methods have been added:
GsSshSocket class >> exampleOpenSshPrivateKey
Return an instance of GsSshPrivateKey that may be used to access the ssh test server at ssh-test.gemtalksystems.com.
GsSshSocket class >> examplePrivateKeyAsOpenSshString
Private key for the ssh test server at ssh-test.gemtalksystems.com in OpenSSH format.
GsSshSocket class >> nbSshClientExample3
Example of remote ssh command using non-blocking protocol with PKI authentication.
GsSshSocket class >> sshClientExample3
Example of an remote ssh command using blocking protocol with PKI authentication.
GsSecureSocket now supports validating that a client connection’s SNI (Server Name Indication) name matches a host name in the peer certificate.
By default, this additional validation is not done; the same validation is done as in previous releases.
To enable validation, add the expected host name to the GsSecureSocket before making the secure connection, using GsSecureSocket >> addExpectedHost: or GsSecureSocket >> setExpectedHost:. Multiple hosts can be added to a Socket’s expected hosts.
During the connection TLS handshake, if the certificate’s names don’t match the expected host name, the connection is not completed. This validation is done automatically during the connection, if the expected hosts is set.
To disable validation, set the expected hosts to nil using
GsSecureSocket >> setExpectedHosts: nil.
The matching can be made more strict by setting additional flags using
GsSecureSocket >> setExpectedHostFlags:.
GsSecureSocket >> addExpectedHost: aString
Adds aString to the list of expected host names the receiver will connect to. This method must be executed before the #secureConnect method and only with client sockets. Raises an exception if the receiver is not a client socket, #secureConnect has already been executed, or if aString is not a non-empty instance of String.
GsSecureSocket >> setExpectedHost: aString
Sets the expected host name that the receiver will connect to. If aString is nil, all previously set host names will be cleared and no host name matching will be performed. This method must be executed before the #secureConnect method and only with client sockets. Raises an exception if the receiver is not a client socket, #secureConnect has already been executed, or if aString is not a non-empty instance of String or nil.
GsSecureSocket >> setExpectedHostFlags: anArray
Sets the flags which control host name matching during TLS session negotiation. By default no flags are set. anArray must contain zero or more symbols of the following symbols:
#X509_CHECK_FLAG_ALWAYS_CHECK_SUBJECT
#X509_CHECK_FLAG_NO_WILDCARDS
#X509_CHECK_FLAG_NO_PARTIAL_WILDCARDS
#X509_CHECK_FLAG_MULTI_LABEL_WILDCARDS
#X509_CHECK_FLAG_SINGLE_LABEL_SUBDOMAINS
#X509_CHECK_FLAG_NEVER_CHECK_SUBJECT
An empty array causes all previously set flags to be cleared.
A detailed description of these flags may be found in the OpenSSL documentation at: https://www.openssl.org/docs/man3.0/man3/X509_check_host.html
The following methods on GsSecureSocket and GsX509Certificate allow you to query for more details about the peer certificate.
GsSecureSocket >> matchedPeerName
Returns a String representing the DNS hostname or subject CommonName from the peer certificate that matched one of the hosts set by the #setExpectedHost: or #addExpectedHost: methods. Returns nil if no host matching was performed. Raises an exception if the receiver is not a client socket or if the secure connection has not been established.
GsSecureSocket >> peerCertificate
Answer an instance of GsX509Certificate representing the peer's certificate. Raises an exception if the receiver has not completed the TLS handshake with its peer. Returns nil if no certificate was sent by the peer. This will always happen if anonymous TLS is used and can happen when certificate verification is disabled.
GsSecureSocket >> peerCertificateChain
Answer an instance of GsX509CertificateChain containing the peer's certificate chain. Raises an exception if the receiver has not completed the TLS handshake with its peer. Returns nil if no certificate was sent by the peer. This always happens if anonymous TLS is used and may happen when certificate verification is disabled.
GsX509Certificate >> isSelfSigned
Answer a Boolean indicating if the receiver is a self-signed certificate.
GsX509Certificate >> issuerName
Returns a string representing the issuer common name of the receiver.
GsX509Certificate >> isValidNow
Answer a Boolean indicating if the receiver is valid at this point in time, that is the current time falls within the window between the receiver's 'not before' and 'not after' times.
GsX509Certificate >> notAfterTime
Returns a SmallDateAndTime representing the 'not after' time of the receiver in GMT.
GsX509Certificate >> notAfterTimeGmtSeconds
Returns a SmallInteger representing 'not after' time of the receiver expressed as the number of seconds since 00:00:00UTC January 1, 1970.
GsX509Certificate >> notBeforeTime
Returns a SmallDateAndTime representing the 'not before' time of the receiver in GMT. GsX509Certificate >> notBeforeTimeGmtSeconds. Returns a SmallInteger representing 'not before' time of the receiver expressed as the number of seconds since 00:00:00UTC January 1, 1970.
GsX509Certificate >> notBeforeTimeGmtSeconds
Returns a SmallInteger representing 'not before' time of the receiver expressed as the number of seconds since 00:00:00UTC January 1, 1970.
GsX509Certificate >> subjectAlternateNames
Returns an Array of Strings representing the contents of the subject alternate extension contained in the receiver, or an empty array if the receiver does not contain the extension.
GsX509Certificate >> subjectName
Returns a string representing the subject common name of the receiver.
There is a known bug in libssh, #58: Opening sftp fails in non-blocking mode, that prevents non-blocking GsSftpSockets from being used. (#50942)
The following methods are not supported for GsSftpSocket:
makeNonBlocking
nbSshConnect
nbSshConnectTimeout:
GsSecureSocket >> setCaCertLocation now includes checking the trusted CA cert locations on the Mac, which allows the GsSecureSocket examples to work on Mac.
The following examples have been added:
GsSecureSocket class >> httpsClientExampleForHost: hostName withSniName: sniName blocking: bool
Connect to an https web server on port 443 at the given host and perform a simple GET request. Full verification of the server certificate is performed. Self-signed certificates will fail verification.
GsSecureSocket class >> httpsClientExampleNB
Connect to the google https web server on port 443 in nonblocking mode and perform a simple GET request. Full verification of the server certificate is performed. Returns true on success.
GsSecureSocket class >> httpsSniClientExampleNB
Example to connect to a webserver that requires SNI in nonblocking mode. Not using SNI (server name == nil) will fail to connect. Returns true on success.
Using GsHostProcess to execute C code with arguments that include whitespace and quotes has Smalltalk-specific requirements for escaping/formatting. Hand applying formatting is error-prone; and including unmatched single quotes was not possible.
Now, arguments can be supplied as an array of strings to an additional argument. The following methods have been added:
GsHostProcess class >> execute: commandLineString args: anArray
A variant of the existing GsHostProcess class >> execute: method with the added args: argument.
GsHostProcess class >> execute: commandLineString input: stdinString args: anArray
A variant of the existing GsHostProcess class >> execute:input: method with the added args: argument.
GsHostProcess class >> fork: commandLineString args: anArray
A variant of the existing GsHostProcess class >> fork: method with the added args: argument.
In these methods, the commandLineString is parsed for space separated arguments. anArray may be nil or an Array of instances of String, Unicode7 or Utf8.
Elements of anArray are appended to the arguments contained in commandLineString, to form the total argv array of the child; any quoting or whitespace within an element of anArray is passed directly to the child in the corresponding element of child's argv.
When using GsHostProcess, if any argument has complicated quoting or whitespace, it is recommended that commandLineString should contain only the full path to the executable, and arguments should be passed as elements of anArray.
When doing limited cache warming on repository startup, you may now also manually warm AllSymbols, using the new methods:
System class >> warmAllSymbols:
System class >> warmAllSymbols: numSessions parameters: aGemStoneParameters
These functions start an external session to perform the warming. Note that warmAllSymbols: takes its login parameters from the current session. This is not sufficient to login if the current user’s password is not swordfish or the NetLDI is performing authentication.
In most cases you should use warmAllSymbols:parameters:, which allows you to pass in an instance of GemStoneParameters, either based on the current session or using other parameters.
| params |
params := GemStoneParameters newDefault.
params
password: 'currentGemStoneUserPassword';
hostPassword: 'myHostPassword';
yourself.
System warmAllSymbols: 5 parameters: params.
Due to changes in commit conflict handling (as described here), the conflict type #Rc-Write-Write has been replaced by #Rc-Retry-Failure.
The commit failure type #RcReadSet has been added, containing the RcReadSet contents to assist in debugging.
The conflict details returned from System class >> commitConflicts, detailedConflictReportString and transactionConflicts have been updated to include timestamps.
The method System class >> _gemCommitConflictDetails (and the primitive it invokes) now returns a SmallInteger rather than a boolean.
The method CanonSymbolDict >> _audit has been added, providing a way to audit AllSymbols.
Support for legacy System hiddenSets is done by sending messages to GsBitmap. The hiddenSet ids are different between System and GsBitmap. Previously, this required several lookups to produce the desired GsBitmap.
System now includes a number of class variables, which reference the GsBitmap ids, and methods that previously hardcoded the set by symbolicName now reference the class variable.
Methods have been added to provide the configuration values for the Gem and Stone in a string format:
System class >> gemConfigurationReportString
Returns a String representation of gemConfigurationReport.
System class >> stoneConfigurationReportString
Returns a String representation of stoneConfigurationReport.
Several methods have been added to support split tranlogs; these are listed here.
This convenience method has also been added:
System class >> pagesNeedReclaimCount
Return number of pages not yet reclaimed by the reclaimGem.
External session executions that result in kinds of CharacterCollection return the contents to the calling session in ByteArrays encoded as UTF-16. This is converted to the appropriate class, if possible, by the method resolveResult.
Previously, results that were instances of Unicode7 were returned as ByteArrays. Now, these are resolved, and an instance of Unicode7 is returned. This applies to both GsExternalSession and GsTsExternalSession
Instances of Unicode16 or Unicode32 are still returned as ByteArrays, as well as DoubleByteStrings and QuadByteStrings. If your application uses strings containing characters out of the ASCII range, it is recommended to use encodeAsUTF8 in the code executing on the external session, and returning the encoded string.
Previously, GsExternalSession returned ByteArrays for return types of Utf8. Now, these are automatically decoded to kinds of String. This applies to all byte sizes of strings. This is the same behavior as GsTsExternalSession has had in previous releases.
When an instance of Utf8 is returned, it was previously always returning a Unicode7, Unicode16 or Unicode32. Now, it will return the appropriate class, either a legacy String or Unicode string, depending on the StringConfiguration of the calling session’s repository.
A non-blocking external session is created using GsTsExternalSession>> forkAndDetachBlock: or forkAndDetachBlock:. When this session logs out, it signals error 4137, which is a normal end of session for a non-blocking session. This was presented in the gem’s log file such that it looked like a gem error. The message has been updated to include "The session is terminating normally". (#51264)
The following methods have been added:
GsTsExternalSession >> parameters: aGemStoneParameters
Set the external session’s parameters instance variable to aGemStoneParameters.
GemStoneParameters >> stoneName
Alternate accessor method for the instance variable gemStoneName.
GemStoneParameters >> stoneName: aName
Alternate settor method for the instance variable gemStoneName.
GemStoneParameters class >> newDefault
Create a new instance of GemStoneParameters based on the current session, with the default password 'swordfish' and no default host password.
GemStoneX509Parameters >> addGemArg: aString
Add a gem argument to extraGemArgs without deleting an existing value in extraGemArgs.
If GEMSTONE_NRS_ALL includes a #dir or #log directive, this was not included in GsNetworkResourceString defaultGemNRSFromCurrent. (#50954)
When using a NetLDI that does not have a name in the services database, and GEMSTONE_NRS_ALL is not defined, GsNetworkResourceString defaultGemNRSFromCurrent parsed incorrectly, and included a trailing ! in the NetLDI name (which may be the port number). This causes logins using that NRS (e.g. with GsTsExternalSession) to fail. (#50901)
UserProfile >> loginHook
If a method or block has been installed using loginHook:, return that; otherwise, return nil.
GsTestCase logging now reports stacks for assertion failures more similarly to the way errors are reported. Instead of just FAILURE:, the leading line now will report:
ERROR 2753 a ResumableTestFailure occurred (error 2753)
GsTestCase >> assert:identical: has improved printing when SmallInteger arguments do not match.
Previously, JsonParser parsed expressions using scientific notation, such as '1E-1', into instance of Fraction. Now, instances of SmallDouble or Float are returned.
A fraction of 0/0 previously reported kind as infinity, now this is a NaN.
FixedPoint previously always returned kind as normal; now it will return NaN, infinity, and zero if appropriate.
There were remaining maintenance methods that logged output to the client rather than the server. To allow these to execute using the thread-safe GCI, such as via GsTsExternalSession, these have been changed to log output to the server. Logging to client or server is the same in linked sessions, but in a topaz RPC sessions, output now goes to the Gem log. The following methods are affected:
GsNMethod class>>convertArrayBuildersIn:list:
GsNMethod class>>convertArrayBuildersInTopazScript:
GsNMethod class>>_convertArrayBuildersIn:list:refDir:
Repository>>_shrinkExtents
System class>>startCheckpointSync
System class>>_commitPrintingDiagnostics
Upgrade3Init class >> _allUsers_addInversePrivilege
For details, seeSequenceableCollection + removed.
DecimalFloat >> _asStringE
GciLibrary >> GciHostInstallFaultHandler_:_:
GemStoneParameters >> _getArg:key:
GemStoneParameters >> _secureArg:key:
GemStoneParameters >> _securePasswords
GemStoneParameters >> _zeroArgPrim:
GsTestCase >> repeatIfInterruptedByGC:
GsTestCase >> shouldRepeatIfInterruptedByGC
GsTlsCredential class >> newFromPemString:
HtInternalNode >> makeRoomAtIndex:
KeyValueDictionary >> fillFrom:resizeTo:with:
LogEntry >> argArray:
LogEntry >> receiver:
LogEntry >> selector:
Object >> _primitiveSelectiveAbort
PrivateObject >> _primitiveSelectiveAbort
RcCounter >> _getInvalidSessionIds
RcCounter >> _getSessionElementFor:
RcIdentityBag >> _components:
RcIdentityBag >> _indexForSessionId:
RcIdentityBag >> _privateRemove:fromRemovalBag:logging:updateRcValueCache:
RcIdentityBag >> _privateRemove:logging:updateRcValueCache:
RcIdentityBag >> _processRemovalBagFor:logging:
RcIdentityBag >> _thisSessionAdditionIndex
RcKeyValueDictionary >> _rebuildTable:logging:
RcKeyValueDictionary >> _removeKey:logging:
RcQueueSessionComponent class >> speciesOfElements
RedoLog >> addLogEntry:forConflictObject:
RedoLog >> addLogEntry:forLargeConflictObject:
RedoLog >> clear
System class >> _cancelWaitForDebugExitClient
System class >> _removeFromRcQueue
TimeZone class >> fromSolaris
TimeZone class >> _initialize1
TimeZone class >> _initialize2
The split tranlogs features allows tranlog records to be copied, as they are written, into smaller chunks whose size is determined by a timeout. The many chunk files that are written during the period that a single ordinary tranlog is written by the Stone, can be accessed or restored without combining, and many GemStone code and utilities treat these as the equivalent of an ordinary tranlog. They can be combined into a matching ordinary tranlog using copydbf or the unix cat command.
Both logsender and logreceiver support split tranlogs.
The logsender performs the copy-and-split operation. This can be done outside of a hot standby system to produce WORM-level security, reducing the interval in which the tranlog file is writable. The logsender performing the copy-and-split operation cannot also have a connection to the logreceiver to support a hot standby system. It is allowed to connect both a split-tranlogs logsender and a hot-standby logsender to the same stone, so both functions can be supported.
The Stone’s behavior when writing tranlogs is unaffected. The Stone will write its ordinary tranlogs as before.
Split-tranlog support for the logreceiver is quite different. The logreceiver receives tranlog records from the logsender and write these to the local disk. With split tranlogs enabled, the logreceiver writes these tranlogs as split tranlogs, rather than full tranlog files.
startlogsender has new arguments to allow specification of a timeout and the target directory for write. The logsender performing tranlog splits does not perform normal hot standby functions; the -P argument is used only for stoplogsender, not for listening for connections from a logreceiver.
startlogreceiver has a new argument to allow specification of a timeout. When this is used, the tranlogs received from the logsender and written by the logreceiver on the slave system, are written to the -T directories as split tranlogs,. These split tranlogs are replayed by continuous restore in the same way as ordinary tranlogs.
startlogsender has the following additional arguments:
-W <path> path to write-once filesystem for writing tranlogX.dbf.sN split tranlogs. Requires -F.
-F <writeTimeoutSecs> Write tranlogs as split tranlogs to the path specified by -W. <writeTimeoutSecs> is the allowed time for holding a tranlogX.dbf.sN open before closing that file and opening tranlogX.dbf.sM where M equals N + 1. Only used for split tranlogs. Requires -D.
When -F and -W are used, -A is disallowed, as are the SSL options -C -J -K -Q -S -V.
The logsender can be stopped and restarted, and the writing of records to split tranlogs will seamlessly resume where the previous logsender stopped.
startlogreceiver has the following additional argument:
-F <writeTimeoutSecs> Write tranlogs as split tranlogs to the directory specified by -T. <writeTimeoutSecs> is the allowed time for holding a tranlogX.dbf.sN open before closing that file and opening tranlogX.dbf.sM where M equals N + 1. Only used for split tranlogs. Requires -D.
The tranlog chunks are named tranlogTLNumber.dbf.schunkID, where the first chunkID is 0001. The chunk ID is not limited to 4 digits; 0-padding is for convenience for testing using cat, etc. With a 30 second write timeout, 4 digits provides enough chunk ids for a single tranlog to be copied as split tranlogs for more than 80 hours before requiring 5 digits. The new chunk file is not actually created until there are transactions ready to be written, so an idle system will not continuously create new chunk files.
Once the timeout has expired and the logsender is ready to start a new chunk file, the previous tranlog is fsynced to disk and made user read-only, with permission 400.
If a write, fsync, or chmod on a chunk file returns an error, the logsender will exit.
Added System methods to control split tranlogs logsender process:
System class >> killLogSenderSplitLogs
Causes stone to send SIGTERM to the log sender process that was started with the arguments -F -W.
System class >> logsenderSessionIdSplitLogs
Return the session ID of the logsender process started with -W -F, or zero if no logsender is connected to the stone process. Note a logsender can exist without a connection to the stone.
For example, to start writing split tranlogs, with chunks written every 30 seconds to a directory named /gshost/splitTranlogs/, use an expression such as the following:
startlogsender -F 30 -W /gshost/splitTranlogs/ -P 54321 -s myStoneName
If this runs for 90 seconds in an active system, it would produce the following split tranlog chunk files, in addition to writing tranlog1.dbf in the normal tranlog location:
/gshost/splitTranlogs/tranlog1.dbf.s0001
/gshost/splitTranlogs/tranlog1.dbf.s0002
/gshost/splitTranlogs/tranlog1.dbf.s0003
Chunk files are only opened read-only.
Chunk files can be used directly for copydbf or restore, by specifying the first tranlog chunk file (tranlog1.dbf.s0001). This will look for all tranlogs chunk files tranlog1.dbf.s0001...tranlog1.dbf.sN until a file N+1 is not found.
copydbf -i tranlog1.dbf.s0001
will report the status of all tranlog1.dbf.s* files.
You can use copydbf to create a merged file, which is the same as the normal tranlog1.dbf written by the Stone. The copydbf argument of the first chunk file (tranlog1.dbf.s0001) will automatically pick up the remaining chunk files.
copydbf tranlog1.dbf.s0001 tranlog1.copy.dbf
Creates a merged file containing all the tranlog1.dbf.s* files (with monotonically increasing numbers). If the stone’s ordinary tranlog is named tranlog1.dbf, then:
diff tranlog1.copy.dbf tranlog1.dbf
Chunk files can also be concatenated using cat, which produces a file that is identical to the ordinary tranlog that was written by the Stone.
cat tranlog1.dbf.s* > tranlog1.mergedChunks.dbf
This requires that all chunks be part of the monotonically increasing set; missing files in the sequence are not detected.
Also note that if more than 4 digits have been used when writing files (that is, a file tranlog1.dbf.s10000 was created), any scripts using cat would need to generate the proper sequence of input files, to ensure the files are in the correct order.
When tranlogs are opened for restore, it will look for s tranlog named tranlog1.dbf.s0001 as well as the other supported filename patterns (tranlog1.dbf, tranlog1.dbf.lz4, and tranlog1.dbf.gz). If tranlog1.dbf.s0001 is found, it is opened, read-only, as a split tranlog and all the chunk files tranlog1.dbf.s0001... tranlog1.dbf.sN until a file N+1 is not found, are restored.
Once all the chunk files that composed the tranlog are restored, it will continue restoring the next tranlog (tranlog2), which may be in any of the four supported filename patterns.
The following has been added, to avoid out of memory conditions in which the code_gen region size is the limiting factor.
Previously, if the Stone took a long time to shutdown, stopstone could return before the stone was completely shut down and the shared memory segment released, which meant that a subsequent startstone failed.
In v3.7.2, the shutdown sequence has been redesigned to avoid this situation. stopstone will block until the shared memory segment is released and startstone will be able to succeed. The Stone itself will now shut down before the Shared Page Cache Monitor. The stone and SPCMon log file messages reflect this new sequence.
The stopstone -t secs argument allows you to specify a timeout. By default (if -t is not specified), this is -1, and stopstone will wait forever for the Stone to stop and the shared memory segment to be available. Previously, stopstone errored with an explicit -t -1 argument.
In recent releases, startnetldi has tightened checking to ensure that a setting in $GEMSTONE_NRS_ALL matches the specified netldi server name.
Now, startnetldi also checks the -P and -X arguments, and any mappings in the services database.
When utilities such as startstone and startnetldi have argument errors or other startup issues, they report an error message. A number of cases in which the error message was not preceded by [ERROR] or Error: now correctly include this prefix.
The stoned command is normally invoked by startstone, however it is legal to invoke it directly. In 3.7.x, the -l argument to stoned is required.
In earlier v3.7 versions, the stoned utility SEGVed in absence of -l argument; now, it errors and the stone does not start. (#51144)
If an error occurs with a GemStone utility, usually the full usage is printed after the error message. For some utilities this is long, obscuring the actual error. Now, startstone and startnetldi will print only the usage lines, not the option details, if an error occurs. To see full details, use the -h argument.
When using a NetLDI with a name other than gs64ldi, it was previous necessary either to define the GEMSTONE_NRS_ALL, or use a gemnetid login parameter NRS that included the netldi: NRS directive, for example:
set gemnetid !@hostx#netldi:12345!gemnetobject
Now, the NetLDI name or port can be provided using the netldi topaz command. The netldi topaz command was previously restricted to use with X509 secured GemStone; now it is usable with standard logins, with different semantics. Note that it is an error to specify a netldi command argument that disagrees with a netldi: NRS argument in the environment variable GEMSTONE_NRS_ALL.
This simplifies the required fields for login when not using the default-named netldi. For example, without setting GEMSTONE_NRS_ALL, for a local login, parameters such as the following were required:
set stone myStoneName user DataCurator
set gemnetid !#netldi:12345!gemnetobject
Which can now be replaced by :
topaz> set stone myStoneName user DataCurator netldi 54321
For login from a remote node, parameters such as the following:
set stone myStoneName user DataCurator
set gemnetid !@hostx#netldi:12345!gemnetobject
topaz> set stone myStoneName user DataCurator netldi 54321
topaz> set gemnet !@hostx!gemnetobject
Many functions have been added to support working with traits in topaz; see Topaz support for traits.
DISPLAY ORIGIN causes the origin of a method that was added from a trait, or loaded from Rowan, to be displayed after the method source when a method is listed. DISPLAY ORIGIN is true by default.
The origin of a method may be an ordinary GemStone class, a trait, or rowan. Where the origin of a method is a class, then no additional information is displayed. If the origin is a trait, the name of the trait is displayed. If the origin is rowan, the name of the Rowan project and Rowan package are displayed.
topaz 1> list method addToLog:
addToLog: aString
resultToReport isNil ifTrue: [resultToReport := String new].
resultToReport add: aString.
---ORIGIN: Trait method #'LoggingTrait'---