* Initial code to implement multi-instance queue manager * alter default mqsc to prevent race between listeners on standby startup * Updates to multi-instance queue manager code * initial multi instance test * Multi-instance code improvements * Multi instance fixes and first test * configure queue manager * Add mirror log filtering for mult-instance QMs * Add log message for multi-instance enabled * Improvements to container runtime logging * refactor test * Test active standby switch * Improve createQueueManager function * Test multi instance race * wait * multi instance mount tests * skip race test * mount tests * no mount test * single instance split mount tests * readiness check * More updates for handling standby queue manager * Improve standby checks * Minor fixes to miqm * Fix logging of JSON errors * Update copyrights * Fix log includes
79 lines
2.2 KiB
Go
79 lines
2.2 KiB
Go
/*
|
|
© Copyright IBM Corporation 2018, 2019
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
// Package mqini provides information about queue managers
|
|
package mqini
|
|
|
|
import (
|
|
"bufio"
|
|
"path/filepath"
|
|
"strings"
|
|
|
|
"github.com/ibm-messaging/mq-container/internal/command"
|
|
)
|
|
|
|
// QueueManager describe high-level configuration information for a queue manager
|
|
type QueueManager struct {
|
|
Name string
|
|
Prefix string
|
|
Directory string
|
|
DataPath string
|
|
InstallationName string
|
|
}
|
|
|
|
// getQueueManagerFromStanza parses a queue manager stanza
|
|
func getQueueManagerFromStanza(stanza string) (*QueueManager, error) {
|
|
scanner := bufio.NewScanner(strings.NewReader(stanza))
|
|
qm := QueueManager{}
|
|
for scanner.Scan() {
|
|
l := scanner.Text()
|
|
l = strings.TrimSpace(l)
|
|
t := strings.Split(l, "=")
|
|
switch t[0] {
|
|
case "Name":
|
|
qm.Name = t[1]
|
|
case "Prefix":
|
|
qm.Prefix = t[1]
|
|
case "Directory":
|
|
qm.Directory = t[1]
|
|
case "DataPath":
|
|
qm.DataPath = t[1]
|
|
case "InstallationName":
|
|
qm.InstallationName = t[1]
|
|
}
|
|
}
|
|
return &qm, scanner.Err()
|
|
}
|
|
|
|
// GetQueueManager returns queue manager configuration information
|
|
func GetQueueManager(name string) (*QueueManager, error) {
|
|
// dspmqinf essentially returns a subset of mqs.ini, but it's simpler to parse
|
|
out, _, err := command.Run("dspmqinf", "-o", "stanza", name)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return getQueueManagerFromStanza(out)
|
|
}
|
|
|
|
// GetErrorLogDirectory returns the directory holding the error logs for the
|
|
// specified queue manager
|
|
func GetErrorLogDirectory(qm *QueueManager) string {
|
|
if qm.DataPath != "" {
|
|
return filepath.Join(qm.DataPath, "errors")
|
|
}
|
|
return filepath.Join(qm.Prefix, "qmgrs", qm.Directory, "errors")
|
|
}
|