Skip to main content

Config.MapMirrors

persistent class Config.MapMirrors extends %Library.Persistent, Config.GenericMapMethods, Config.GenericMapProperties, %SYSTEM.Help

SQL Table Name: Config.MapMirrors

This class allows you to activate and view Mirror definitions in the [MapMirrors.<mirror name>] section of the CPF file through programatic APIs. The properties in this section are managed via the Enterprise Management system as the information needs to be kept in sync across all of the instances which share the mirror definition. The ^MIRROR utility or the System Management Portal may be used to withdraw from a mirror in which case it will delete one of these sections.

In all of the Config methods, the CPFFile parameter defaults to the currently active CPF file. If you wish to query a different CPF file the file must be specifyied in the method call.
The Flags parameter is normally omitted; the defaults are usually sufficient for most cases.

You can use either the Get API to retrieve an array containing all of the parameters from the object or you can open an instance using the Object syntax to craete a reference variable.

EXAMPLE:

; Use class methods to retrieve properties
%SYS>s MirName="TEST"
%SYS>s Member="TESTSERVER/CACHE"
%SYS>s Status=##Class(Config.MapMirrors).Get(MirName,Member,.Properties)
%SYS>i 'Status w !,"Error="_$SYSTEM.Status.GetErrorText(Status)
%SYS>zw Properties
Properties("AgentAddress")="testserver"
Properties("AgentPort")=2188
Properties("AsyncMemberType")=0
Properties("ConnectsTo")=""
Properties("DejournalFilter")=""
Properties("ECPAddress")="testserver"  ;This is the superserver address in the documentation
Properties("EncryptCommunication")=0
Properties("GUID")="F23D0A92-5961-4E2A-BFE9-EF91880323F0"
Properties("InstanceDirectory")="c:\intersystems\cache\"
Properties("MemberType")=0
Properties("MirrorAddress")="testserver"  ;This is also called the mirror private address
Properties("MirrorSSPort")=1972
Properties("PreferredArbiter")=""
Properties("SSLComputerName")=""

Property Inventory

Method Inventory

Parameters

parameter CAPITALNAME = 1;
The Mirror System Name is always uppercase

Properties

property AgentAddress as Config.Host;
Network address (IP address preferred to avoid DNS issues) mirror members which connect to the primary should use to contact the Agent on this failover member. This is omitted reporting members as the agent is not used for mirroring on those systems. This is required on failover members. This field does not need to be specified on DR members although it will need to be filled in before promotion of the DR to a Failover member. It is best to configure the agent and the address information earlier rather than later.

The agent can transfer journal data so a private address may be desirable here to avoid network congestion.
Property methods: AgentAddressDisplayToLogical(), AgentAddressGet(), AgentAddressGetStored(), AgentAddressIsValid(), AgentAddressLogicalToDisplay(), AgentAddressLogicalToOdbc(), AgentAddressNormalize(), AgentAddressSet()
property AgentPort as %Integer;
Port # which the agent on this system is configured to listen on. ##class(SYS.Agent).GetApplicationPort() will return the current value if the local agent is active.
Property methods: AgentPortDisplayToLogical(), AgentPortGet(), AgentPortGetStored(), AgentPortIsValid(), AgentPortLogicalToDisplay(), AgentPortNormalize(), AgentPortSet(), AgentPortXSDToLogical()
property AsyncMemberType as %Integer (MAXVAL = 2, MINVAL = 0) [ InitialExpression = 0 ];
AsyncMemberType indicates the async member is a disaster recovery (DR), read-only reporting or read-write reporting async member.
0 - Disaster Recovery (DR). This is a disaster recovery async member, all its mirrored databases are read-only mirrored databases.
1 - Read-Only Reporting. This is a reporting async member, all its mirrored databases could be read-only or read-write databases, the default is read-only when the database is created.
2 - Read-Write Reporting. This is a reporting async member, all its mirrored databases could be read-only or read-write databases, the default is read-write when the database is created.
Property methods: AsyncMemberTypeDisplayToLogical(), AsyncMemberTypeGet(), AsyncMemberTypeGetStored(), AsyncMemberTypeIsValid(), AsyncMemberTypeLogicalToDisplay(), AsyncMemberTypeNormalize(), AsyncMemberTypeSet(), AsyncMemberTypeXSDToLogical()
property ConnectsTo as %String;
Reserved for future use.
Property methods: ConnectsToDisplayToLogical(), ConnectsToGet(), ConnectsToGetStored(), ConnectsToIsValid(), ConnectsToLogicalToDisplay(), ConnectsToLogicalToOdbc(), ConnectsToNormalize(), ConnectsToSet()
property DejournalFilter as %String;
The name of the filter class for mirror dejournaling, null string means the dejournal filter is disabled.
This property is meaningful only for Reporting Async members.
Property methods: DejournalFilterDisplayToLogical(), DejournalFilterGet(), DejournalFilterGetStored(), DejournalFilterIsValid(), DejournalFilterLogicalToDisplay(), DejournalFilterLogicalToOdbc(), DejournalFilterNormalize(), DejournalFilterSet()
property ECPAddress as Config.Host;
This is the superserver address referenced in the documentation for this instance. External mirror-aware systems can connect to the primary using this address. Currently the only such external systems are ECP application servers connecting to failover members. This is distributed to the ECP clients, along with the address for the other failover member (if there is one) when an ECP client builds a connection to a mirror.

