Использование агента Jolokia с RMI-сервером

У меня проблемы с использованием Jolokia в сочетании с RMI-Service. Как только служба RMI запущена, Jolokia больше не доступна через http.

Я создал пример класса, чтобы воспроизвести проблему:

package com.example.rmi;

import java.net.InetAddress;
import java.rmi.Naming;
import java.rmi.RemoteException;
import java.rmi.registry.LocateRegistry;
import java.rmi.server.UnicastRemoteObject;

public class RMITest {

    private class RMIService extends UnicastRemoteObject {

        private static final long serialVersionUID = 1L;

        protected RMIService() throws RemoteException {
            super();
        }

        public void doStuff() {
            System.out.println("Processing...");

        }

    }

    public static void main(String[] args) throws RemoteException {
        RMITest rmiServer = new RMITest();
        rmiServer.init();
    }

    private void init() throws RemoteException {
        RMIService rmiService = new RMIService();

        try {
            System.out.println("Starting RMI-Service...");
            String hostname = InetAddress.getLocalHost().getHostName();
            System.setProperty("java.rmi.server.hostname", hostname);

            int port = 2005;
            LocateRegistry.createRegistry(port);
            Naming.rebind("rmi://" + hostname + ":" + port
                    + "/RMIService", rmiService);
            System.out.println("RMI-Service started!");

        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

Если я изменю основной метод, чтобы не запускать службу RMI, Jolokia будет доступна через URL-адрес http http://127.0.0.1:8778/jolokia/ еще раз:

public static void main(String[] args) throws RemoteException {
    RMITest rmiServer = new RMITest();
    //rmiServer.init();

    while(true) {
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
   }

Сервис представляет собой исполняемую банку. Вот команда, которую я использую для запуска приложения:

java -javaagent:jolokia-jvm-1.3.7-agent.jar=port=8778,host=localhost -jar RMITest-0.0.1-SNAPSHOT.jar

Я скачал агент jolokia с официального сайта: Загрузка агента Jolokia


person JanTheGun    schedule 17.08.2017    source источник


Ответы (1)


Я нашел обходной путь, запустив агент программно после запуска RMI-Service.

В следующей статье Stackoverflow-Post описано, как это сделать: Запуск агента Java после запуска программы

Поэтому я запускаю следующий статический метод после запуска метода инициализации:

public static void attachGivenAgentToThisVM(String pathToAgentJar) {
    try {
        String nameOfRunningVM = ManagementFactory.getRuntimeMXBean().getName();
        String pid = nameOfRunningVM.substring(0, nameOfRunningVM.indexOf('@'));
        VirtualMachine vm = VirtualMachine.attach(pid);
        vm.loadAgent(pathToAgentJar, "");
        vm.detach();
    } catch (Exception e) {
        e.printStackTrace();
    }
}

Также необходима зависимость от «tools.jar»:

<dependency>
    <groupId>com.sun</groupId>
    <artifactId>tools</artifactId>
    <version>1.8</version>
    <scope>system</scope>
    <systemPath>${java.home}/../lib/tools.jar</systemPath>
</dependency>

Я бы все же предпочел запустить агент непосредственно из командной строки. Таким образом, лучшее решение высоко ценится.

person JanTheGun    schedule 17.08.2017