2013-10-23 13 views
6

Próbuję zbadać jmeter i szybko napotkałem pewne problemy. Próbuję wykonać samouczek pod adresem http://jmeter.apache.org/usermanual/jmeter_proxy_step_by_step.pdf. Kiedy próbuję uruchomić rejestrator, otrzymuję komunikat, że nie mogę utworzyć błędu serwera proxy. Dzienniki dać mi tę wiadomość:Jmeter 2.10 Nagrywarka HTTP zgłasza wyjątek keytool

2013/10/23 13:40:54 INFO - jmeter.util.JsseSSLManager: Using default SSL protocol: TLS 
2013/10/23 13:40:54 INFO - jmeter.util.JsseSSLManager: SSL session context: per-thread 
2013/10/23 13:54:32 WARN - jmeter.protocol.http.proxy.ProxyControl: Could not open/read key store C:\apache-jmeter-2.10\bin\proxyserver.jks (The system cannot find the file specified) 
2013/10/23 13:54:32 INFO - jmeter.protocol.http.proxy.ProxyControl: Creating Proxy CA in C:\apache-jmeter-2.10\bin\proxyserver.jks 
2013/10/23 13:54:32 ERROR - jmeter.protocol.http.proxy.ProxyControl: Could not initialise key store java.io.IOException: Cannot run program "keytool" (in directory "C:\apache-jmeter-2.10\bin"): CreateProcess error=2, The system cannot find the file specified 

nie wiem dlaczego exe nie będzie podniósł, ponieważ jest częścią java i na mojej drodze lub dlaczego zip jmeter wyklucza niezbędny plik więc skopiowałem keytool z mojej instalacji java do katalogu, którego szukał i spróbował ponownie. kiedy nie mam to:

ERROR - jmeter.protocol.http.proxy.ProxyControl: Could not initialise key store java.io.IOException:

dostałem kod od -1073741515, który jako początkujący nie jest pomocne. Próbowałem tych rzeczy zi bez wskazania serwera proxy, bez różnicy w wynikach. Jestem na systemie Windows 7 w wersji 64-bitowej i używam jdk 1.7.

Jakieś sugestie dotyczące kroków, które mogę podjąć, aby rozwiązać problem?

Edycja: Oto pełna dziennika

