打包方式修改
parent
3cedbda107
commit
bb9ca476c8
|
@ -174,19 +174,29 @@ this.onReceive=function(head,type,payload){
|
||||||
|
|
||||||
//数据上报
|
//数据上报
|
||||||
var reply=
|
var reply=
|
||||||
{
|
{
|
||||||
productKey:pk,
|
productKey:pk,
|
||||||
deviceName:dn,
|
deviceName:dn,
|
||||||
mid:payload.id,
|
mid:payload.id,
|
||||||
content:{
|
content:{
|
||||||
topic:topic.replace("/s/","/c/")+"_reply",
|
topic:topic.replace("/s/","/c/")+"_reply",
|
||||||
payload:JSON.stringify({
|
payload:JSON.stringify({
|
||||||
id:payload.id,
|
id:payload.id,
|
||||||
method: payload.method+"_reply",
|
method: payload.method+"_reply",
|
||||||
code:0,
|
code:0,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
var action={};
|
||||||
|
if(!topic.endsWith("_reply")){
|
||||||
|
//需要回复的消息
|
||||||
|
action={
|
||||||
|
type:"ack",
|
||||||
|
content:JSON.stringify(reply)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
type:"report",
|
type:"report",
|
||||||
data:{
|
data:{
|
||||||
|
@ -198,10 +208,7 @@ this.onReceive=function(head,type,payload){
|
||||||
payload:payload
|
payload:payload
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
action:{
|
action:action
|
||||||
type:"ack",
|
|
||||||
content:JSON.stringify(reply)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Binary file not shown.
Before Width: | Height: | Size: 497 KiB |
BIN
doc/安装Pulsar.jpg
BIN
doc/安装Pulsar.jpg
Binary file not shown.
Before Width: | Height: | Size: 108 KiB |
|
@ -38,7 +38,8 @@ public class ComponentClassLoader {
|
||||||
classLoader.close();
|
classLoader.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
classLoader = URLClassLoader.newInstance(new URL[]{jarPath.toURI().toURL()}, ClassLoader.getSystemClassLoader());
|
classLoader = URLClassLoader.newInstance(new URL[]{jarPath.toURI().toURL()},
|
||||||
|
Thread.currentThread().getContextClassLoader());
|
||||||
classLoaders.put(name, classLoader);
|
classLoaders.put(name, classLoader);
|
||||||
|
|
||||||
Method method = URLClassLoader.class.getDeclaredMethod("addURL", URL.class);
|
Method method = URLClassLoader.class.getDeclaredMethod("addURL", URL.class);
|
||||||
|
|
|
@ -48,7 +48,7 @@ function register(payload){
|
||||||
var dn=arr[1];
|
var dn=arr[1];
|
||||||
var model=arr[2];
|
var model=arr[2];
|
||||||
var pwd=md5("xdkKUymrEGSCYWswqCvSPyRSFvH5j7CU"+auth.clientid);
|
var pwd=md5("xdkKUymrEGSCYWswqCvSPyRSFvH5j7CU"+auth.clientid);
|
||||||
if(pwd!=auth.password){
|
if(pwd.toLocaleLowerCase()!=auth.password.toLocaleLowerCase()){
|
||||||
throw new Error("incorrect password");
|
throw new Error("incorrect password");
|
||||||
}
|
}
|
||||||
return {
|
return {
|
||||||
|
@ -173,6 +173,30 @@ this.onReceive=function(head,type,payload){
|
||||||
}
|
}
|
||||||
|
|
||||||
//数据上报
|
//数据上报
|
||||||
|
var reply=
|
||||||
|
{
|
||||||
|
productKey:pk,
|
||||||
|
deviceName:dn,
|
||||||
|
mid:payload.id,
|
||||||
|
content:{
|
||||||
|
topic:topic.replace("/s/","/c/")+"_reply",
|
||||||
|
payload:JSON.stringify({
|
||||||
|
id:payload.id,
|
||||||
|
method: payload.method+"_reply",
|
||||||
|
code:0,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var action={};
|
||||||
|
if(!topic.endsWith("_reply")){
|
||||||
|
//需要回复的消息
|
||||||
|
action={
|
||||||
|
type:"ack",
|
||||||
|
content:JSON.stringify(reply)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
type:"report",
|
type:"report",
|
||||||
data:{
|
data:{
|
||||||
|
@ -183,7 +207,8 @@ this.onReceive=function(head,type,payload){
|
||||||
topic:topic,
|
topic:topic,
|
||||||
payload:payload
|
payload:payload
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
|
action:action
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,104 +0,0 @@
|
||||||
|
|
||||||
var mid=1;
|
|
||||||
|
|
||||||
function getMid(){
|
|
||||||
mid++;
|
|
||||||
if(mid>10000){
|
|
||||||
mid=1;
|
|
||||||
}
|
|
||||||
return mid+"";
|
|
||||||
}
|
|
||||||
|
|
||||||
this.decode = function (msg) {
|
|
||||||
//对msg进行解析,并返回物模型数据
|
|
||||||
var content=msg.content;
|
|
||||||
var topic = content.topic;
|
|
||||||
var payload = content.payload;
|
|
||||||
var identifier = topic.substring(topic.lastIndexOf("/") + 1);
|
|
||||||
|
|
||||||
if (topic.endsWith("/property/post")) {
|
|
||||||
//属性上报
|
|
||||||
return {
|
|
||||||
mid: msg.mid,
|
|
||||||
productKey: msg.productKey,
|
|
||||||
deviceName: msg.deviceName,
|
|
||||||
type:"property",
|
|
||||||
identifier: "report", //属性上报
|
|
||||||
occur: new Date().getTime(), //时间戳,设备上的事件或数据产生的本地时间
|
|
||||||
time: new Date().getTime(), //时间戳,消息上报时间
|
|
||||||
data: payload.params,
|
|
||||||
};
|
|
||||||
} else if (topic.indexOf("/event/") > 0) {
|
|
||||||
//事件上报
|
|
||||||
return {
|
|
||||||
mid: msg.mid,
|
|
||||||
productKey: msg.productKey,
|
|
||||||
deviceName: msg.deviceName,
|
|
||||||
type:"event",
|
|
||||||
identifier: identifier,
|
|
||||||
occur: new Date().getTime(),
|
|
||||||
time: new Date().getTime(),
|
|
||||||
data: payload.params,
|
|
||||||
};
|
|
||||||
}else if(topic.endsWith("/service/property/set_reply")){
|
|
||||||
//属性设置回复
|
|
||||||
return {
|
|
||||||
mid: msg.mid,
|
|
||||||
productKey: msg.productKey,
|
|
||||||
deviceName: msg.deviceName,
|
|
||||||
type:"property",
|
|
||||||
identifier: identifier,
|
|
||||||
occur: new Date().getTime(),
|
|
||||||
time: new Date().getTime(),
|
|
||||||
code: payload.code
|
|
||||||
};
|
|
||||||
} else if (topic.endsWith("_reply")) {
|
|
||||||
//服务回复
|
|
||||||
return {
|
|
||||||
mid: msg.mid,
|
|
||||||
productKey: msg.productKey,
|
|
||||||
deviceName: msg.deviceName,
|
|
||||||
type:"service",
|
|
||||||
identifier: identifier,
|
|
||||||
occur: new Date().getTime(),
|
|
||||||
time: new Date().getTime(),
|
|
||||||
code: payload.code,
|
|
||||||
data: payload.data,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
};
|
|
||||||
|
|
||||||
this.encode = function (service,device) {
|
|
||||||
var type=service.type;
|
|
||||||
var identifier=service.identifier;
|
|
||||||
var topic="/sys/"+service.productKey+"/"+service.deviceName+"/c/service/";
|
|
||||||
var method="thing.service.";
|
|
||||||
|
|
||||||
if(type=="property"){
|
|
||||||
method+="property."+identifier;
|
|
||||||
topic+="property/"+identifier;
|
|
||||||
}else if(type=="service"){
|
|
||||||
method+=identifier;
|
|
||||||
topic+=identifier;
|
|
||||||
}
|
|
||||||
var deviceMid=getMid();
|
|
||||||
var params={};
|
|
||||||
for(var p in service.params){
|
|
||||||
params[p]=service.params[p];
|
|
||||||
}
|
|
||||||
|
|
||||||
return {
|
|
||||||
productKey:service.productKey,
|
|
||||||
deviceName:service.deviceName,
|
|
||||||
mid:deviceMid,
|
|
||||||
content:{
|
|
||||||
topic:topic,
|
|
||||||
payload:JSON.stringify({
|
|
||||||
id:deviceMid,
|
|
||||||
method:method,
|
|
||||||
params:params
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
|
@ -3,10 +3,62 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/plugins/maven-assembly-plugin/assembly/1.1.2 http://maven.apache.org/xsd/assembly-1.1.2.xsd">
|
xsi:schemaLocation="http://maven.apache.org/plugins/maven-assembly-plugin/assembly/1.1.2 http://maven.apache.org/xsd/assembly-1.1.2.xsd">
|
||||||
<id>standalone-package</id>
|
<id>standalone-package</id>
|
||||||
<formats>
|
<formats>
|
||||||
<format>tar</format>
|
<format>zip</format>
|
||||||
</formats>
|
</formats>
|
||||||
|
|
||||||
<includeBaseDirectory>false</includeBaseDirectory>
|
<includeBaseDirectory>false</includeBaseDirectory>
|
||||||
|
|
||||||
<fileSets>
|
<fileSets>
|
||||||
|
<!--
|
||||||
|
0755->即用户具有读/写/执行权限,组用户和其它用户具有读写权限;
|
||||||
|
0644->即用户具有读写权限,组用户和其它用户具有只读权限;
|
||||||
|
-->
|
||||||
|
<!-- 将assemblies/bin目录下的所有文件输出到打包后的bin目录中 -->
|
||||||
|
<fileSet>
|
||||||
|
<directory>${project.parent.basedir}/iot-standalone/src/main/bin</directory>
|
||||||
|
<outputDirectory>/bin</outputDirectory>
|
||||||
|
<includes>
|
||||||
|
<include>**/*.bat</include>
|
||||||
|
<include>**/*.sh</include>
|
||||||
|
</includes>
|
||||||
|
<fileMode>0755</fileMode>
|
||||||
|
<!--如果是脚本,一定要改为unix.如果是在windows上面编码,会出现dos编写问题-->
|
||||||
|
<lineEnding>unix</lineEnding>
|
||||||
|
<filtered>true</filtered><!-- 是否进行属性替换 -->
|
||||||
|
</fileSet>
|
||||||
|
|
||||||
|
<!-- 将/iot-standalone/src/main/resources下配置文件打包到config目录 -->
|
||||||
|
<fileSet>
|
||||||
|
<directory>${project.parent.basedir}/iot-standalone/src/main/resources</directory>
|
||||||
|
<outputDirectory>/config</outputDirectory>
|
||||||
|
<includes>
|
||||||
|
<include>**/*.xml</include>
|
||||||
|
<include>**/*.properties</include>
|
||||||
|
<include>**/*.yml</include>
|
||||||
|
</includes>
|
||||||
|
<filtered>true</filtered><!-- 是否进行属性替换 -->
|
||||||
|
</fileSet>
|
||||||
|
|
||||||
|
<!-- 将项目启动jar打包到lib目录中 -->
|
||||||
|
<fileSet>
|
||||||
|
<directory>target</directory>
|
||||||
|
<outputDirectory>lib</outputDirectory>
|
||||||
|
<includes>
|
||||||
|
<include>*.jar</include>
|
||||||
|
</includes>
|
||||||
|
</fileSet>
|
||||||
|
|
||||||
|
<!-- 将项目说明文档打包到docs目录中 -->
|
||||||
|
<fileSet>
|
||||||
|
<directory>${project.parent.basedir}</directory>
|
||||||
|
<outputDirectory>docs</outputDirectory>
|
||||||
|
<includes>
|
||||||
|
<include>*.md</include>
|
||||||
|
</includes>
|
||||||
|
<fileMode>0644</fileMode>
|
||||||
|
</fileSet>
|
||||||
|
|
||||||
|
<!--将初始化数据打包到data目录-->
|
||||||
<fileSet>
|
<fileSet>
|
||||||
<directory>${project.parent.basedir}/data/components</directory>
|
<directory>${project.parent.basedir}/data/components</directory>
|
||||||
<outputDirectory>data/components</outputDirectory>
|
<outputDirectory>data/components</outputDirectory>
|
||||||
|
@ -28,13 +80,6 @@
|
||||||
<include>**/*</include>
|
<include>**/*</include>
|
||||||
</includes>
|
</includes>
|
||||||
</fileSet>
|
</fileSet>
|
||||||
</fileSets>
|
|
||||||
<dependencySets>
|
|
||||||
<dependencySet>
|
|
||||||
<outputDirectory>lib</outputDirectory>
|
|
||||||
|
|
||||||
<scope>runtime</scope>
|
</fileSets>
|
||||||
<unpack>false</unpack>
|
|
||||||
</dependencySet>
|
|
||||||
</dependencySets>
|
|
||||||
</assembly>
|
</assembly>
|
Binary file not shown.
|
@ -181,6 +181,11 @@
|
||||||
</configuration>
|
</configuration>
|
||||||
</plugin>
|
</plugin>
|
||||||
|
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-maven-plugin</artifactId>
|
||||||
|
</plugin>
|
||||||
|
|
||||||
<plugin>
|
<plugin>
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
<artifactId>maven-assembly-plugin</artifactId>
|
<artifactId>maven-assembly-plugin</artifactId>
|
||||||
|
|
|
@ -0,0 +1,38 @@
|
||||||
|
echo off
|
||||||
|
|
||||||
|
set APP_NAME=${project.build.finalName}.jar
|
||||||
|
set LOG_IMPL_FILE=log4j2.xml
|
||||||
|
set LOGGING_CONFIG=
|
||||||
|
if exist ../config/%LOG_IMPL_FILE% (
|
||||||
|
set LOGGING_CONFIG=-Dlogging.config=../config/%LOGGING_CONFIG%
|
||||||
|
)
|
||||||
|
set CONFIG= -Dlogging.path=../log %LOGGING_CONFIG% -Dspring.config.location=../config/
|
||||||
|
|
||||||
|
set DEBUG_OPTS=
|
||||||
|
if ""%1"" == ""debug"" (
|
||||||
|
set DEBUG_OPTS= -Xloggc:../log/gc.log -verbose:gc -XX:+PrintGCDetails -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=../log
|
||||||
|
goto debug
|
||||||
|
)
|
||||||
|
|
||||||
|
set JMX_OPTS=
|
||||||
|
if ""%1"" == ""jmx"" (
|
||||||
|
set JMX_OPTS= -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=9888 -Dcom.sun.management.jmxremote.ssl=FALSE -Dcom.sun.management.jmxremote.authenticate=FALSE
|
||||||
|
goto jmx
|
||||||
|
)
|
||||||
|
|
||||||
|
echo "Starting the %APP_NAME%"
|
||||||
|
java -Xms512m -Xmx512m -server %DEBUG_OPTS% %JMX_OPTS% %CONFIG% -jar ../lib/%APP_NAME%
|
||||||
|
echo "java -Xms512m -Xmx512m -server %DEBUG_OPTS% %JMX_OPTS% %CONFIG% -jar ../lib/%APP_NAME%"
|
||||||
|
goto end
|
||||||
|
|
||||||
|
:debug
|
||||||
|
echo "debug"
|
||||||
|
java -Xms512m -Xmx512m -server %DEBUG_OPTS% %CONFIG% -jar ../lib/%APP_NAME%
|
||||||
|
goto end
|
||||||
|
|
||||||
|
:jmx
|
||||||
|
java -Xms512m -Xmx512m -server %JMX_OPTS% %CONFIG% -jar ../lib/%APP_NAME%
|
||||||
|
goto end
|
||||||
|
|
||||||
|
:end
|
||||||
|
pause
|
|
@ -0,0 +1,109 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# 项目名称
|
||||||
|
SERVER_NAME="${project.artifactId}"
|
||||||
|
|
||||||
|
# jar名称
|
||||||
|
JAR_NAME="${project.build.finalName}.jar"
|
||||||
|
|
||||||
|
# 进入bin目录
|
||||||
|
cd `dirname $0`
|
||||||
|
# bin目录绝对路径
|
||||||
|
BIN_DIR=`pwd`
|
||||||
|
# 返回到上一级项目根目录路径
|
||||||
|
cd ..
|
||||||
|
# 打印项目根目录绝对路径
|
||||||
|
# `pwd` 执行系统命令并获得结果
|
||||||
|
DEPLOY_DIR=`pwd`
|
||||||
|
|
||||||
|
# 外部配置文件绝对目录,如果是目录需要/结尾,也可以直接指定文件
|
||||||
|
# 如果指定的是目录,spring则会读取目录中的所有配置文件
|
||||||
|
CONF_DIR=$DEPLOY_DIR/config
|
||||||
|
# SERVER_PORT=`sed '/server.port/!d;s/.*=//' config/application.properties | tr -d '\r'`
|
||||||
|
# 获取应用的端口号
|
||||||
|
SERVER_PORT=`sed -nr '/port: [0-9]+/ s/.*port: +([0-9]+).*/\1/p' config/application.yml|head -1`
|
||||||
|
|
||||||
|
PIDS=`ps -f | grep java | grep "$CONF_DIR" |awk '{print $2}'`
|
||||||
|
if [ "$1" = "status" ]; then
|
||||||
|
if [ -n "$PIDS" ]; then
|
||||||
|
echo "The $SERVER_NAME is running...!"
|
||||||
|
echo "PID: $PIDS"
|
||||||
|
exit 0
|
||||||
|
else
|
||||||
|
echo "The $SERVER_NAME is stopped"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -n "$PIDS" ]; then
|
||||||
|
echo "ERROR: The $SERVER_NAME already started!"
|
||||||
|
echo "PID: $PIDS"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -n "$SERVER_PORT" ]; then
|
||||||
|
SERVER_PORT_COUNT=`netstat -tln | grep $SERVER_PORT | wc -l`
|
||||||
|
if [ $SERVER_PORT_COUNT -gt 0 ]; then
|
||||||
|
echo "ERROR: The $SERVER_NAME port $SERVER_PORT already used!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# 项目日志输出绝对路径
|
||||||
|
LOGS_DIR=$DEPLOY_DIR/log
|
||||||
|
# 如果logs文件夹不存在,则创建文件夹
|
||||||
|
if [ ! -d $LOGS_DIR ]; then
|
||||||
|
mkdir $LOGS_DIR
|
||||||
|
fi
|
||||||
|
STDOUT_FILE=$LOGS_DIR/catalina.log
|
||||||
|
|
||||||
|
# JVM Configuration
|
||||||
|
JAVA_OPTS=" -Djava.awt.headless=true -Djava.net.preferIPv4Stack=true "
|
||||||
|
JAVA_DEBUG_OPTS=""
|
||||||
|
if [ "$1" = "debug" ]; then
|
||||||
|
JAVA_DEBUG_OPTS=" -Xdebug -Xnoagent -Djava.compiler=NONE -Xrunjdwp:transport=dt_socket,address=8000,server=y,suspend=n "
|
||||||
|
fi
|
||||||
|
|
||||||
|
JAVA_JMX_OPTS=""
|
||||||
|
if [ "$1" = "jmx" ]; then
|
||||||
|
JAVA_JMX_OPTS=" -Dcom.sun.management.jmxremote.port=1099 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false "
|
||||||
|
fi
|
||||||
|
|
||||||
|
JAVA_MEM_OPTS=""
|
||||||
|
BITS=`java -version 2>&1 | grep -i 64-bit`
|
||||||
|
if [ -n "$BITS" ]; then
|
||||||
|
JAVA_MEM_OPTS=" -server -Xmx512m -Xms512m -Xmn256m -Xss256k"
|
||||||
|
else
|
||||||
|
JAVA_MEM_OPTS=" -server -Xms512m -Xmx512m"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# 加载外部log4j2文件的配置
|
||||||
|
LOG_IMPL_FILE=log4j2.xml
|
||||||
|
LOGGING_CONFIG=""
|
||||||
|
if [ -f "$CONF_DIR/$LOG_IMPL_FILE" ]
|
||||||
|
then
|
||||||
|
LOGGING_CONFIG="-Dlogging.config=$CONF_DIR/$LOG_IMPL_FILE"
|
||||||
|
fi
|
||||||
|
CONFIG_FILES=" -Dlogging.path=$LOGS_DIR $LOGGING_CONFIG -Dspring.config.location=$CONF_DIR/ "
|
||||||
|
echo -e "Starting the $SERVER_NAME ..."
|
||||||
|
nohup java $JAVA_OPTS $JAVA_MEM_OPTS $JAVA_DEBUG_OPTS $JAVA_JMX_OPTS $CONFIG_FILES -jar $DEPLOY_DIR/lib/$JAR_NAME > $STDOUT_FILE 2>&1 &
|
||||||
|
|
||||||
|
COUNT=0
|
||||||
|
while [ $COUNT -lt 1 ]; do
|
||||||
|
echo -e ".\c"
|
||||||
|
sleep 1
|
||||||
|
if [ -n "$SERVER_PORT" ]; then
|
||||||
|
COUNT=`netstat -an | grep $SERVER_PORT | wc -l`
|
||||||
|
else
|
||||||
|
COUNT=`ps -f | grep java | grep "$DEPLOY_DIR" | awk '{print $2}' | wc -l`
|
||||||
|
fi
|
||||||
|
if [ $COUNT -gt 0 ]; then
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
|
||||||
|
echo "OK!"
|
||||||
|
PIDS=`ps -f | grep java | grep "$DEPLOY_DIR" | awk '{print $2}'`
|
||||||
|
echo "PID: $PIDS"
|
||||||
|
echo "STDOUT: $STDOUT_FILE"
|
|
@ -0,0 +1,18 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# 项目名称
|
||||||
|
APPLICATION="${project.artifactId}"
|
||||||
|
|
||||||
|
# 项目启动jar包名称
|
||||||
|
APPLICATION_JAR="${project.build.finalName}.jar"
|
||||||
|
|
||||||
|
# 通过项目名称查找到PI,然后kill -9 pid
|
||||||
|
PID=$(ps -ef | grep "${APPLICATION_JAR}" | grep -v grep | awk '{ print $2 }')
|
||||||
|
if [[ -z "$PID" ]]
|
||||||
|
then
|
||||||
|
echo ${APPLICATION} is already stopped
|
||||||
|
else
|
||||||
|
echo kill ${PID}
|
||||||
|
kill -9 ${PID}
|
||||||
|
echo ${APPLICATION} stopped successfully
|
||||||
|
fi
|
|
@ -21,7 +21,10 @@ public class EmbeddedRedisConfig {
|
||||||
RedisServer redisServer;
|
RedisServer redisServer;
|
||||||
String os = System.getProperty("os.name").toLowerCase();
|
String os = System.getProperty("os.name").toLowerCase();
|
||||||
if (os.contains("windows")) {
|
if (os.contains("windows")) {
|
||||||
redisServer = RedisServer.builder().setting("maxheap 200m").build();
|
redisServer = RedisServer.builder().setting("maxheap 200m")
|
||||||
|
.port(6379)
|
||||||
|
.setting("bind localhost")
|
||||||
|
.build();
|
||||||
} else {
|
} else {
|
||||||
redisServer = new RedisServer();
|
redisServer = new RedisServer();
|
||||||
}
|
}
|
||||||
|
|
|
@ -150,26 +150,7 @@ public class DeviceService {
|
||||||
//设备指令下发
|
//设备指令下发
|
||||||
deviceComponentManager.send(thingService);
|
deviceComponentManager.send(thingService);
|
||||||
}
|
}
|
||||||
String mid = thingService.getMid();
|
return thingService.getMid();
|
||||||
DeviceInfo device = deviceInfoData.findByDeviceId(deviceId);
|
|
||||||
|
|
||||||
//保存设备日志
|
|
||||||
ThingModelMessage thingModelMessage = ThingModelMessage.builder()
|
|
||||||
.mid(mid)
|
|
||||||
.deviceId(deviceId)
|
|
||||||
.productKey(pk)
|
|
||||||
.deviceName(dn)
|
|
||||||
.uid(device.getUid())
|
|
||||||
.type(type)
|
|
||||||
.identifier(identifier)
|
|
||||||
.data(data)
|
|
||||||
.occurred(System.currentTimeMillis())
|
|
||||||
.time(System.currentTimeMillis())
|
|
||||||
.build();
|
|
||||||
|
|
||||||
thingModelMessageData.add(thingModelMessage);
|
|
||||||
|
|
||||||
return mid;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,5 +20,7 @@ public class Request {
|
||||||
|
|
||||||
private String id;
|
private String id;
|
||||||
|
|
||||||
|
private String method;
|
||||||
|
|
||||||
private Object params;
|
private Object params;
|
||||||
}
|
}
|
|
@ -33,8 +33,8 @@ public class ReportTest {
|
||||||
|
|
||||||
|
|
||||||
if (args.length == 0) {
|
if (args.length == 0) {
|
||||||
Mqtt.brokerHost = "127.0.0.1";
|
// Mqtt.brokerHost = "127.0.0.1";
|
||||||
// Mqtt.brokerHost = "120.76.96.206";
|
Mqtt.brokerHost = "120.76.96.206";
|
||||||
// Mqtt.brokerHost = "172.16.1.109";
|
// Mqtt.brokerHost = "172.16.1.109";
|
||||||
} else {
|
} else {
|
||||||
Mqtt.brokerHost = args[0];
|
Mqtt.brokerHost = args[0];
|
||||||
|
@ -74,6 +74,7 @@ public class ReportTest {
|
||||||
() -> {
|
() -> {
|
||||||
Request request = new Request();
|
Request request = new Request();
|
||||||
request.setId(UUID.randomUUID().toString());
|
request.setId(UUID.randomUUID().toString());
|
||||||
|
request.setMethod("thing.event.property.post");
|
||||||
Map<String, Object> param = new HashMap<>();
|
Map<String, Object> param = new HashMap<>();
|
||||||
param.put("volt", Math.round(Math.random() * 100));
|
param.put("volt", Math.round(Math.random() * 100));
|
||||||
request.setParams(param);
|
request.setParams(param);
|
||||||
|
|
Loading…
Reference in New Issue