Other mirror members may also make connections to a member's superserver address for certain control and monitoring purposes. When a member is primary, async members attempt to establish their data channel to the member using this address if the mirror private address is not accessible, which means that journal data may travel over the network via this address.

This a required field on failover members, optional on others.
Property methods: ECPAddressDisplayToLogical(), ECPAddressGet(), ECPAddressGetStored(), ECPAddressIsValid(), ECPAddressLogicalToDisplay(), ECPAddressLogicalToOdbc(), ECPAddressNormalize(), ECPAddressSet()
property EncryptCommunication as %Integer [ InitialExpression = 0 ];
When SSL is not required by Config.Mirrors.UseSSL mirror wide setting, this property controls whether this member uses SSL for its outgoing connections and/or whether it requires SSL for its incoming connections. Whenever SSL is used to encrypt a connection, the endpoints also perform authorization and verify that the DN name in the SSL configuration matches the listed SSLComputerName for that system in the Mirror configuration.

Values are:
  • 0 - Encryption is not required. Outgoing connections may still be encrypted if the member we connect to requires SSL for incoming connections.

  • 1 - SSL is used to encrypt outgoing connections. the server must have an SSL Mirror configuration or the connection will fail

  • 2 - Encryption is required for incoming connections. The clients which connect must have an SSL Mirror configuration or the connection will fail

  • 3 - Both 1+2: Outgoing connections are encrypted, encryption is required for incoming connections

  • Property methods: EncryptCommunicationDisplayToLogical(), EncryptCommunicationGet(), EncryptCommunicationGetStored(), EncryptCommunicationIsValid(), EncryptCommunicationLogicalToDisplay(), EncryptCommunicationNormalize(), EncryptCommunicationSet(), EncryptCommunicationXSDToLogical()
property GUID as %String [ Required ];
Uniquely identifies this node in the mirror. Apart from identifying the nodes, primary used to identify the instance that owns a particular copy of a mirrored database.
Property methods: GUIDDisplayToLogical(), GUIDGet(), GUIDGetStored(), GUIDIsValid(), GUIDLogicalToDisplay(), GUIDLogicalToOdbc(), GUIDNormalize(), GUIDSet()
property InstanceDirectory as %SysPath [ Required ];
The installation directory of the instance (the parent of the mgr directory). Used primarily on failover members to identify the instance to the agent
Property methods: InstanceDirectoryDisplayToLogical(), InstanceDirectoryGet(), InstanceDirectoryGetStored(), InstanceDirectoryIsValid(), InstanceDirectoryLogicalToDisplay(), InstanceDirectoryLogicalToOdbc(), InstanceDirectoryNormalize(), InstanceDirectorySet()
property MemberType as %Integer [ InitialExpression = 0 , Required ];
Numeric value indicating the type of mirror member.

