Die xfnts_start-Methode ruft die svc_start()-Methode auf, die in der Datei xfnts.c definiert ist, um den xfs-Dämon zu starten. Dieser Abschnitt beschreibt svc_start().
Der Befehl zum Starten des xfs-Dämons lautet wie folgt:
# xfs -config Konfigurationsverzeichnis/fontserver.cfg -port Portnummer |
Die Confdir_list-Erweiterungseigenschaft identifiziert das Konfigurationsverzeichnis während die Port_list-Eigenschaft die Portnummer identifiziert. Der Cluster-Administrator gibt für diese Eigenschaften bei der Konfiguration des Datendienstes bestimmte Werte an.
Die xfnts_start-Methode deklariert diese Eigenschaften als Zeichenketten-Arrays. Die xfnts_start-Methode erhält die Werte, die der Cluster-Administrator unter Verwendung der Funktionen scds_get_ext_confdir_list() und scds_get_port_list() festlegt. Diese Funktionen werden in der Online-Dokumentation zu scds_property_functions(3HA) beschrieben.
scha_str_array_t *confdirs;
scds_port_list_t *portlist;
scha_err_t err;
/* get the configuration directory from the confdir_list property */
confdirs = scds_get_ext_confdir_list(scds_handle);
(void) sprintf(xfnts_conf, "%s/fontserver.cfg", confdirs->str_array[0]);
/* obtain the port to be used by XFS from the Port_list property */
err = scds_get_port_list(scds_handle, &portlist);
if (err != SCHA_ERR_NOERR) {
scds_syslog(LOG_ERR,
"Could not access property Port_list.");
return (1);
}
Beachten Sie, dass die confdirs-Variable auf das erste Element (0) im Array zeigt.
Die xfnts_start-Methode verwendet sprintf(), um die Befehlszeile für xfs zu bilden.
/* Construct the command to start the xfs daemon. */
(void) sprintf(cmd,
"/usr/openwin/bin/xfs -config %s -port %d 2>/dev/null",
xfnts_conf, portlist->ports[0].port);
Beachten Sie, dass die Ausgabe an /dev/null weitergeleitet wird, um vom Dämon generierte Meldungen zu unterdrücken.
Die xfnts_start-Methode übergibt die xfs-Befehlszeile an scds_pmf_start(), um den Datendienst unter PMF zu starten.
scds_syslog(LOG_INFO, "Issuing a start request.");
err = scds_pmf_start(scds_handle, SCDS_PMF_TYPE_SVC,
SCDS_PMF_SINGLE_INSTANCE, cmd, -1);
if (err == SCHA_ERR_NOERR) {
scds_syslog(LOG_INFO,
"Start command completed successfully.");
} else {
scds_syslog(LOG_ERR,
"Failed to start HA-XFS ");
}
Beachten Sie die folgenden Punkte zum Aufruf von scds_pmf_start():
Das SCDS_PMF_TYPE_SVC-Argument identifiziert das Programm so, dass es als Datendienstanwendung gestartet wird. Diese Methode kann auch einen Fehler-Monitor oder eine andere Anwendung starten.
Das SCDS_PMF_SINGLE_INSTANCE-Argument identifiziert dies als Einfachinstanzenressource.
Das cmd-Argument ist die zuvor generierte Befehlszeile.
Das endgültieg Argument, -1, gibt die untergeordnete Überwachungsebene an. Der Wert -1 gibt an, dass PMF alle untergeordneten Elemente sowie den ursprünglichen Prozess überwacht.
Vor der Rückgabe setzt svc_pmf_start() den Speicher frei, der für die portlist-Struktur zugewiesen wird.
scds_free_port_list(portlist); return (err);