2013/10/23 15:34:06 INFO - jmeter.util.JMeterUtils: Setting Locale to en_US 
2013/10/23 15:34:06 INFO - jmeter.JMeter: Loading user properties from: C:\apache-jmeter-.10\bin\user.properties 
2013/10/23 15:34:06 INFO - jmeter.JMeter: Loading system properties from: C:\apache-meter-2.10\bin\system.properties 
2013/10/23 15:34:07 INFO - jmeter.JMeter: Copyright (c) 1998-2013 The Apache Software Foundation 
2013/10/23 15:34:07 INFO - jmeter.JMeter: Version 2.10 r1533061 
2013/10/23 15:34:07 INFO - jmeter.JMeter: java.version=1.7.0_21 
2013/10/23 15:34:07 INFO - jmeter.JMeter: java.vm.name=Java HotSpot(TM) 64-Bit Server VM 
2013/10/23 15:34:07 INFO - jmeter.JMeter: os.name=Windows 7 
2013/10/23 15:34:07 INFO - jmeter.JMeter: os.arch=amd64 
2013/10/23 15:34:07 INFO - jmeter.JMeter: os.version=6.1 
2013/10/23 15:34:07 INFO - jmeter.JMeter: file.encoding=Cp1252 
2013/10/23 15:34:07 INFO - jmeter.JMeter: Default Locale=English (United States) 
2013/10/23 15:34:07 INFO - jmeter.JMeter: JMeter Locale=English (United States) 
2013/10/23 15:34:07 INFO - jmeter.JMeter: JMeterHome=C:\apache-jmeter-2.10 
2013/10/23 15:34:07 INFO - jmeter.JMeter: user.dir =C:\apache-jmeter-2.10\bin 
2013/10/23 15:34:07 INFO - jmeter.JMeter: PWD  =C:\apache-jmeter-2.10\bin 
2013/10/23 15:34:07 INFO - jmeter.JMeter: IP: xxxxxxxx Name: xxxxx FullName: xxxxx 
2013/10/23 15:34:07 INFO - jmeter.JMeter: Loaded icon properties from org/apache/jmeter/images/icon.properties 
2013/10/23 15:34:07 INFO - jmeter.engine.util.CompoundVariable: Note: Function class names must contain the string: '.functions.' 
2013/10/23 15:34:07 INFO - jmeter.engine.util.CompoundVariable: Note: Function class names must not contain the string: '.gui.' 
2013/10/23 15:34:07 INFO - jmeter.gui.action.LookAndFeelCommand: Using look and feel: javax.swing.plaf.metal.MetalLookAndFeel [Metal, CrossPlatform] 
2013/10/23 15:34:08 INFO - jmeter.util.BSFTestElement: Registering JMeter version of JavaScript engine as work-round for BSF-22 
2013/10/23 15:34:08 INFO - jmeter.protocol.http.sampler.HTTPSamplerBase: Cannot find .className property for htmlParser, using default 
2013/10/23 15:34:08 INFO - jmeter.protocol.http.sampler.HTTPSamplerBase: Parser for text/html is  
2013/10/23 15:34:08 INFO - jmeter.protocol.http.sampler.HTTPSamplerBase: Parser for application/xhtml+xml is  
2013/10/23 15:34:08 INFO - jmeter.protocol.http.sampler.HTTPSamplerBase: Parser for application/xml is  
2013/10/23 15:34:08 INFO - jmeter.protocol.http.sampler.HTTPSamplerBase: Parser for text/xml is  
2013/10/23 15:34:08 INFO - jmeter.protocol.http.sampler.HTTPSamplerBase: Parser for text/vnd.wap.wml is org.apache.jmeter.protocol.http.parser.RegexpHTMLParser 
2013/10/23 15:34:08 INFO - jmeter.gui.util.MenuFactory: Skipping org.apache.jmeter.protocol.http.control.gui.WebServiceSamplerGui 
2013/10/23 15:34:08 INFO - jmeter.gui.util.MenuFactory: Skipping org.apache.jmeter.protocol.http.modifier.gui.ParamModifierGui 
2013/10/23 15:34:08 INFO - jmeter.protocol.http.proxy.ProxyControl: HTTP(S) Test Script Recorder SSL Proxy will use keys that support embedded 3rd party resources in file C:\apache-jmeter-2.10\bin\proxyserver.jks 
2013/10/23 15:34:09 INFO - jmeter.samplers.SampleResult: Note: Sample TimeStamps are START times 
2013/10/23 15:34:09 INFO - jmeter.samplers.SampleResult: sampleresult.default.encoding is set to ISO-8859-1 
2013/10/23 15:34:09 INFO - jmeter.samplers.SampleResult: sampleresult.useNanoTime=true 
2013/10/23 15:34:09 INFO - jmeter.samplers.SampleResult: sampleresult.nanoThreadSleep=5000 
2013/10/23 15:34:22 WARN - jmeter.protocol.http.proxy.ProxyControl: Could not open/read key store C:\apache-jmeter-2.10\bin\proxyserver.jks (The system cannot find the file specified) 
2013/10/23 15:34:22 INFO - jmeter.protocol.http.proxy.ProxyControl: Creating Proxy CA in C:\apache-jmeter-2.10\bin\proxyserver.jks 
2013/10/23 15:34:22 ERROR - jmeter.protocol.http.proxy.ProxyControl: Could not initialise key store java.io.IOException: Cannot run program "keytool" (in directory "C:\apache-jmeter-2.10\bin"): CreateProcess error=2, The system cannot find the file specified 
    at java.lang.ProcessBuilder.start(Unknown Source) 
    at org.apache.jorphan.exec.SystemCommand.run(SystemCommand.java:142) 
    at org.apache.jorphan.exec.SystemCommand.run(SystemCommand.java:125) 
    at org.apache.jorphan.exec.KeyToolUtils.genkeypair(KeyToolUtils.java:123) 
    at org.apache.jorphan.exec.KeyToolUtils.generateProxyCA(KeyToolUtils.java:181) 
    at org.apache.jmeter.protocol.http.proxy.ProxyControl.initDynamicKeyStore(ProxyControl.java:1275) 
    at org.apache.jmeter.protocol.http.proxy.ProxyControl.initKeyStore(ProxyControl.java:1205) 
    at org.apache.jmeter.protocol.http.proxy.ProxyControl.startProxy(ProxyControl.java:431) 
    at org.apache.jmeter.protocol.http.proxy.gui.ProxyControlGui.startProxy(ProxyControlGui.java:485) 
    at org.apache.jmeter.protocol.http.proxy.gui.ProxyControlGui.actionPerformed(ProxyControlGui.java:370) 
    at javax.swing.AbstractButton.fireActionPerformed(Unknown Source) 
    at javax.swing.AbstractButton$Handler.actionPerformed(Unknown Source) 
    at javax.swing.DefaultButtonModel.fireActionPerformed(Unknown Source) 
    at javax.swing.DefaultButtonModel.setPressed(Unknown Source) 
    at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(Unknown Source) 
    at java.awt.Component.processMouseEvent(Unknown Source) 
    at javax.swing.JComponent.processMouseEvent(Unknown Source) 
    at java.awt.Component.processEvent(Unknown Source) 
    at java.awt.Container.processEvent(Unknown Source) 
    at java.awt.Component.dispatchEventImpl(Unknown Source) 
    at java.awt.Container.dispatchEventImpl(Unknown Source) 
    at java.awt.Component.dispatchEvent(Unknown Source) 
    at java.awt.LightweightDispatcher.retargetMouseEvent(Unknown Source) 
    at java.awt.LightweightDispatcher.processMouseEvent(Unknown Source) 
    at java.awt.LightweightDispatcher.dispatchEvent(Unknown Source) 
    at java.awt.Container.dispatchEventImpl(Unknown Source) 
    at java.awt.Window.dispatchEventImpl(Unknown Source) 
    at java.awt.Component.dispatchEvent(Unknown Source) 
    at java.awt.EventQueue.dispatchEventImpl(Unknown Source) 
    at java.awt.EventQueue.access$200(Unknown Source) 
    at java.awt.EventQueue$3.run(Unknown Source) 
    at java.awt.EventQueue$3.run(Unknown Source) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source) 
    at java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source) 
    at java.awt.EventQueue$4.run(Unknown Source) 
    at java.awt.EventQueue$4.run(Unknown Source) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at java.security.ProtectionDomain$1.doIntersectionPrivilege(Unknown Source) 
    at java.awt.EventQueue.dispatchEvent(Unknown Source) 
    at java.awt.EventDispatchThread.pumpOneEventForFilters(Unknown Source) 
    at java.awt.EventDispatchThread.pumpEventsForFilter(Unknown Source) 
    at java.awt.EventDispatchThread.pumpEventsForHierarchy(Unknown Source) 
    at java.awt.EventDispatchThread.pumpEvents(Unknown Source) 
    at java.awt.EventDispatchThread.pumpEvents(Unknown Source) 
    at java.awt.EventDispatchThread.run(Unknown Source) 