0 - Failover member
1 - <reserved for future use>
2 - Async member (doesn't accept client connections)
(defined in %syMirror.inc as FailoverMemberType, AsyncMemberType)
Property methods: MemberTypeDisplayToLogical(), MemberTypeGet(), MemberTypeGetStored(), MemberTypeIsValid(), MemberTypeLogicalToDisplay(), MemberTypeNormalize(), MemberTypeSet(), MemberTypeXSDToLogical()
property MirrorAddress as Config.Host [ Required ];
Address (IP preferred to avoid DNS troubles) the other mirror members should use to contact the superserver on this instance. When a Caché instance is running as the primary failover member, each of the other mirror members uses the mirror private address to establish its mirror data channel, the channel over which it receives journal data from the primary and the most heavily used mirror communication channel.

Failover members are restricted in that they can only use this address for establishing the connection to receive live updates. Async members attempt to use this address to connect to the primary but fall back to the superserver address (ECPAddress property) if necessary.

This documentation refers to ths property as the Mirror Private Address.
Property methods: MirrorAddressDisplayToLogical(), MirrorAddressGet(), MirrorAddressGetStored(), MirrorAddressIsValid(), MirrorAddressLogicalToDisplay(), MirrorAddressLogicalToOdbc(), MirrorAddressNormalize(), MirrorAddressSet()
property MirrorSSPort as %Integer [ Required ];
SuperServer port for this instance. Used in conjunction with both the MirrorAddress and the ECPAddress by clients establishing connections to this instance.
Property methods: MirrorSSPortDisplayToLogical(), MirrorSSPortGet(), MirrorSSPortGetStored(), MirrorSSPortIsValid(), MirrorSSPortLogicalToDisplay(), MirrorSSPortNormalize(), MirrorSSPortSet(), MirrorSSPortXSDToLogical()
property Name as %String (MAXLEN = 32) [ Required ];
This is the name of this instance in the mirror. Mirror system names must be unique (enforced by Enterprise Manager) across all of the mirrors which the EM manages, as an instance has a single mirror system name which may appear in multiple mirror sets (eg. a reporting member may connect to multiple mirrors). For the most part the GUID is used to identify a mirror member, the Name is used for display purposes.

The name must not contain a colon (':') and is converted to uppercase before saving.
Property methods: NameDisplayToLogical(), NameGet(), NameGetStored(), NameIsValid(), NameLogicalToDisplay(), NameLogicalToOdbc(), NameNormalize()
property SSLComputerName as %String (MAXLEN = 1024);
Value of the DN field in the SSL certificate which is part of the %Mirror SSL configuration on this instance. When SSL is enabled an instance sends this value as part of establishing a TCP connection. Both sides of the connection verify that the other side's DN value matches a value stored in the configuration. It is best for every mirror member to have a unique DN value as otherwise it may be possible for a system that was removed from the mirror to still connect if it's DN value matches the DN stored with another system of the same type (eg. async v. failover).
Property methods: SSLComputerNameDisplayToLogical(), SSLComputerNameGet(), SSLComputerNameGetStored(), SSLComputerNameIsValid(), SSLComputerNameLogicalToDisplay(), SSLComputerNameLogicalToOdbc(), SSLComputerNameNormalize(), SSLComputerNameSet()

Methods

classmethod %OnDeleteCallBack(Obj As %ObjectHandle) as %Status
Called from %Delete().
Any error returned here will keep the object from being deleted.
classmethod Count(mirrorname As %String, othersonly As %Boolean = 0, ByRef CPFFile As %String = "") as %Integer
Returns the number of mirror set members defined in a configuration. If othersonly is set we exclude ourselves (if we're listed) from the total.

Queries

query List(ID As %String, Names As %String = "*", CPFFile As %String = "", Flags As %Integer = 0, Format As %Integer = 0)
Selects Name As %String, AgentAddress As %String, AgentPort As %Integer, ConnectsTo As %String, ECPAddress As %String, GUID As %String, InstanceDirectory As %String, MemberType As %Integer, MirrorAddress As %String, MirrorSSPort As %Integer, SSLComputerName As %String, EncryptCommunication As %Integer, PreferredArbiter As %String, DejournalFilter As %String, AsyncMemberType As %Integer
List MapMirrors section in a CPF file.

Parameters:
Names - Comma separated list of MapMirror names
"*" - All records match
"String,String1" - Any records matching one of these elements
"String*" - Any record starting with "String"
"String,String1*,String2" - Any record mathing one of these elements, or starting with "String1"
CPFFile - Name of the CPF file to use. A null string means use the active CPF file.
Flags - Currently ignored.
Format
0 - Standard report list format
1 - ^CONFIG global format
2 - CPF file format format
Note: This query may change in future versions

Indexes

index (CPFNameSectionHeaderIDName on CPFName,SectionHeader,ID,Name) [IdKey, Type = key, Unique];
Index methods: CPFNameSectionHeaderIDNameCheck(), CPFNameSectionHeaderIDNameDelete(), CPFNameSectionHeaderIDNameExists(), CPFNameSectionHeaderIDNameOpen(), CPFNameSectionHeaderIDNameSQLCheckUnique(), CPFNameSectionHeaderIDNameSQLExists(), CPFNameSectionHeaderIDNameSQLFindPKeyByConstraint(), CPFNameSectionHeaderIDNameSQLFindRowIDByConstraint()

Inherited Members

Inherited Properties

Inherited Methods

Storage

Storage Model: CacheStorage (Config.MapMirrors)

^|"^^"_$ZU(12)|SYS("CONFIG")(ID)
=
Directory
Comments
AgentAddress
AgentPort
ConnectsTo
ECPAddress
GUID
InstanceDirectory
MemberType
MirrorAddress
MirrorSSPort
SSLComputerName
EncryptCommunication
PreferredArbiter
DejournalFilter
AsyncMemberType
FeedbackOpens in a new tab