JINFO – информация о java-процессе | OTUS
⚡ Открываем подписку на курсы!
Проходите параллельно 3 онлайн-курса в месяц по цене одного.
Подробнее

Курсы

Программирование
Flutter Mobile Developer Подготовка к сертификации Oracle Java Programmer (OCAJP)
-8%
Алгоритмы и структуры данных
-12%
Web-разработчик на Python
-11%
Архитектура и шаблоны проектирования
-14%
JavaScript Developer. Basic Супер-интенсив «СУБД в высоконагруженных системах»
-18%
iOS-разработчик. Базовый курс
-23%
Разработчик на Spring Framework
-23%
Python Developer. Basic
-16%
C# ASP.NET Core разработчик
-18%
Разработчик программных роботов (RPA) на базе UiPath и PIX
-6%
JavaScript Developer. Professional
-9%
Android Developer. Basic
-10%
Java Developer. Professional Разработчик C# AWS для разработчиков Highload Architect Reverse-Engineering. Professional CI/CD Vue.js разработчик Agile Project Manager Нереляционные базы данных Супер - интенсив по паттернам проектирования Супер - интенсив по Kubernetes Advanced Fullstack JavaScript developer
Инфраструктура
PostgreSQL
-10%
IoT-разработчик
-12%
Administrator Linux. Professional
-11%
Базы данных
-19%
Administrator Linux.Basic
-18%
Супер-интенсив «СУБД в высоконагруженных системах»
-18%
Супер-интенсив "SQL для анализа данных"
-16%
Software Architect
-12%
Сетевой инженер AWS для разработчиков Highload Architect Разработчик голосовых ассистентов и чат-ботов Внедрение и работа в DevSecOps Администратор Linux. Виртуализация и кластеризация Нереляционные базы данных Супер-практикум по использованию и настройке GIT
Специализации Курсы в разработке Подготовительные курсы
+7 499 938-92-02

JINFO – информация о java-процессе

Java_Deep_28.2-5020-a59224.png

Бывает такое, что во время «боевой» эксплуатации java-приложения появляется потребность посмотреть параметры java-процесса. Порой надо узнать, с какими параметрами приложение было запущено, определить значения переменных окружения и другую подобную информацию. В Java-мире для решения задач мониторинга есть множество интересных инструментов. Сегодня мы рассмотрим один из них. Это jinfo.

Сегодня «подопытным кроликом» будет популярная утилита jconcole. Допустим, jconcole – это некий java-процесс, информацию о котором мы хотим получить.

Первое, что надо сделать – получить pid (т. е. идентификатор процесса jconcole). Делаем это так:

ps -ef | grep jconsole

В моем случае pid – 5653.

Зная pid, на jconcole можно «натравить» jinfo. Делается это так:

 jinfo 5653

Тут всё просто, jinfo в качестве параметра надо передать pid процесса, о котором нам нужна информация.

Jinfo в консоль напечатает много интересной информации о процессе.

Например, это:

  • «java.runtime.version» и «java.home» – jvm, которую использует процесс. Часто в старых системах на серверах зоопарк jvm, и не понятно, кто что использует;
  • «java.io.tmpdir» и «user.dir» – показывают, куда наиболее вероятно процесс может сохранять какие-то файлы;
  • «java.class.path» – показывает, откуда процесс загружает библиотеки;
  • «Command line» – параметры командной стоки, с которыми стартовало приложение.

Отдельно хочется остановиться на system properties, ведь не всегда эти значения легко узнать.

В случае с jconsole при старте определяется system property «application.home». Jinfo выводит текущее значение system properties, т. е. если во время работы приложения system properties изменилось, jinfo выведет актуальное значение.

Jinfo – интересная и полезная утилита диагностики, однако надо знать, что сейчас статус этой утилиты – «экспериментальная». Т. е. она может работать, а может и с такой ошибкой падать: «can't determine target's VM version : field "_reserve_for_allocation_prefetch" not found in type Abstract_VM_Version».

Если у вас jinfo не заработает, не забывайте про «стабильную классику» – jconcole.

Не пропустите новые полезные статьи!

Спасибо за подписку!

Мы отправили вам письмо для подтверждения вашего email.
С уважением, OTUS!

Автор
0 комментариев
Для комментирования необходимо авторизоваться