Если вы знаете количество записей ex ante, вы должны предварительно распределить пространство, указав индекс (принимая пример данных из другого ответа):
import pandas as pd
import numpy as np
# we know we're gonna have 5 rows of data
numberOfRows = 5
# create dataframe
df = pd.DataFrame(index=np.arange(0, numberOfRows), columns=('lib', 'qty1', 'qty2') )
# now fill it up row by row
for x in np.arange(0, numberOfRows):
#loc or iloc both work here since the index is natural numbers
df.loc[x] = [np.random.randint(-1,1) for n in range(3)]
In[23]: df
Out[23]:
lib qty1 qty2
0 -1 -1 -1
1 0 0 0
2 -1 0 -1
3 0 -1 0
4 -1 0 0
Сравнение скорости
In[30]: %timeit tryThis() # function wrapper for this answer
In[31]: %timeit tryOther() # function wrapper without index (see, for example, @fred)
1000 loops, best of 3: 1.23 ms per loop
100 loops, best of 3: 2.31 ms per loop
И - как из комментариев - с размером 6000, разница в скорости становится еще больше:
Увеличение размера массива (12) и количества строк (500) делает разницу скорости более яркой: 313ms против 2.29s
blockquote>
Доступны следующие утилиты JMX командной строки:
Groovy JMX Пример:
import java.lang.management.*
import javax.management.ObjectName
import javax.management.remote.JMXConnectorFactory as JmxFactory
import javax.management.remote.JMXServiceURL as JmxUrl
import groovy.swing.SwingBuilder
import javax.swing.WindowConstants as WC
def serverUrl = 'service:jmx:rmi:///jndi/rmi://localhost:9003/jmxrmi'
String beanName = "com.webwars.gameplatform.data:type=udmdataloadsystem,id=0"
def server = JmxFactory.connect(new JmxUrl(serverUrl)).MBeanServerConnection
def dataSystem = new GroovyMBean(server, beanName)
println "Connected to:\n$dataSystem\n"
println "Executing jmxForceRefresh()"
dataSystem.jmxForceRefresh();
Пример cmdline-jmxclient:
Если у вас есть
С помощью операции:
Затем вы можете написать простой скрипт bash (если вы загрузите cmdline-jmxclient-0.10.3.jar и поместите в тот же каталог, что и ваш скрипт):
#!/bin/bash
cmdLineJMXJar=./cmdline-jmxclient-0.10.3.jar
user=yourUser
password=yourPassword
jmxHost=localhost
port=9003
#No User and password so pass '-'
echo "Available Operations for com.company.data:type=datasystem,id=0"
java -jar ${cmdLineJMXJar} ${user}:${password} ${jmxHost}:${port} com.company.data:type=datasystem,id=0
echo "Executing XML update..."
java -jar ${cmdLineJMXJar} - ${jmxHost}:${port} com.company.data:type=datasystem,id=0 jmxForceRefresh
Вы также можете посмотреть jmx4perl . Он предоставляет доступ без Java к удаленному MBeans сервера Java EE. Тем не менее, на целевой платформе должен быть установлен небольшой сервлет-агент, который обеспечивает надежный доступ JMX через HTTP с помощью полезной нагрузки JSON. (Версия 0.50 добавит режим без агента, реализуя прокси-сервер JSR-160).
Преимущества - это быстрое время запуска по сравнению с запуском локальной JVM Java и простотой использования. jmx4perl поставляется с полным набором модулей Perl, которые можно легко использовать в ваших собственных сценариях:
use JMX::Jmx4Perl;
use JMX::Jmx4Perl::Alias; # Import certains aliases for MBeans
print "Memory Used: ",
JMX::Jmx4Perl
->new(url => "http://localhost:8080/j4p")
->get_attribute(MEMORY_HEAP_USED);
Вы также можете использовать псевдоним для общих комбинаций MBean / Attribute / Operation (например, для большинства MXBeans). Для дополнительных функций (Nagios-Plugin, XPath-подобный доступ к сложным типам атрибутов ...), пожалуйста, обратитесь к документации jmx4perl.
Плагин Syabru Nagios JMX предназначен для использования в Nagios, но не требует Nagios и очень удобен для использования в командной строке:
~$ ./check_jmx -U service:jmx:rmi:///jndi/rmi://localhost:1099/JMXConnector --username myuser --password mypass -O java.lang:type=Memory -A HeapMemoryUsage -K used
JMX OK - HeapMemoryUsage.used = 445012360 | 'HeapMemoryUsage used'=445012360;;;;
Взгляните на JManage . Он может выполнять методы MBean и получать / устанавливать атрибуты из командной строки .
Немного рискованно, но вы можете запустить зависающую команду POST со значениями из формы с консоли JMX, ее URL-адресом и http-аутентификацией (если требуется):
curl -s -X POST --user 'myuser:mypass'
--data "action=invokeOp&name=App:service=ThisServiceOp&methodIndex=3&arg0=value1&arg1=value1&submit=Invoke"
http://yourhost.domain.com/jmx-console/HtmlAdaptor
Остерегайтесь: метод индекс может измениться с изменениями программного обеспечения. И реализация веб-формы может измениться.
Вышеуказанное основано на источнике служебной страницы JMX для операции, которую вы хотите выполнить:
http://yourhost.domain.com/jmx-console/HtmlAdaptor?action=inspectMBean&name=YourJMXServiceName
Источник формы :
form method="post" action="HtmlAdaptor">
<input type="hidden" name="action" value="invokeOp">
<input type="hidden" name="name" value="App:service=ThisServiceOp">
<input type="hidden" name="methodIndex" value="3">
<hr align='left' width='80'>
<h4>void ThisOperation()</h4>
<p>Operation exposed for management</p>
<table cellspacing="2" cellpadding="2" border="1">
<tr class="OperationHeader">
<th>Param</th>
<th>ParamType</th>
<th>ParamValue</th>
<th>ParamDescription</th>
</tr>
<tr>
<td>p1</td>
<td>java.lang.String</td>
<td>
<input type="text" name="arg0">
</td>
<td>(no description)</td>
</tr>
<tr>
<td>p2</td>
<td>arg1Type</td>
<td>
<input type="text" name="arg1">
</td>
<td>(no description)</td>
</tr>
</table>
<input type="submit" value="Invoke">
</form>
HttpURLConnection
, и я могу подтвердить, что он работает. (кстати, submit=Invoke
не требуется)
– tom
18 July 2018 в 11:54
@ Dougnukem ответ мне очень помог. Я применил подход Groovy (suing groovy 2.3.3)
Я внес некоторые изменения в код Dougnukem. Это будет работать с java 7 и будет печатать два атрибута для stdout evet 10 секунд.
package com.my.company.jmx
import groovy.util.GroovyMBean;
import javax.management.remote.JMXServiceURL
import javax.management.remote.JMXConnectorFactory
import java.lang.management.*
class Monitor {
static main(args) {
def serverUrl = 'service:jmx:rmi:///jndi/rmi://localhost:5019/jmxrmi'
String beanName = "Catalina:type=DataSource,class=javax.sql.DataSource,name=\"jdbc/CommonDB\""
println "numIdle,numActive"
while(1){
def server = JMXConnectorFactory.connect(new JMXServiceURL(serverUrl))
//make sure to reconnect in case the jvm was restrated
server.connect()
GroovyMBean mbean = new GroovyMBean(server.MBeanServerConnection, beanName)
println "${mbean.numIdle},${mbean.numActive}"
server.close()
sleep(10000)
}
}
}
Скомпилируйте этот код в банку, используя maven-compiler-plugin, чтобы вам не требовалась жесткая установка только groovy- all.jar Ниже приведено соответствующее определение плагина и зависимость.
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<compilerId>groovy-eclipse-compiler</compilerId>
<source>1.7</source>
<target>1.7</target>
</configuration>
<dependencies>
<dependency>
<groupId>org.codehaus.groovy</groupId>
<artifactId>groovy-eclipse-compiler</artifactId>
<version>2.8.0-01</version>
</dependency>
<dependency>
<groupId>org.codehaus.groovy</groupId>
<artifactId>groovy-eclipse-batch</artifactId>
<version>2.3.4-01</version>
</dependency>
</dependencies>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>org.codehaus.groovy</groupId>
<artifactId>groovy-all</artifactId>
<version>2.4.3</version>
</dependency>
</dependencies>
Обмотайте его летучей мышью или оболочкой, и она будет выводить данные на стандартный вывод.
Я не уверен в среде, похожей на bash. Вы можете попробовать несколько простых программ-оболочек в Java (с аргументами программы), которые вызывают ваши MBeans на удаленном сервере. Затем вы можете вызвать эти оболочки из сценария оболочки
. Если вы можете использовать что-то вроде Python или Perl, вас может заинтересовать JSR-262 , что позволяет вам разоблачить операции JMX веб-сервисы. Это планируется включить в Java 7, но вы, возможно, сможете использовать кандидат на выпуск ссылки
Потенциально проще всего написать это в Java
import javax.management.*;
import javax.management.remote.*;
public class JmxInvoke {
public static void main(String... args) throws Exception {
JMXConnectorFactory.connect(new JMXServiceURL(args[0]))
.getMBeanServerConnection().invoke(new ObjectName(args[1]), args[2], new Object[]{}, new String[]{})
}
}
. Это будет скомпилировано для одного класса .class и не нуждается в зависимостях на сервере или в какой-либо сложной упаковке maven.
call it с
javac JmsInvoke.java
java -cp . JmxInvoke [url] [beanName] [method]
Я разработал jmxfuse, который предоставляет JMX Mbeans как файловую систему Linux FUSE с аналогичной функциональностью как / proc fs. Он полагается на Jolokia как мост на JMX. Атрибуты и операции отображаются для чтения и записи.
http://code.google.com/p/jmxfuse/
Например, чтобы читать атрибут:
me@oddjob:jmx$ cd log4j/root/attributes
me@oddjob:jmx$ cat priority
для записи атрибута:
me@oddjob:jmx$ echo "WARN" > priority
для вызова операции:
me@oddjob:jmx$ cd Catalina/none/none/WebModule/localhost/helloworld/operations/addParameter
me@oddjob:jmx$ echo "myParam myValue" > invoke