Предотвращение блокировок файла сборки с помощью Microsoft.SqlServer.Types - PullRequest
0 голосов
/ 28 октября 2019

Добавление Microsoft.SqlServer.Types к существующему веб-проекту, чтобы мы могли использовать пространственные типы DBGeography и DBGeometry из NuGet, добавляли в проект собственные сборки и включали Loader, который выглядит примерно так:

public class Utilities
{
    [DllImport("kernel32.dll", CharSet = CharSet.Auto, SetLastError = true)]
    private static extern IntPtr LoadLibrary(string libname);

    /// <summary>
    /// Loads the required native assemblies for the current architecture (x86 or x64)
    /// </summary>
    /// <param name="rootApplicationPath">
    /// Root path of the current application. Use Server.MapPath(".") for ASP.NET applications
    /// and AppDomain.CurrentDomain.BaseDirectory for desktop applications.
    /// </param>
    public static void LoadNativeAssemblies(string rootApplicationPath)
    {
        var nativeBinaryPath = IntPtr.Size > 4
            ? Path.Combine(rootApplicationPath, @"SqlServerTypes\x64\")
            : Path.Combine(rootApplicationPath, @"SqlServerTypes\x86\");

        LoadNativeAssembly(nativeBinaryPath, "msvcr120.dll");
        LoadNativeAssembly(nativeBinaryPath, "SqlServerSpatial140.dll");
    }

    private static void LoadNativeAssembly(string nativeBinaryPath, string assemblyName)
    {
        var path = Path.Combine(nativeBinaryPath, assemblyName);
        var ptr = LoadLibrary(path);
        if (ptr == IntPtr.Zero)
        {
            throw new Exception(string.Format(
                "Error loading {0} (ErrorCode: {1})",
                assemblyName,
                Marshal.GetLastWin32Error()));
        }
    }
}

Который затем должен вызываться из нашего global.asax.cs следующим образом:

SqlProviderServices.SqlServerTypesAssemblyName =
    "Microsoft.SqlServer.Types, Version=14.0.0.0, Culture=neutral, PublicKeyToken=89845dcd8080cc91";
SqlServerTypes.Utilities.LoadNativeAssemblies(Server.MapPath("~"));

(первая строка найдена только после некоторого копания).

Это все работаетхорошо локально и работает нормально после развертывания ... но проблема в том, что при повторном развертывании нашего проекта эти собственные сборки блокируются, и это нарушает сборку. Рабочий процесс должен быть остановлен и перезапущен до того, как может произойти развертывание, и это большая проблема.

Итак, мой вопрос, есть ли лучший способ справиться с этим? Файл readme.htm, который загружается с пакетом NuGet, предполагает, что вам необходимо развернуть собственные сборки на машине, на которой не установлены «Типы CLR системы для SQL Server» , но не совсем понятно, чтоЕсли вам что-то понадобится, вам нужно сделать это, и то, что вам, возможно, придется изменить, если вы это сделаете.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...