Auf Englisch lesen

Freigeben über


LogArchiveSnapshot Klasse

Definition

Stellt eine Momentaufnahme der LogStore-Instanz dar, die verwendet werden kann, um ein Archiv zu generieren.

C#
public sealed class LogArchiveSnapshot
Vererbung
LogArchiveSnapshot

Beispiele

Im folgenden Beispiel wird die Verwendung der LogArchiveSnapshot-Klasse zur Archivierung eines LogStore in einem XML-Dokument veranschaulicht.

C#
class LogBackup
{
    static void ArchiveToXML(LogStore logStore, string fileName)
    {
        LogArchiveSnapshot snapshot = logStore.CreateLogArchiveSnapshot();

        XmlTextWriter writer = new XmlTextWriter(fileName, Encoding.ASCII);

        writer.WriteStartElement("logArchive");
        foreach(FileRegion region in snapshot.ArchiveRegions)
        {
            writer.WriteStartElement("fileRegion");
            writer.WriteElementString("path", region.Path);
            writer.WriteElementString("length", region.FileLength.ToString());
            writer.WriteElementString("offset", region.Offset.ToString());
            using(Stream dataStream = region.GetStream())
            {
                byte[] data = new byte[dataStream.Length];
                dataStream.Read(data, 0, data.Length);
                writer.WriteElementString("data", Convert.ToBase64String(data));
            }
            writer.WriteEndElement();
        }
        writer.WriteEndElement();
        writer.Close();
        logStore.SetArchiveTail(snapshot.LastSequenceNumber);
    }
    static void RestoreFromXML(string fileName)
    {
        using(XmlTextReader reader = new XmlTextReader(fileName))
        {
            reader.ReadStartElement("logArchive");
            while(reader.IsStartElement())
            {
                string path = reader.ReadElementString("path");
                long length = Int64.Parse(reader.ReadElementString("length"));
                long offset = Int64.Parse(reader.ReadElementString("offset"));
                string dataString = reader.ReadElementString("data");
                byte[] data = Convert.FromBase64String(dataString);
                FileStream fileStream;
                using(fileStream = new FileStream(path, FileMode.OpenOrCreate, FileAccess.Write))
                {
                    fileStream.SetLength(length);
                    fileStream.Position = offset; fileStream.Write(data, 0, data.Length);
                }
            }
        reader.ReadEndElement();
        }
    }
}

Hinweise

Ein LogArchiveSnapshot-Objekt enthält die Informationen, die erforderlich sind, um regelmäßige Sicherungskopien der Daten in einem LogStore zu generieren. Die tatsächlichen Daten sind in der zählbaren Auflistung von FileRegion-Objekten enthalten, die von der ArchiveRegions-Eigenschaft zurückgegeben wird. Jede FileRegion-Instanz stellt eine Bytesequenz in einer Datei dar, die archiviert werden muss.

Die Eigenschaften ArchiveTail, BaseSequenceNumber und LastSequenceNumber dienen nur zur Information. Sie können gemeinsam mit den Archivdaten aufgezeichnet werden, damit zusätzliche Informationen verfügbar sind. Zur Wiederherstellung der Daten sind sie jedoch nicht erforderlich.

Eigenschaften

ArchiveRegions

Ruft eine zählbare Auflistung von FileRegion-Instanzen ab, die die tatsächlichen Archivierungsdaten enthält.

ArchiveTail

Ruft die Sequenznummer des LogStore-Archivendes zu der Zeit ab, als die Momentaufnahme aufgezeichnet wurde.

BaseSequenceNumber

Ruft die Basissequenznummer von LogStore zu der Zeit ab, als die Momentaufnahme aufgezeichnet wurde.

LastSequenceNumber

Ruft die letzte Sequenznummer von LogStore zu der Zeit ab, als die Momentaufnahme aufgezeichnet wurde.

Methoden

Equals(Object)

Bestimmt, ob das angegebene Objekt gleich dem aktuellen Objekt ist.

(Geerbt von Object)
GetHashCode()

Fungiert als Standardhashfunktion.

(Geerbt von Object)
GetType()

Ruft den Type der aktuellen Instanz ab.

(Geerbt von Object)
MemberwiseClone()

Erstellt eine flache Kopie des aktuellen Object.

(Geerbt von Object)
ToString()

Gibt eine Zeichenfolge zurück, die das aktuelle Objekt darstellt.

(Geerbt von Object)

Gilt für:

Produkt Versionen
.NET Framework 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1