Есть ли связь между компиляцией debug="true" и в режиме публикации "release"

Нужно ли устанавливать debug='false'

<compilation debug="false" targetFramework="4.0" /> 

Даже если опубликовать мой код в режиме выпуска.

Редактировать 1

Как упомянуто в обзоре компиляции MSDN. Это делается в два этапа.

  1. На первом этапе он компилирует код в одну или несколько сборок.
  2. Во втором pahse переводит MSIL в специфичные для процессора инструкции для процессора на компьютере, на котором запущено приложение.

Публикует ли код означает фазу 1 часть и
<compilation .... означает фазу 2.

6 ответов

Я не до конца понимаю ваш вопрос. Если вы спросите об этом, вам нужно вручную установить debug='false', тогда ответ будет зависеть от того, есть ли в проекте файлы с преобразованием конфигурации. Текущий стандартный шаблон веб-проекта Visual Studio включает в себя два файла с преобразованием конфигурации: Web.Debug.config и Web.Release.config. Эти файлы содержат преобразование конфигурации, которое будет применено во время публикации вашего кода. Это пример файла Web.Release.config по умолчанию:

<?xml version="1.0"?>

<!-- For more information on using web.config transformation visit http://go.microsoft.com/fwlink/?LinkId=125889 -->

<configuration xmlns:xdt="http://schemas.microsoft.com/XML-Document-Transform">
  <!--
    In the example below, the "SetAttributes" transform will change the value of 
    "connectionString" to use "ReleaseSQLServer" only when the "Match" locator 
    finds an atrribute "name" that has a value of "MyDB".

    <connectionStrings>
      <add name="MyDB" 
        connectionString="Data Source=ReleaseSQLServer;Initial Catalog=MyReleaseDB;Integrated Security=True" 
        xdt:Transform="SetAttributes" xdt:Locator="Match(name)"/>
    </connectionStrings>
  -->

    <system.web>
    <compilation xdt:Transform="RemoveAttributes(debug)" />
    <!--
      In the example below, the "Replace" transform will replace the entire 
      <customErrors> section of your web.config file.
      Note that because there is only one customErrors section under the 
      <system.web> node, there is no need to use the "xdt:Locator" attribute.

      <customErrors defaultRedirect="GenericError.htm"
        mode="RemoteOnly" xdt:Transform="Replace">
        <error statusCode="500" redirect="InternalError.htm"/>
      </customErrors>
    -->
  </system.web>
</configuration> 

Таким образом, если у вас есть файл преобразования Web.Release.config с содержимым, аналогичным описанному выше, и вы используете возможности публикации в Visual Studio (или в соответствии с целями msbuild), то атрибут debug='true' будет удален при публикации проекта в выпуске. Режим.

Есть много преимуществ для удаления debug='true' из веб-конфигурации. Эти настройки влияют не только на скомпилированные библиотеки, но и на то, какая версия скриптов MS Ajax будет загружена (если вы используете веб-формы ASP.NET и элемент управления Script Manager). Отладочная версия библиотеки MS Ajax имеет много проверок (проверка аргументов и т. Д.), Которые удалены из релизной версии скриптов. Вот почему отладочная версия работает медленно.

Для debug=true против debug=false Обсуждение показывает, что в производственной системе есть много преимуществ для отключения отладки при публикации в производство. Другие ответы и комментарии более подробно об этом (одно большое преимущество, которое я заметил в приложениях MVC4, заключается в том, что пакеты JS и CSS минимизируются при отключенной отладке).

На вопрос о публикации в Release Режим достаточно, пожалуйста, прочитайте ниже:

Если вы используете готовые файлы преобразования, поставляемые с новым проектом ASP.NET, то нет, вам не нужно устанавливать его вручную. Однако, если у вас нет файлов преобразования или вы их не используете, при выпуске в производство вам следует изменить этот параметр.

По сути, когда вы публикуете веб-сайт ASP.NET, он собирается создать приложение и применить соответствующее преобразование web.config (в зависимости от конфигурации, выбранной в разделе "Настройки" при использовании функции "Опубликовать в Интернете"). Я предполагаю, что вы выбираете режим "Release", а затем публикуете код в указанном месте.

Обычно, чтобы начать работу с преобразованиями, при создании приложения ASP.NET в Visual Studio вам будут предоставлены два преобразования для вашего web.config: web.Debug.config а также web.Release.config (Вы можете увидеть их, щелкнув по символу раскрытия рядом с вашим файлом web.config).