Caused by: java.io.IOException: CreateProcess error=2, The system cannot find the file specified 
    at java.lang.ProcessImpl.create(Native Method) 
    at java.lang.ProcessImpl.<init>(Unknown Source) 
    at java.lang.ProcessImpl.start(Unknown Source) 
    ... 46 more 
+0

Zaktualizowałem moją odpowiedź, czy możesz ponownie uruchomić, jeśli nadal nie działa, zapytaj o listę mailingową użytkownika jmeter –

Odpowiedz

10

Od JMeter 2.10, nagranie zostało ulepszone, aby lepiej obsługiwać osadzonych zasobów i tworzenia certyfikatów w locie. To sprawia, że ​​nagrywanie złożonych stron HTTPS jest znacznie łatwiejsze.

Aby dodać te funkcje, JMeter teraz używa keytool narzędzia (dostępnego w JDK), więc należy się upewnić, czy konfiguracja jest poprawna, przeczytaj tę stronę wiki przed rozpoczęciem:

także zapewnienie czytasz:

Uwaga: znacznie lepiej jest używać JDK7. (Jdk7 powinien być zainstalowany w systemie)

Jeśli nie chcesz czytać długiej odpowiedzi (które powinny :-)), a następnie: zapewnić sobie JAVA_HOME i PATH prawidłowo ustawione, aby to zrobić: Otwórz plik jmeter.bat i dodaj to (na początku po komendzie launch.exe):

