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);