mirror of
https://github.com/ppy/osu.git
synced 2025-01-13 19:52:55 +08:00
Fix realm backup creation failing when run from RealmAccess
constructor
At the point of construction, we are not on the update thread, but it doesn't really matter at this point because there's no other usages.
This commit is contained in:
parent
64edc6888d
commit
506409a9c4
@ -132,11 +132,12 @@ namespace osu.Game.Database
|
|||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
realm.CreateBackup(Path.Combine(backup_folder, $"client.{backupSuffix}.realm"), realmBlockOperations);
|
realm.CreateBackup(Path.Combine(backup_folder, $"client.{backupSuffix}.realm"));
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
// Above call will dispose of the blocking token when done.
|
// Once the backup is created, we need to stop blocking operations so the migration can complete.
|
||||||
|
realmBlockOperations.Dispose();
|
||||||
// Clean up here so we don't accidentally dispose twice.
|
// Clean up here so we don't accidentally dispose twice.
|
||||||
realmBlockOperations = null;
|
realmBlockOperations = null;
|
||||||
}
|
}
|
||||||
|
@ -184,14 +184,14 @@ namespace osu.Game.Database
|
|||||||
|
|
||||||
// If a newer version database already exists, don't backup again. We can presume that the first backup is the one we care about.
|
// If a newer version database already exists, don't backup again. We can presume that the first backup is the one we care about.
|
||||||
if (!storage.Exists(newerVersionFilename))
|
if (!storage.Exists(newerVersionFilename))
|
||||||
CreateBackup(newerVersionFilename);
|
createBackup(newerVersionFilename);
|
||||||
|
|
||||||
storage.Delete(Filename);
|
storage.Delete(Filename);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Logger.Error(e, "Realm startup failed with unrecoverable error; starting with a fresh database. A backup of your database has been made.");
|
Logger.Error(e, "Realm startup failed with unrecoverable error; starting with a fresh database. A backup of your database has been made.");
|
||||||
CreateBackup($"{Filename.Replace(realm_extension, string.Empty)}_{DateTimeOffset.UtcNow.ToUnixTimeSeconds()}_corrupt{realm_extension}");
|
createBackup($"{Filename.Replace(realm_extension, string.Empty)}_{DateTimeOffset.UtcNow.ToUnixTimeSeconds()}_corrupt{realm_extension}");
|
||||||
storage.Delete(Filename);
|
storage.Delete(Filename);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -236,7 +236,7 @@ namespace osu.Game.Database
|
|||||||
}
|
}
|
||||||
|
|
||||||
// For extra safety, also store the temporarily-used database which we are about to replace.
|
// For extra safety, also store the temporarily-used database which we are about to replace.
|
||||||
CreateBackup($"{Filename.Replace(realm_extension, string.Empty)}_{DateTimeOffset.UtcNow.ToUnixTimeSeconds()}_newer_version_before_recovery{realm_extension}");
|
createBackup($"{Filename.Replace(realm_extension, string.Empty)}_{DateTimeOffset.UtcNow.ToUnixTimeSeconds()}_newer_version_before_recovery{realm_extension}");
|
||||||
|
|
||||||
storage.Delete(Filename);
|
storage.Delete(Filename);
|
||||||
|
|
||||||
@ -778,9 +778,19 @@ namespace osu.Game.Database
|
|||||||
private string? getRulesetShortNameFromLegacyID(long rulesetId) =>
|
private string? getRulesetShortNameFromLegacyID(long rulesetId) =>
|
||||||
efContextFactory?.Get().RulesetInfo.FirstOrDefault(r => r.ID == rulesetId)?.ShortName;
|
efContextFactory?.Get().RulesetInfo.FirstOrDefault(r => r.ID == rulesetId)?.ShortName;
|
||||||
|
|
||||||
public void CreateBackup(string backupFilename, IDisposable? blockAllOperations = null)
|
/// <summary>
|
||||||
|
/// Create a full realm backup.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="backupFilename">The filename for the backup.</param>
|
||||||
|
public void CreateBackup(string backupFilename)
|
||||||
{
|
{
|
||||||
using (blockAllOperations ?? BlockAllOperations("creating backup"))
|
if (realmRetrievalLock.CurrentCount != 0)
|
||||||
|
throw new InvalidOperationException($"Call {nameof(BlockAllOperations)} before creating a backup.");
|
||||||
|
|
||||||
|
createBackup(backupFilename);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void createBackup(string backupFilename)
|
||||||
{
|
{
|
||||||
Logger.Log($"Creating full realm database backup at {backupFilename}", LoggingTarget.Database);
|
Logger.Log($"Creating full realm database backup at {backupFilename}", LoggingTarget.Database);
|
||||||
|
|
||||||
@ -802,7 +812,6 @@ namespace osu.Game.Database
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Flush any active realm instances and block any further writes.
|
/// Flush any active realm instances and block any further writes.
|
||||||
|
Loading…
Reference in New Issue
Block a user