Поделиться через


Как обновить нестандартные сборки и расширения

Добавления: 15 сентября 2007 г.

Службы SQL Server Reporting Services предоставляют расширяемую архитектуру, позволяющую разработчикам создавать общие сборки для модулей пользовательской обработки данных, доставки, подготовки и безопасности. Также в них поддерживается использование пользовательских сборок для значений элементов, стилей и форматирования отчетов.

Если в установке служб SQL Server 2000 Reporting Services были развернуты пользовательские модули или сборки, то программа установки блокирует автоматическое обновление этой установки и выведет следующую ошибку: «На этом сервере отчетов развернуты пользовательские сборки». Если было выбрано обновление нескольких компонентов, то обновление других компонентов SQL Server 2005 можно продолжить. Однако для обновления служб Reporting Services понадобится закрыть программу установки и совершить следующие шаги.

  1. Удалите пользовательские настройки из файла rsreportserver.config. Чтобы провести обновление пользовательской установки, можно временно удалить настройки конфигурации для пользовательских сборок и модулей из файла rsreportserver.config. После этого программа установки сможет успешно провести проверку на наличие пользовательских сборок, поскольку без пользовательских настроек установка выглядит точно так же, как и установка по умолчанию.
  2. Запустите программу установки, чтобы обновить службы Reporting Services.
  3. При необходимости перекомпилируйте пользовательскую сборку или модуль.
    • Нестандартные модули безопасности необходимо перекомпилировать обязательно. Во все модули безопасности сервера отчетов должны входить ссылки на настройки безопасности моделей и их элементов, даже если в дальнейшем не планируется их использование.
    • Другие модули и сборки необходимо перекомпилировать только в том случае, если они зависят от файла или от пути к файлу из старой установки. В обновленной установке в имена программных папок входят сведения об экземплярах (например MSSQL.1 для экземпляра по умолчанию компонента Database Engine). Если модуль или сборка ссылаются на путь, которого больше не существует, то во время их выполнения будет выведена ошибка. Например, следующая ошибка, возникающая после обновления, сообщит о необходимости перекомпиляции модуля обработки данных: «Произошла ошибка при обработке отчета. Предпринята попытка использовать незарегистрированный для этого сервера отчетов модуль обработки данных >имя>».
      Если необходимо провести перекомпиляцию, то следует использовать среду Visual Studio 2005 или загрузить компонент Visual Studio 2005 Express Edition. Программные файлы служб SQL Server 2005 Reporting Services управляются сборками, созданными на основе платформы Microsoft .NET Framework 2.0. Чтобы создать ссылку на версию библиотеки Microsoft.ReportingServices.Interfaces.dll SQL Server 2005 в своем проекте, следует скомпилировать этот проект с помощью среды разработки Visual Studio 2005, в которой создаются приложения .NET Framework 2.0.
  4. Переместите пользовательские сборки и модули в правильную папку обновленной установки. Необходимо найти папку, в которой содержатся программные файлы служб Reporting Services, и скопировать в нее файлы пользовательских приложений. Если были установлены экземпляры по умолчанию компонента Database Engine и служб Reporting Services, то программные файлы служб Reporting Services, скорее всего, будут в папке MSSQL.2.
  5. Добавьте пользовательские настройки в файл rsreportserver.config.

Удаление пользовательских настроек и обновление служб Reporting Services

  1. Создайте резервную копию файла rsreportserver.config.

  2. Удалите настройки пользовательских модулей из файла rsreportserver.config. Из других файлов конфигурации и файлов политики безопасности записи удалять не нужно. Эти файлы будут обновлены и перемещены во время обновления; любые пользовательские установки будут сохранены.

  3. Запустите программу установки для обновления каждой установки сервера отчетов.

Bb839481.note(ru-ru,SQL.90).gifВажно!
Если в программе установки SQL Server 2005 были выбраны новые образцы, то процесс обновления удалит старые образцы и заменит их более новыми версиями. Если образцы модулей или сборок активно используются, то перед началом обновления скопируйте их исходные файлы в другую папку.
  1. Скопируйте пользовательские сборки в новую структуру каталогов. Поместите файлы в папку \Program Files\Microsoft SQL Server\MSSQL.x\Reporting Services\ReportServer\Bin.
  2. Откройте файл rsreportserver.config и добавьте в него настройки пользовательских модулей.

Перекомпиляция пользовательской сборки

  1. Перекомпилируйте нестандартный модуль безопасности или пользовательскую сборку, зависящую от файла в структуре каталога сервера отчетов, следующим образом.

    1. Запустите среду Visual Studio 2005.
    2. Откройте решение. Будет предложено преобразовать файлы.
    3. В окне обозревателя решений щелкните правой кнопкой мыши Ссылки, а затем выберите Добавить ссылку.
    4. Щелкните Обзор.
    5. Перейдите в папку Program Files\Microsoft SQL Server\MSSQL.x\Reporting Services\ReportServer\Bin и выберите файл Microsoft.ReportingServices.Interfaces.dll.
    6. Постройте проект или решение.
  2. Скопируйте пользовательский модуль или сборку в папку \ReportServer\Bin.

  3. Если для них не существует записи, то добавьте настройки пользовательского модуля или сборки в файл rsreportserver.config.

  4. Проверьте файлы rsreportdesigner.config, rswebapplication.config и файлы конфигурации политики безопасности, чтобы убедиться, что пользовательские настройки все еще действительны. В частности, если в пользовательские настройки входит путь к папке служб Reporting Services, то его значение следует отредактировать, чтобы в нем был новый путь.

  5. Проверьте приложения и отчеты.

См. также

Основные понятия

Обновление служб Reporting Services

Другие ресурсы

Using Custom Assemblies with Reports
Reporting Services Extensions

Справка и поддержка

Получение помощи по SQL Server 2005