На этой странице представлены советы по устранению неполадок, которые помогут вам начать работу с Performance Monitoring Performance Monitoring использовать его функции и инструменты.
Первые проверки для устранения неполадок
Следующие две проверки представляют собой общие рекомендации, которые следует соблюдать перед дальнейшим устранением неполадок.
1. Проверьте журналы на наличие событий, связанных с производительностью.
Проверьте сообщения в журналах, чтобы убедиться, что SDK Performance Monitoring фиксирует события, связанные с производительностью.
Включите отладочное логирование для Performance Monitoring во время сборки, добавив элемент
<meta-data>в файлAndroidManifest.xmlвашего приложения следующим образом:<application> <meta-data android:name="firebase_performance_logcat_enabled" android:value="true" /> </application>Проверьте журналы на наличие сообщений об ошибках.
Performance Monitoring помечает свои сообщения журналов тегом
FirebasePerformance. Используя фильтрацию logcat, вы можете просмотреть трассировку длительности и журналы сетевых запросов HTTP/S, выполнив следующую команду:adb logcat -s FirebasePerformance
Проверьте наличие следующих типов журналов, указывающих на то, что Performance Monitoring регистрирует события, связанные с производительностью:
-
Logging trace metric: TRACE_NAME , FIREBASE_PERFORMANCE_CONSOLE_URL -
Logging network request trace: URL
-
Нажмите на URL-адрес, чтобы просмотреть данные в консоли Firebase. Обновление данных на панели мониторинга может занять несколько секунд.
Если ваше приложение не регистрирует события, связанные с производительностью, ознакомьтесь с советами по устранению неполадок .
2. Проверьте панель состояния Firebase.
Проверьте панель состояния Firebase на случай, если обнаружен известный сбой в работе Firebase или системы Performance Monitoring .
Начало работы с Performance Monitoring
Если вы только начинаете использовать Performance Monitoring ( iOS+ | Android | Web ), следующие советы по устранению неполадок помогут решить проблемы, связанные с обнаружением SDK Firebase или отображением первых данных о производительности в консоли Firebase .
Firebase может определить, успешно ли вы добавили SDK Performance Monitoring в ваше приложение, когда получает информацию о событиях (например, о взаимодействиях с приложением). Обычно в течение 10 минут после запуска приложения на панели мониторинга производительности в консоли Firebase отображается сообщение «SDK обнаружен». Затем, в течение 30 минут, на панели мониторинга отображаются исходные обработанные данные.
Если с момента добавления последней версии SDK в ваше приложение прошло более 10 минут, а изменений по-прежнему нет, проверьте сообщения в журналах , чтобы убедиться, что Performance Monitoring регистрирует события. Для устранения проблемы с задержкой обнаружения SDK попробуйте выполнить соответствующие действия по устранению неполадок, описанные ниже.
Убедитесь, что вы используете Performance Monitoring Android SDK версии 19.1.0 или более поздней (или Firebase BoM версии 26.3.0 или более поздней), см. примечания к выпуску .
Если вы всё ещё занимаетесь локальной разработкой, попробуйте генерировать больше событий для сбора данных:
- Генерируйте события, несколько раз переключая приложение между фоновым и активным режимами, взаимодействуя с приложением путем навигации по экранам и/или инициируя сетевые запросы.
Убедитесь, что ваш конфигурационный файл Firebase (
google-services.json) корректно добавлен в ваше приложение и что вы его не изменяли. В частности, проверьте следующее:К имени файла конфигурации не добавляются дополнительные символы, например
(2).Файл конфигурации находится в каталоге модуля (на уровне приложения) вашего приложения.
Идентификатор приложения Firebase для Android (
mobilesdk_app_id), указанный в файле конфигурации, является правильным для вашего приложения. Найдите свой идентификатор приложения Firebase в разделе «Ваши приложения» в проекта .
Если вам кажется, что с конфигурационным файлом вашего приложения что-то не так, попробуйте следующее:
Удалите конфигурационный файл, который в данный момент находится в вашем приложении.
Следуйте этим инструкциям , чтобы загрузить новый файл конфигурации и добавить его в ваше Android-приложение.
Если SDK регистрирует события, и всё, кажется, настроено правильно, но вы всё ещё не видите сообщение об обнаружении SDK или обработанные данные (через 10 минут), обратитесь в службу поддержки Firebase .
Проверьте настройку плагина Performance Monitoring Gradle следующим образом:
Убедитесь, что вы правильно добавили плагин . В частности, проверьте следующее:
- Вы добавили плагин (
) в файлapply plugin: 'com.google.firebase.firebase-perf' build.gradleвашего модуля (уровня приложения) . - Вы добавили зависимость для плагина в classpath (
) в файлclasspath 'com.google.firebase:perf-plugin:2.0.2' build.gradleна уровне проекта .
- Вы добавили плагин (
Убедитесь, что плагин не отключен ни одним из следующих флагов:
- Включите
instrumentationEnabledв файлеbuild.gradleвашего модуля (на уровне приложения). -
firebasePerformanceInstrumentationEnabledв файлgradle.properties
- Включите
Убедитесь, что SDK Performance Monitoring не отключен ни одним из следующих флагов в файле
AndroidManifest.xml:-
firebase_performance_collection_enabled -
firebase_performance_collection_deactivated
-
Убедитесь, что Performance Monitoring не отключен во время выполнения .
Если вы не можете найти отключенные функции в своем приложении, обратитесь в службу поддержки Firebase .
Система Performance Monitoring обрабатывает данные о событиях, влияющих на производительность, прежде чем отобразить их на панели мониторинга производительности .
Если с момента появления сообщения «SDK обнаружен» прошло более 24 часов , а данные по-прежнему не отображаются, проверьте панель состояния Firebase на случай, если обнаружена известная проблема. Если проблемы нет, обратитесь в службу поддержки Firebase .
Общее устранение неполадок
Если вы успешно добавили SDK и используете Performance Monitoring в своем приложении, следующие советы по устранению неполадок помогут решить общие проблемы, связанные с функциями и инструментами Performance Monitoring .
Если вы не видите сообщений в журнале о событиях производительности , попробуйте выполнить следующие действия по устранению неполадок:
Проверьте настройку плагина Performance Monitoring Gradle следующим образом:
Убедитесь, что вы правильно добавили плагин . В частности, проверьте следующее:
- Вы добавили плагин (
) в файлapply plugin: 'com.google.firebase.firebase-perf' build.gradleвашего модуля (уровня приложения) . - Вы добавили зависимость для плагина в classpath (
) в файлclasspath 'com.google.firebase:perf-plugin:2.0.2' build.gradleна уровне проекта .
- Вы добавили плагин (
Убедитесь, что плагин не отключен ни одним из следующих флагов:
- Включите
instrumentationEnabledв файлеbuild.gradleвашего модуля (на уровне приложения). -
firebasePerformanceInstrumentationEnabledв файлgradle.properties
- Включите
Убедитесь, что SDK Performance Monitoring не отключен ни одним из следующих флагов в файле
AndroidManifest.xml:-
firebase_performance_collection_enabled -
firebase_performance_collection_deactivated
-
Убедитесь, что Performance Monitoring не отключен во время выполнения .
Если вы не можете найти отключенные функции в своем приложении, обратитесь в службу поддержки Firebase .
Если у вас отсутствуют данные трассировки отрисовки экрана, попробуйте выполнить следующие действия по устранению неполадок:
Убедитесь, что вы используете последнюю версию Android SDK (v22.0.4). Трассировка отрисовки экрана доступна только в версии 15.2.0 или более поздней.
Убедитесь, что вы не отключили аппаратное ускорение для экрана вручную.
Убедитесь, что вы не используете DexGuard или Jack. Performance Monitoring несовместим с этими наборами инструментов.
DexGuard отключает автоматический сбор трассировок при запуске приложения, в фоновом и активном режимах работы приложения. Однако любые пользовательские трассировки кода должны работать нормально, если ваше приложение использует DexGuard.
Класс Jack устарел и, как правило, не должен использоваться в вашем приложении.
Вы видите данные о производительности для автоматически собранных трассировок , но не для трассировок пользовательского кода ? Попробуйте выполнить следующие действия по устранению неполадок:
Если вы настроили трассировку пользовательского кода через API трассировки , проверьте параметры трассировки, особенно следующие:
- Названия для пользовательских трассировок кода и пользовательских метрик должны соответствовать следующим требованиям: отсутствие пробелов в начале и конце, отсутствие символа подчеркивания (
_) в начале, а максимальная длина — 32 символа. - Все трассировки должны быть запущены и остановлены. Любая трассировка, которая не запущена, не остановлена или остановлена до запуска, не будет регистрироваться в журнале.
- Названия для пользовательских трассировок кода и пользовательских метрик должны соответствовать следующим требованиям: отсутствие пробелов в начале и конце, отсутствие символа подчеркивания (
Если вы настроили трассировку пользовательского кода с помощью аннотации
@AddTrace, проверьте настройки плагина Performance Monitoring Gradle:Убедитесь, что вы правильно добавили плагин . В частности, проверьте следующее:
- Вы добавили плагин (
) в файлapply plugin: 'com.google.firebase.firebase-perf' build.gradleвашего модуля (уровня приложения) . - Вы добавили зависимость для плагина в classpath (
) в файлclasspath 'com.google.firebase:perf-plugin:2.0.2' build.gradleна уровне проекта .
- Вы добавили плагин (
Убедитесь, что плагин не отключен ни одним из следующих флагов:
- Включите
instrumentationEnabledв файлеbuild.gradleвашего модуля (на уровне приложения). -
firebasePerformanceInstrumentationEnabledв файлgradle.properties
- Включите
Проверьте сообщения в журналах , чтобы убедиться, что Performance Monitoring регистрирует ожидаемые трассировки пользовательского кода.
Если Performance Monitoring регистрирует события, но данные не отображаются в течение 24 часов, обратитесь в службу поддержки Firebase .
Если отсутствуют данные сетевого запроса, попробуйте выполнить следующие действия по устранению неполадок:
Для приложений Android плагин Performance Monitoring Gradle позволяет осуществлять инструментарий, обеспечивающий автоматический мониторинг сетевых HTTP/S-запросов . Обратите внимание на следующее:
Убедитесь, что вы правильно добавили плагин . В частности, проверьте следующее:
- Вы добавили плагин (
) в файлapply plugin: 'com.google.firebase.firebase-perf' build.gradleвашего модуля (уровня приложения) . - Вы добавили зависимость для плагина в classpath (
) в файлclasspath 'com.google.firebase:perf-plugin:2.0.2' build.gradleна уровне проекта .
- Вы добавили плагин (
Убедитесь, что плагин не отключен ни одним из следующих флагов:
- Включите
instrumentationEnabledв файлеbuild.gradleвашего модуля (на уровне приложения). -
firebasePerformanceInstrumentationEnabledв файлgradle.properties
- Включите
Проверьте наличие несовместимости сетевых библиотек. Performance Monitoring автоматически собирает метрики для сетевых запросов, использующих следующие сетевые библиотеки: OkHttp 3.xx, Java URLConnection и Apache HttpClient.
Обратите внимание, что вы можете добавить собственный мониторинг сетевых запросов .
Обратите внимание на следующее:
В зависимости от поведения вашего кода и используемых им сетевых библиотек, Performance Monitoring может сообщать только о завершенных сетевых запросах. Это означает, что открытые HTTP/S-соединения могут не отображаться в отчете.
Performance Monitoring несовместима с DexGuard и Jack.
- DexGuard отключает мониторинг сетевых запросов HTTP/S.
- Класс Jack устарел и, как правило, не должен использоваться в вашем приложении.
Performance Monitoring не отображает сетевые запросы с недействительными заголовками
Content-Type. Однако сетевые запросы без заголовковContent-Typeбудут по-прежнему приниматься.
Узнайте больше о том, как Performance Monitoring агрегирует данные сетевых запросов по шаблонам URL.
Вы также можете попробовать использовать пользовательские шаблоны URL-адресов !
Часто задаваемые вопросы
В продолжение недавнего внедрения системы оповещений, которая автоматически уведомляет вас о превышении установленных вами пороговых значений, мы заменили раздел «Наиболее актуальные проблемы» на «Недавние оповещения» . Раздел «Проблемы» теперь устарел и заменен на оповещения.
Селектор приложений в верхней части карточки «Производительность» фильтрует записи оповещений в разделе «Последние оповещения» . Отображаются только три самых последних оповещения для выбранного(ых) приложения(й).
Чтобы узнать больше об оповещениях, см. раздел «Настройка оповещений о проблемах с производительностью» .
Performance Monitoring поддерживает оповещения о метриках, превышающих заданные пороговые значения. Во избежание путаницы с этими настраиваемыми пороговыми значениями для метрик производительности мы убрали возможность настройки пороговых значений для проблем .
Мы заменили страницы «Подробности» и «Метрики» новым, централизованным пользовательским интерфейсом (UI), чтобы улучшить процесс устранения неполадок. Этот новый интерфейс для устранения неполадок предлагает те же основные функции, что и страницы «Подробности» и «Метрики». Чтобы узнать больше об устранении неполадок, см. раздел «Просмотр дополнительных данных для конкретной трассировки» .
Performance Monitoring собирает данные о производительности с пользовательских устройств вашего приложения. Если у вашего приложения много пользователей или если оно генерирует большой объем данных о производительности, Performance Monitoring может ограничить сбор данных подмножеством устройств, чтобы уменьшить количество обрабатываемых событий. Эти ограничения достаточно высоки, чтобы даже при меньшем количестве событий значения метрик все еще отражали опыт использования приложения пользователями.
Для управления объемом собираемых данных Performance Monitoring использует следующие параметры выборки:
Ограничение скорости передачи данных на устройстве : Чтобы предотвратить внезапные всплески отправки трассировок устройством, мы ограничиваем количество трассировок кода и сетевых запросов, отправляемых устройством, до 300 событий каждые 10 минут. Такой подход защищает устройство от зацикливания измерений, которое может отправлять большие объемы данных о производительности, и предотвращает искажение результатов измерений производительности одним устройством.
Динамическая выборка : Performance Monitoring ежедневно собирает ограниченное количество трассировок кода и сетевых запросов для каждого приложения у всех пользователей приложения. На устройствах (с помощью Firebase Remote Config ) задается динамическая частота выборки, определяющая, следует ли случайному устройству собирать и отправлять трассировки. Устройство, не выбранное для выборки, не отправляет никаких событий. Динамическая частота выборки зависит от приложения и корректируется таким образом, чтобы общий объем собираемых данных оставался ниже установленного предела.
Проекты, в которых включена интеграция с BigQuery, получают более высокий лимит на количество трассировок сетевых запросов.
Пользовательские сессии отправляют дополнительные, подробные данные с устройства пользователя, что требует больше ресурсов для сбора и отправки этих данных. Чтобы минимизировать влияние пользовательских сессий, Performance Monitoring может также ограничить их количество.
Ограничение скорости на стороне сервера : Чтобы гарантировать, что приложения не превысят лимит выборки, Performance Monitoring может использовать выборку на стороне сервера для отбрасывания некоторых событий, полученных от устройств. Хотя этот тип ограничения не меняет эффективность наших метрик, он может вызвать незначительные изменения в закономерностях, в том числе следующие:
- Количество трассировок может отличаться от количества выполнений фрагмента кода.
- Трассировки, тесно связанные в коде, могут иметь разное количество выборок.
Вкладку «Проблемы» заменили функцией «Оповещения», которая автоматически уведомляет вас о превышении установленных вами пороговых значений. Вам больше не нужно вручную проверять консоль Firebase , чтобы узнать статус порогового значения. Подробнее об оповещениях см. в разделе «Настройка оповещений о проблемах с производительностью» .
Мы переработали раздел Performance Monitoring в консоли Firebase , так что на вкладке «Панель мониторинга» отображаются ключевые метрики и все трассировки в одном месте. В рамках переработки мы удалили страницы «На устройстве» и «В сети» .
В таблице трассировок внизу вкладки «Панель управления» содержится вся та же информация, что и на вкладках «На устройстве» и «Сеть» , но с некоторыми дополнительными функциями, включая возможность сортировки трассировок по процентному изменению для определенного показателя. Чтобы просмотреть все показатели и данные для конкретной трассировки, щелкните имя трассировки в таблице трассировок.
Просмотрите результаты трассировки на следующих вкладках таблицы трассировки:
- Трассировка сетевых запросов (как стандартная, так и пользовательская) — подвкладка «Сетевые запросы»
- Пользовательские трассировки кода — подвкладка «Пользовательские трассировки»
- Трассировка запуска приложения, приложения на переднем плане, приложения в фоновом режиме — подвкладка «Пользовательские трассировки»
- Трассировка отрисовки экрана — Подвкладка «Отрисовка экрана»
- Трассировка загрузки страницы — Подвкладка «Загрузка страницы»
Подробную информацию о таблице трассировки, а также о метриках и данных просмотра можно найти на странице обзора консоли ( iOS+ | Android | Web ).
Медленная отрисовка кадров и зависание кадров рассчитываются исходя из предполагаемой частоты обновления устройства 60 Гц. Если частота обновления устройства ниже 60 Гц, время отрисовки каждого кадра будет меньше, поскольку в секунду отрисовывается меньше кадров. Более медленное время отрисовки может привести к увеличению количества сообщений о медленных или зависших кадрах, поскольку больше кадров будут отрисовываться медленнее или зависать. Однако, если частота обновления устройства выше 60 Гц, время отрисовки каждого кадра будет меньше. Это может привести к уменьшению количества сообщений о медленных или зависших кадрах. Это текущее ограничение в SDK Performance Monitoring .
Чтобы помимо активности приложения отслеживать производительность фрагментов, убедитесь, что ваше приложение использует Android SDK Performance Monitoring версии 20.1.0 или выше. Для получения дополнительной информации см. раздел «Добавление мониторинга производительности в ваше приложение» .
Каждый из фрагментов и трассировок активности основаны на имени класса, определенном в вашем приложении. Каждая трассировка экрана содержит префикс st, за которым следует имя класса. В консоли Firebase префикс удаляется. Для получения дополнительной информации см. раздел «Подробнее о данных производительности отрисовки экрана (приложения Apple и Android)» .
Performance Monitoring осуществляет выборочную проверку всех событий, собранных на устройстве. Такой подход позволяет нам собирать минимальное количество событий, необходимых с пользовательских устройств для предоставления показателей производительности.
Performance Monitoring позволяет настраивать оповещения по интересующим вас показателям. Например, для трассировок отрисовки экрана можно настроить оповещения , которые будут уведомлять вас, когда процент медленных и зависших кадров превысит установленный вами порог.
Performance Monitoring для Android использует инструментирование байт-кода для предоставления некоторых встроенных функций, таких как мониторинг сетевых запросов HTTP/S . В рамках компиляции этот процесс требует итерации по всем классам вашего приложения (включая зависимости) для инструментирования кода, который имеет решающее значение для измерения производительности сетевых запросов вашего приложения.
Вот некоторые ключевые факторы, способствующие увеличению времени сборки:
- Количество классов или файлов
- Размер каждого из этих классов (количество строк кода)
- Конфигурация вашего компьютера
- Первоначальная сборка против последующей сборки (последующие сборки обычно быстрее первоначальной).
Для оптимизации времени сборки рассмотрите возможность модульной структуры кода .
Начиная с версии 1.3.3 плагина Performance Monitoring , мы сосредоточились на значительном улучшении процесса инкрементальной сборки и кэширования входных данных библиотек. Чтобы получить самые последние улучшения, внесенные во время сборки, убедитесь, что используете последнюю версию плагина (v2.0.2) .
Обратите внимание, что вы можете отключить плагин Performance Monitoring для отладочных сборок локально, если хотите избежать длительного времени сборки. Однако этот подход не рекомендуется для производственных сборок, поскольку он может привести к пропуску измерений производительности сетевых запросов в вашем приложении.
Performance Monitoring для Android использует инструментирование байт-кода для предоставления некоторых встроенных функций, таких как мониторинг сетевых запросов HTTP/S . В рамках компиляции этот процесс требует итерации по всем классам вашего приложения (включая зависимости) для инструментирования кода, который имеет решающее значение для измерения производительности сетевых запросов вашего приложения.
Если после интеграции с плагином Performance Monitoring вы получаете ошибки сборки, такие как JSR/RET are not supported with computeFrames option или аналогичные ошибки, это может быть связано с тем, что у вас также есть зависимость от библиотеки, несовместимой с плагином Performance Monitoring Gradle.
Чтобы обойти эту проблему, вы можете исключить несовместимые классы/библиотеки из процесса инструментирования, выполнив следующие шаги:
- Обновите плагин Performance Monitoring Gradle до последней версии (минимум v1.4.0 ).
- Обновите версию плагина Android Gradle до v7.2.0 или новее.
- Добавьте следующий флаг в файл
build.gradleвашего модуля (на уровне приложения), чтобы исключить несовместимые классы/библиотеки из процесса инструментирования: Чтобы узнать больше о свойствеandroid { // ... androidComponents { onVariants(selector().all(), { instrumentation.excludes.add("example.incompatible.library") }) } }
excludeв APIInstrumentationплагинов Android Gradle, см. раздел «Инструментирование» .
Пожалуйста, создавайте запросы на GitHub, если вы сталкиваетесь с ошибками сборки, вызванными несовместимыми библиотеками, чтобы их также можно было исключить из Performance Monitoring с помощью плагина.
Если вы включили интеграцию BigQuery с Firebase Performance Monitoring , ваши данные будут экспортированы в BigQuery через 12–24 часа после окончания дня (по тихоокеанскому времени).
Например, данные за 19 апреля будут доступны в BigQuery 20 апреля в период с 12:00 до полуночи (все даты и время указаны по тихоокеанскому времени).
Near real-time data processing and display
Firebase Performance Monitoring processes collected performance data as it comes in, which results in near real-time data display in the Firebase console. Processed data displays in the console within a few minutes of its collection, hence the term "near real-time".
To take advantage of near real-time data processing, make sure your app uses a real-time compatible SDK version .
To take advantage of near real-time data processing, you only need to make sure that your app uses a Performance Monitoring SDK version that's compatible with real-time data processing.
These are the real-time compatible SDK versions:
- iOS — v7.3.0 or later
- tvOS — v8.9.0 or later
- Android — v19.0.10 or later (or Firebase Android BoM v26.1.0 or later)
- Web — v7.14.0 or later
Note that we always recommend using the latest version of SDK, but any version listed above will enable Performance Monitoring to process your data in near real time.
These are the SDK versions compatible with real-time data processing:
- iOS — v7.3.0 or later
- tvOS — v8.9.0 or later
- Android — v19.0.10 or later (or Firebase Android BoM v26.1.0 or later)
- Web — v7.14.0 or later
Note that we always recommend using the latest version of SDK, but any version listed above will enable Performance Monitoring to process your data in near real time.
If your app doesn't use a real-time compatible SDK version, you will still see all your app's performance data in the Firebase console. However, the display of performance data will be delayed by roughly 36 hours from the time of its collection.
Yes! Regardless of which SDK version an app instance uses, you'll see performance data from all your users.
However, if you're looking at recent data (less than roughly 36 hours old), then the displayed data is from users of app instances using a real-time compatible SDK version. The non-recent data, though, includes performance data from all versions of your app.
Contacting Firebase Support
If you reach out to Firebase Support , always include your Firebase App ID. Find your Firebase App ID in the Your apps card of your Project settings .