Dieses Dokument beschreibt ein Problem, das beim Upgrade von Cisco Unified Contact Center Express (UCCX)-Systemen auf Version 8 und höher sowie beim Hochladen einer großen Anzahl von Repository-Elementen auf das System oder beim Uploaden einer großen Anzahl von Repository-Elementen auf das System in Version 8 oder höher auftritt.
UCCX-Versionen 7.x und höher verwenden Microsoft SQL (MSSQL) als Datenbankmodul. MSSQL unterscheidet in Bezug auf die Datenspeicherung nicht zwischen Daten verschiedener Typen. Wenn Daten in einer 3-GB-Datenbank gespeichert werden, speichert MSSQL alle Daten unabhängig vom Typ in einem 3-GB-Block.
Im Gegensatz dazu unterscheidet Informix, die in UCCX Version 8.0 und höher verwendete Datenbank-Engine, beim Speichern auf der Festplatte zwischen Daten verschiedener Typen. Typische Datenbankdaten (z. B. Zeichenfolgen, Zeichen und Integer.) werden in einem Festplattenchunk gespeichert, der der Datenbank gewidmet ist, während BLOB-Daten (Binary Large Object), sofern sie in den Datensätzen der Datenbanktabelle vorhanden sind, in einem separaten Bereich der Festplatte gespeichert werden, der als Leerzeichen bezeichnet wird. Ein Leerzeichen ist eine logische Einheit, die aus einem oder mehreren Festplatten-Chunks besteht, die BLOB-Daten speichern. Informix speichert traditionelle Daten und BLOB-Daten separat, um die Leistung beim Lesen und Schreiben von BLOB-Daten von und auf die Datenbank und den Datenträger zu erhöhen. Wenn eine Datenbank erstellt wird, die BLOB-Daten enthält, muss der Administrator die Größe der Festplatten-Chunks für die Datenbank (um herkömmliche Daten zu speichern) und die Größe des Leerzeichens einzeln angeben.
Für Datenspeicherungsmechanismen platziert MSSQL alle Daten in einer einzigen Gruppe der Größe N, während Informix die Speicherung dieser Daten in zwei Gruppen aufteilt: ein Eimer für die Kontextinformationen über BLOB-Daten der Größe X und ein weiterer Eimer für die BLOB-Objekte der Größe Y.
In UCCX kann der Administrator Repository-Elemente hochladen, die aus Prompts, Documents, Grammars und Scripts bestehen. Der Inhalt dieser Elemente wird in den entsprechenden Datenbanktabellen als BLOB-Daten und Kontextinformationen über sie gespeichert, z. B. Dateiname, Ordner, letzte geänderte Uhrzeit, zuletzt geänderter Benutzer, Länge und Prüfsumme.
Repository-Elemente werden in der UCCX-Datenbank db_cra_repository gespeichert. In UCCX-Versionen 7.x und früher, die MSSQL verwenden, ist das db_cra_repository 3 GB groß und enthält sowohl die Kontextinformationen als auch die BLOB-Informationen. In UCCX-Versionen 8.0 und höher, die Informix verwenden, ist der an das db_cra_repository angehängte Datenspeicher 10,2 MB groß und speichert nur die Kontextinformationen zu den Repository-Elementen. Der Inhalt der Repository-Objekte wird im BLOB-Format in einem Leerzeichen mit der Bezeichnung uccx_sbspace gespeichert. In UCCX-Versionen 8.0 und höher beträgt der uccx_sbspace 3 GB.
Die Ausgabe von show uccx dbserver disk auf einem UCCX Version 8.0+-Server zeigt die Unterscheidung zwischen diesen beiden Datenspeichern:
Abhängig von der Mischung von Daten in der MSSQL-Datenbank ist es möglich, dass die Größe der in der MSSQL-Datenbank gespeicherten BLOB-Daten die definierte Größe des in Informix enthaltenen Speicherplatzes überschreitet, wenn eine Migration oder ein Upgrade versucht wird. Ebenso ist es möglich, dass die Kontextinformationen über die in der MSSQL-Datenbank gespeicherten BLOB-Daten die vom Administrator festgelegte Größe für diese Daten im Informix-Datenbankchunk überschreiten.
In diesem Fall schlägt das Upgrade oder die Migration von UCCX Version 7.x auf UCCX Version 8.x fehl, da entweder das db_cra_repository oder der uccx_sbspace nicht groß genug sind, um die gleichen Informationen zu speichern, die in MSSQL gespeichert wurden. Dies ist in der Regel ein Problem in einem UCCX-System, das eine große Anzahl von Aufforderungen enthält. Kontextbezogene Prompt- und BLOB-Daten müssen das db_cra_repository und das uccx_sbspace mit Dokumenten, Grammaren und Scripts gemeinsam nutzen, aber diese anderen Repository-Typen sind in der Regel klein in Größe und Anzahl.
Betrachten Sie beispielsweise ein UCCX-System der Version 7.x mit Zehntausenden von Aufforderungen, die jeweils nur wenige Sekunden Audio enthalten. In der UCCX-Version 7.x, die MSSQL verwendet, werden der Inhalt und die Kontextinformationen zur Aufforderung im selben 3-GB-Textbaustein gespeichert. Da es viele kleine Eingabeaufforderungen gibt, speichert die Datenbank möglicherweise 50 MB kontextbezogene Informationen zu den Aufforderungen, aber nur 2 GB BLOB-Daten, die das Audio der Aufforderungen darstellen. Daher belegen die Prompts im Repository etwas mehr als 2 GB der 3-GB-Grenze, die bei der Datenbankerstellung festgelegt wurde.
Wenn Sie versuchen, dieses System auf UCCX Version 8.x und Informix zu migrieren, schlägt die Migration fehl, weil die 50 MB an Kontextinformationen die 10,2 MB-Grenze des db_cra_repostiory überschreiten, obwohl der 2 GB Prompt Content weit unter die Grenze des uccx_sbspace passt.
Umgekehrt sollten Sie ein UCCX 7.x-System mit weniger, aber immer noch vielen, langen Eingabeaufforderungen in Betracht ziehen. Bei weniger Eingabeaufforderungen, aber mit einer größeren Anzahl von Aufforderungen ist das Verhältnis von auffordertem Inhalt zu kontextbezogenen Informationen unterschiedlich. In UCCX Version 7.x und MSSQL kann der Prompt-Inhalt bis zu 2,8 GB des db_cra_repository beanspruchen, und die Kontextinformationen 3 MB. Dieses System wird erfolgreich aktualisiert, da die 3 MB in das db_cra_repository passt und die 2,8 GB in den zugewiesenen uccx_sbspace passt.
Wenn Sie versuchen, auf UCCX Version 8.x oder höher zu migrieren, überschreiten die Kontextdaten der auf das UCCX Version 7.x oder frühere System hochgeladenen Aufforderungen normalerweise die Größenbeschränkung von db_cra_repository, bevor der Aufforderungsinhalt die Größenbeschränkung des uccx_sbspace überschreitet. Zusätzlich ist der tatsächliche freie Speicherplatz für benutzerdefinierte Repository-Objekte 6,9 MB, da die Standardkonfiguration 3,4 MB des db_cra_repository belegt.
Wenn Sie versuchen, neue Repository-Elemente (Dokumente, Grammare, Aufforderungen, Skripte) auf ein UCCX-System hochzuladen, das Version 8 oder höher ausführt, erhalten Sie die folgende Fehlermeldung:
The files uploaded are not valid or not structured
according to languages. Please check the help
documentation for more details.
Durch die Migration von UCCX-Version 7.0(2) und früher auf Version 8.0 und höher werden das Betriebssystem und die Datenbankengine geändert, auf der die Anwendung ausgeführt wird. Das in UCCX Version 8.0 und höher verwendete Datenbankmodul speichert Daten anders als die in UCCX Version 7.x und höher gespeicherten Daten. Dies hat Auswirkungen auf die Migration von UCCX, da Datenbanken mit großen Datensätzen in UCCX-Version 7.x möglicherweise nicht ordnungsgemäß auf UCCX-Version 8.x migriert werden.
Bevor Sie auf UCCX Version 8.x migrieren, schätzen Sie die Menge des db_cra_repository und uccx_sbspace, die zum Speichern der aktuellen Repository-Objekte im UCCX Version 7.x-System erforderlich ist, um ein künftiges Wachstum aufzunehmen.
Bestimmen Sie zunächst die Anzahl der Zeilen in jeder der Repository-Tabellen, die Informationen zu Repository-Elementen und -Ordnern enthalten.
Verwenden Sie Microsoft SQL Query Analyzer, um die Anzahl der Zeilen aus den Ordnertabellen des Repository mit folgenden Befehlen aufzuzeichnen:
Informix berücksichtigt die Größe der Festplatte in Seiten. Bestimmen Sie die Anzahl der Seiten, die von den Inhalten der Repository-Ordnertabellen mit dieser Formel belegt werden, und ersetzen Sie die Anzahl der Zeilen durch die Zählungen, die aus den zuvor genannten Befehlen stammen. Berechnen Sie diese Formel für jede Tabelle, und fügen Sie die Anzahl der Seiten hinzu. Es ist nicht möglich, die Anzahl der Seiten genau zu bestimmen, wenn zuerst die Anzahl der Zeilen aus jeder Tabelle hinzugefügt wird, und dann wird das Ergebnis der Formel berechnet.
# Seiten documentfoldertbl + # Seiten grammarsfoldertbl + # Seiten promptsfoldertbl + # Seiten scriptseitenfoldertbl = Gesamtanzahl Seiten für Ordnertabellen
Führen Sie die gleiche Berechnung durch, um die Gesamtzahl der Seiten für die Dateitabellen zu ermitteln, die die eigentlichen Repository-Elemente enthalten. Geben Sie diese Befehle mit Microsoft SQL Query Analyzer ein:
Bestimmen Sie die Anzahl der Seiten, die von den Inhalten der Repository-Dateitabellen mit dieser Formel belegt sind, und ersetzen Sie die Anzahl der Zeilen durch die Zählungen, die aus den zuvor genannten Befehlen stammen. Berechnen Sie die Formel für jede Tabelle, und fügen Sie die Anzahl der Seiten hinzu.
# Pages documentsFileBl + # Pages grammarsfiletbl + # Pages promptsfiletbl + # Pages scriptsfiletbl = Gesamtanzahl der Seiten für Dateitabellen
Führen Sie diese Berechnungen durch, um die aktuelle Größenschätzung der Repository-Daten abzuschließen:
Wenn die Berechnungen zeigen, dass die Kontextinformationen zu den aktuell in UCCX Version 7.x hochgeladenen Repository-Elementen und -Ordnern 3,4 MB überschreiten, wird empfohlen, das Design der Repository-Elemente neu zu gestalten. Obwohl der freie Speicherplatz für die kontextbezogenen Informationen über Repository-Objekte in db_cra_repository 6,9 MB beträgt, wird empfohlen, 50% für zukünftiges Wachstum verfügbar zu lassen. Die Wachstumsschätzungen und der maximal zulässige Speicherplatz werden pro Bereitstellung auf Basis der erwarteten Wachstumsfaktoren berechnet.
Da Prompts in der Regel der größte Verbraucher des Repository-Speicherplatz sind, werden im Rest dieses Artikels Methoden zur Reduzierung der Anzahl von Prompts im Repository beschrieben.
Wenn die derzeit im UCCX Version 7.x-Repository hochgeladenen Eingabeaufforderungen einen wesentlichen Teil des gesamten Speicherplatz im Repository belegen, müssen Sie Design, Speicherung und Abruf der Prompt-Anweisung vor der Migration auf UCCX Version 8.x umgestalten. Wenn Sie das Prompt-Design umgestalten möchten, sollten Sie folgende Optionen in Betracht ziehen:
VXML wird verwendet, um Prompts On-Demand von einem externen Ort abzurufen und abzuspielen. Wenn Sie große Mengen von Aufforderungen auf einem separaten Webserver speichern, können Sie:
Obwohl viele Optionen zur Instrumentierung der interaktiven Sprachsteuerung (IVR) in VXML vorhanden sind, werden das UCCX-Skript und die VXML-Anwendung verwendet, um eine Aufforderung von einem externen Webserver abzurufen und an den Anrufer abzuspielen, als Grundlage für die weitere Entwicklung. Wie andere benutzerdefinierte Skripts in UCCX werden die in diesem Abschnitt bereitgestellten Skripts als Leitfaden angeboten und werden nicht vom Cisco Technical Assistance Center (TAC) unterstützt.
Der Schritt Sprachbrowser verwendet ein VXML-Dokument. Dieses Dokument muss als Ergebnis des Schritts URL-Dokument erstellen erstellt und auf einem externen Webserver außerhalb von UCCX gehostet werden. Obwohl die VXML-Anwendung geschrieben wurde, um Anrufereingaben über Dual Tone Multi Frequency (DTMF) zu akzeptieren, wurde diese Anwendung nur für die Wiedergabe einer externen Aufforderung entwickelt. Sie kann jedoch erweitert werden, um zusätzliche Funktionen einzuschließen. Es wird davon ausgegangen, dass der Rest des UCCX-Skripts, bevor der Schritt Sprachbrowser aufgerufen wird, über die Logik verfügt, die erforderlich ist, um festzustellen, welche Eingabeaufforderung wiedergegeben wird, und eine String-Variable auf den Dateinamen Prompt festgelegt wird.
Da das VXML-Dokument statisch, aber dynamisch dargestellt wird, wird eine Skriptsprache auf Serverseite verwendet, um das VXML-Dokument zu erstellen. Dabei kann es sich um eine beliebige serverseitige Skriptsprache handeln, die den Content-Type-Header der XML GET-Anforderung-Antwort festlegen kann. In diesem Beispiel wird PHP verwendet.
Die PHP-Seite wird geschrieben, um einen URL-Parameter in einer GET-Anforderung zu akzeptieren, die den Namen der Audioaufforderung darstellt, der abgespielt wird. Die PHP-Seite verknüpft die VXML-Vorlage mit dem in den URL-Parametern für die GET-Anforderung übergebenen Dateinamen Prompt, um das vollständige VXML-Dokument zu bilden. Anschließend wird der Content-Type-Header der Antwort auf XML festgelegt, und der Text der Antwort wird als VXML-Inhalt festgelegt.
<?php
$wav_filename = $_GET['wav'];
$xml_string = '<?xml version="1.0"?>
<vxml xmlns="http://www.w3.org/2001/vxml" version="2.0">
<form>
<block>
<prompt bargein="true">
<audio src="http://<Servername or IP Address>/
<Path>/'.$wav_filename.'.wav" />
</prompt>
</block>
</form>
</vxml>';
header('Content-type: text/xml');
echo $xml_string;
?>
Um ein gut geformtes VXML-Dokument zu erstellen, muss auf die PHP-Beispielseite mit einer GET Request zugegriffen werden, die einen Parameter wav und einen String-Wert enthält, wobei davon ausgegangen wird, dass die PHP-Beispielseite den Namen generatevxml.php hat:
http:///path/generatevxml.php?wav=MenuPrompt
Stellen Sie sicher, dass sich die MenuPrompt.wav an der Stelle auf dem externen Webserver befindet, der in der in der PHP-Seite enthaltenen VXML-Vorlage angegeben ist.
Verwenden Sie im UCCX-Skript den Schritt URL-Dokument erstellen, um eine GET-Anforderung von generatevxml.php auszuführen, die die Basis-URL von http://<Servername oder IP-Adresse>/path/generatevxml.php?wav= mit dem aus der vorherigen Skriptlogik abgeleiteten Forderungsdateinamen verkettet, und legen Sie das Ergebnis in eine Dokumentvariable.
Erstellen Sie einen Sprachbrowser-Schritt, der die Dokumentvariable verwendet.
Wenn dieses Skript aufgerufen wird, wird dem Aufrufer die MenuPrompt.wav-Eingabeaufforderung abgespielt, vorausgesetzt, sowohl generatevxml.php als auch MenuPrompt.wav sind auf dem Webserver von UCCX zugänglich.
Wenn VXML-Anwendungen verwendet werden, um externe Aufforderungen zu speichern, sodass auf diese nur bei Bedarf zugegriffen wird, um sie dem Anrufer wiederzugeben, ermöglicht dies eine höhere Effizienz, Verwaltbarkeit und Wartungsfreundlichkeit. Dieses Problem sollte beachtet werden, wenn ein UCCX Version 7.x-System auf ein UCCX Version 8.x-System aktualisiert wird und die Anzahl der Aufforderungen so groß ist, dass der Inhalt der Kontextinformationen größer ist als der Inhalt des db_cra_repository oder des uccx_sbspace.
Überarbeitung | Veröffentlichungsdatum | Kommentare |
---|---|---|
1.0 |
12-Sep-2013 |
Erstveröffentlichung |