SET JAVA_HOME=Path to JDK

SET PATH=%PATH%;%JAVA_HOME%\bin

Uruchom ponownie JMeter i powtórz test.

Jeśli to nie działa, można obejść poprzez zdefiniowanie następujących nieruchomości JMeter w user.Properties:

proxy.cert.alias=anything

+0

Dziękuję za szybką odpowiedź. Więc zaktualizowałem java, byłem na 1.7.0_21, który jak przypuszczam powinien być w porządku do 1.7.0_45. "java -version" działa dobrze, próba "java keytool" nie działa. nawigacja do katalogu keytools i próba "java keytool" też nie. gdy znajdę się w katalogu, jeśli uruchomię polecenie "keytool", otrzymam listę poleceń, których można się spodziewać. Czy obsługa java -version działa, czy nie wydaje się, że java działa? czy muszę ustawić inną zmienną systemową czy coś? – hhcib

+0

to wygląda na dezaktywację i może pozwolić mi kontynuować eksperymenty, ale chciałbym ustawić wszystko "we właściwy sposób". +1 dla ciekawostki, która pozwoli mi przynajmniej odkryć jmeter – hhcib

+0

dodając linie do nietoperza poprawił problem, dzięki – hhcib

-1

Również polecam do rozważenia alternatyw w postaci automatycznego pisania skryptu. Faktycznie istnieją pewne sposoby .jmx skryptów Pisanie:

  1. wykorzystaniem proxy, jak to opisano w poradniku dałeś

  2. przyrządem Badboy.

    http://www.badboy.com.au/ http://www.badboysoftware.biz/docs/ http://www.youtube.com/watch?v=OX9NbYuE07I

    zalety: łatwy zapis, łatwy eksport do JMeter.

  3. użyciu blazemeter chrom extenstion:

    http://community.blazemeter.com/knowledgebase/articles/231479-chrome-extension

    korzyści: Można wyeksportować skrypt napisany do JMeter i/lub do chmury, jak również i uruchomić go na chmurze.

    Gdy tylko wypróbujesz te metody, prawdopodobnie dowiesz się, co przegapiłeś.

0

Od wersji JMeter 2.10 należy skonfigurować zmienną PATH w systemie Windows.

Problem wynika z nowego PROXY HTTPS.

Aby uniknąć konfiguracji JMeter i JDK z Oracle, wykonuję pakiet do instalacji.

Nowy pakiet został stworzony dla JMeter 2.11

3

Spróbuj uruchomić JMeter z wiersza poleceń z privs administratora, działa na mnie!

+0

Następnie mam inny błąd: ERROR - jmeter.protocol.http.proxy.ProxyControl: Nie można zainicjować magazynu kluczy java.io.FileNotFoundException: Źródło 'ApacheJMeterTemporaryRootCA .crt "nie istnieje Co mam z tym zrobić? – faramka

Powiązane problemy