Если у вас нет никаких преобразований, вы можете создать их, щелкнув правой кнопкой мыши на файле web.config и выбрав "Добавить конфигурацию преобразования", и файлы преобразования будут созданы для ваших различных конфигураций сборки, которые есть в вашем решении.

Как отметил в своем ответе Максим Корнилов, готовая веб-страница.Release.config содержит следующую важную строку преобразования: <compilation xdt:Transform="RemoveAttributes(debug)" />, который говорит приложению удалить debug атрибут из <compilation тег, который сделает публикацию приложения отключенной отладкой.

Примечание: если вы этого не видите RemoveAttributes(debug) в преобразовании конфигурации, которое вы выбираете при публикации, код может публиковаться в режиме отладки.

Если вы действительно хотите быть уверены в том, как работает преобразование, просмотрите содержимое файла web.config после публикации, и вы увидите выходные данные преобразования.

Кроме того, на http://webconfigtransformationtester.apphb.com/ имеется инструмент, который позволит вам проверить, как преобразование web.config повлияет на ваш файл web.config.

Наконец, я большой поклонник использования build-сервера и сборок для публикации своего кода, когда он будет готов к работе (так меньше нужно прямому доступу к серверу таким образом), поэтому преобразование web.config поможет мне в этом. от разрешения мне изменять строки подключения в зависимости от среды, в которой я развертываю, а также для управления предупреждающими сообщениями и т. д. для различных сред (например, предупреждение: тестировать систему, не вводить реальные данные). С помощью преобразований основная коллекция настроек может оставаться в файле web.config (вместе с локальными настройками dev, поскольку нажатие клавиши F5 обычно не применяет преобразование, если только вы не публикуете его локально для тестирования), и в каждой среде есть свои Собственное преобразование конфигурации, которое находится в управлении исходным кодом и с одной и той же ветвью, код может быть легко развернут в нескольких средах без необходимости изменения какого-либо кода.

Да, вам нужно использовать debug = "false".

ASP.Net анализирует.aspx или представления и создает некоторые DLL, которые отличаются от той, которую вы компилируете с Visual Studio. Эта настройка для этих DLL.

Обзор компиляции ASP.NET http://msdn.microsoft.com/en-us/library/ms178466(v=vs.100).aspx

Вам не нужно указывать debug="false". Вы просто можете пропустить это и уйти

<compilation targetFramework="4.5" /> 

IIS полагает, что отладка неверна.

теория

В этой статье за ​​2006 год перечислены последствия debug="true":

  1. ASP.NET запросы не будут задерживаться: для очевидных целей отладки
  2. Пакетная компиляция отключена: страницы и элементы управления компилируются в отдельные сборки
  3. Оптимизация кода: JIT-компилятор генерирует более эффективный код

Номер 3. в основном совпадает с тем, что делает компиляция режима Release.

Ссылки на код

Чтобы провести еще одно расследование, я выпустил Re # на System.Web.Configuration.CompilationSection.Debug в одном из моих веб-проектов на Framework 4.0. Найдено использование были:

  1. System.Web.Configuration.BrowserCapabilitiesCodeGenerator.GenerateAssembly
  2. System.Web.Configuration.CompilationSection.GetCompilerInfoFromExtension
  3. System.Web.Configuration.CompilationSection.GetCompilerInfoFromLanguage
  4. System.Web.Compilation.CompilationUtil.GetRecompilationHash
  5. System.Web.HttpRuntime.InitDebuggingSupport
  6. System.Web.Compilation.CompilationUtil.IsDebuggingEnabled

Все это, похоже, относится к трем пунктам, упомянутым выше.

Эффекты времени выполнения

Обратите внимание, что флаг отладки влияет

  1. компиляция на лету
  2. прекомпиляция (от wdproj)
  3. и MSDeploy

Хотя чистый эффект в основном одинаков, изменение флага не оказывает никакого эффекта на оптимизацию ни для одного кода, который не компилируется на лету (как с предварительной компиляцией wdproj).

Связки

Кроме того, есть по крайней мере 1 другое использование флага отладки: с пакетами ресурсов. JS и CSS в комплекте будут выводиться без изменений, если флаг отладки в приложении / веб-конфигурации включен.

Вам следует. debug="true" Переключатель должен использоваться только во время разработки.

Другие вопросы по тегам