Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
O
OpenXG-WIC-Cnf
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
3
Issues
3
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
CommunityXG
OpenXG-WIC-Cnf
Commits
29112de4
Commit
29112de4
authored
Jan 29, 2021
by
谢建斌
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
代码重构
parent
a0ca07ec
Changes
85
Hide whitespace changes
Inline
Side-by-side
Showing
85 changed files
with
1633 additions
and
279 deletions
+1633
-279
apps/cnf-space-iot/space-iot-mqtt/src/main/java/com/jbxie/spaceiotmqtt/service/ipService.java
...c/main/java/com/jbxie/spaceiotmqtt/service/ipService.java
+0
-58
apps/cnf-spaceiot-longConnection/csl-common-api/pom.xml
apps/cnf-spaceiot-longConnection/csl-common-api/pom.xml
+22
-0
apps/cnf-spaceiot-longConnection/csl-common-api/src/main/java/top/ninwoo/common/entity/DataPackage.java
...i/src/main/java/top/ninwoo/common/entity/DataPackage.java
+25
-0
apps/cnf-spaceiot-longConnection/csl-node-ground/pom.xml
apps/cnf-spaceiot-longConnection/csl-node-ground/pom.xml
+47
-0
apps/cnf-spaceiot-longConnection/csl-node-ground/src/main/java/top/ninwoo/ground/GroundMain.java
...de-ground/src/main/java/top/ninwoo/ground/GroundMain.java
+11
-0
apps/cnf-spaceiot-longConnection/csl-node-ground/src/main/java/top/ninwoo/ground/register/MyApplicationRunner.java
.../java/top/ninwoo/ground/register/MyApplicationRunner.java
+157
-0
apps/cnf-spaceiot-longConnection/csl-node-ground/src/main/java/top/ninwoo/ground/service/GroundService.java
...rc/main/java/top/ninwoo/ground/service/GroundService.java
+134
-0
apps/cnf-spaceiot-longConnection/csl-node-ground/src/main/java/top/ninwoo/ground/service/IPService.java
...nd/src/main/java/top/ninwoo/ground/service/IPService.java
+4
-4
apps/cnf-spaceiot-longConnection/csl-node-ground/test.py
apps/cnf-spaceiot-longConnection/csl-node-ground/test.py
+7
-0
apps/cnf-spaceiot-longConnection/csl-node-satellite/pom.xml
apps/cnf-spaceiot-longConnection/csl-node-satellite/pom.xml
+42
-0
apps/cnf-spaceiot-longConnection/csl-node-satellite/src/main/java/top/ninwoo/satellite/SatelliteMain.java
...ite/src/main/java/top/ninwoo/satellite/SatelliteMain.java
+11
-0
apps/cnf-spaceiot-longConnection/csl-node-satellite/src/main/java/top/ninwoo/satellite/register/MyApplicationRunner.java
...va/top/ninwoo/satellite/register/MyApplicationRunner.java
+100
-0
apps/cnf-spaceiot-longConnection/csl-node-satellite/src/main/java/top/ninwoo/satellite/service/IPService.java
...src/main/java/top/ninwoo/satellite/service/IPService.java
+24
-0
apps/cnf-spaceiot-longConnection/pom.xml
apps/cnf-spaceiot-longConnection/pom.xml
+57
-0
apps/cnf-spaceiot-mqtt/pom.xml
apps/cnf-spaceiot-mqtt/pom.xml
+3
-3
apps/cnf-spaceiot-mqtt/src/main/java/top/ninwoo/mqtt/IotMqttMain.java
...ceiot-mqtt/src/main/java/top/ninwoo/mqtt/IotMqttMain.java
+9
-5
apps/cnf-spaceiot-mqtt/src/main/java/top/ninwoo/mqtt/controller/MqttController.java
.../main/java/top/ninwoo/mqtt/controller/MqttController.java
+2
-4
apps/cnf-spaceiot-mqtt/src/main/java/top/ninwoo/mqtt/mqttUtils/MqttClientCallback.java
...in/java/top/ninwoo/mqtt/mqttUtils/MqttClientCallback.java
+7
-9
apps/cnf-spaceiot-mqtt/src/main/java/top/ninwoo/mqtt/mqttUtils/MyMqttClient.java
...src/main/java/top/ninwoo/mqtt/mqttUtils/MyMqttClient.java
+12
-6
apps/cnf-spaceiot-mqtt/src/main/java/top/ninwoo/mqtt/mqttUtils/PublishThread.java
...rc/main/java/top/ninwoo/mqtt/mqttUtils/PublishThread.java
+2
-3
apps/cnf-spaceiot-shortConnection/css-common-api/pom.xml
apps/cnf-spaceiot-shortConnection/css-common-api/pom.xml
+22
-0
apps/cnf-spaceiot-shortConnection/css-common-api/src/main/java/top/ninwoo/common/entity/ClientKVAck.java
...i/src/main/java/top/ninwoo/common/entity/ClientKVAck.java
+3
-3
apps/cnf-spaceiot-shortConnection/css-common-api/src/main/java/top/ninwoo/common/entity/ClientKVReq.java
...i/src/main/java/top/ninwoo/common/entity/ClientKVReq.java
+4
-3
apps/cnf-spaceiot-shortConnection/css-node-ground/pom.xml
apps/cnf-spaceiot-shortConnection/css-node-ground/pom.xml
+11
-15
apps/cnf-spaceiot-shortConnection/css-node-ground/src/main/java/top/ninwoo/ground/GroundMain.java
...de-ground/src/main/java/top/ninwoo/ground/GroundMain.java
+11
-0
apps/cnf-spaceiot-shortConnection/css-node-ground/src/main/java/top/ninwoo/ground/register/RaftClient.java
.../src/main/java/top/ninwoo/ground/register/RaftClient.java
+77
-0
apps/cnf-spaceiot-shortConnection/css-node-ground/src/main/java/top/ninwoo/ground/register/RaftClient2.java
...src/main/java/top/ninwoo/ground/register/RaftClient2.java
+53
-0
apps/cnf-spaceiot-shortConnection/css-node-ground/src/main/java/top/ninwoo/ground/register/RaftClient3.java
...src/main/java/top/ninwoo/ground/register/RaftClient3.java
+81
-0
apps/cnf-spaceiot-shortConnection/css-node-satellite/Dockerfile
...nf-spaceiot-shortConnection/css-node-satellite/Dockerfile
+0
-0
apps/cnf-spaceiot-shortConnection/css-node-satellite/pom.xml
apps/cnf-spaceiot-shortConnection/css-node-satellite/pom.xml
+63
-0
apps/cnf-spaceiot-shortConnection/css-node-satellite/readme.md
...cnf-spaceiot-shortConnection/css-node-satellite/readme.md
+0
-0
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/RaftNodeBootStrap.java
...src/main/java/top/ninwoo/satellite/RaftNodeBootStrap.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/clusterService/ClusterMembershipChanges.java
...oo/satellite/clusterService/ClusterMembershipChanges.java
+3
-2
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/clusterService/Result.java
...main/java/top/ninwoo/satellite/clusterService/Result.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/clusterService/Server.java
...main/java/top/ninwoo/satellite/clusterService/Server.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/clusterService/impl/ClusterMembershipChangesImpl.java
...ite/clusterService/impl/ClusterMembershipChangesImpl.java
+9
-9
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/current/RaftThread.java
...rc/main/java/top/ninwoo/satellite/current/RaftThread.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/current/RaftThreadPool.java
...ain/java/top/ninwoo/satellite/current/RaftThreadPool.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/current/RaftThreadPoolExecutor.java
.../top/ninwoo/satellite/current/RaftThreadPoolExecutor.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/current/SleepHelper.java
...c/main/java/top/ninwoo/satellite/current/SleepHelper.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/entity/AentryParam.java
...rc/main/java/top/ninwoo/satellite/entity/AentryParam.java
+3
-2
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/entity/AentryResult.java
...c/main/java/top/ninwoo/satellite/entity/AentryResult.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/entity/BaseParam.java
.../src/main/java/top/ninwoo/satellite/entity/BaseParam.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/entity/Command.java
...te/src/main/java/top/ninwoo/satellite/entity/Command.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/entity/LogEntry.java
...e/src/main/java/top/ninwoo/satellite/entity/LogEntry.java
+3
-2
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/entity/ReplicationFailModel.java
...ava/top/ninwoo/satellite/entity/ReplicationFailModel.java
+2
-2
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/entity/RvoteParam.java
...src/main/java/top/ninwoo/satellite/entity/RvoteParam.java
+2
-2
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/entity/RvoteResult.java
...rc/main/java/top/ninwoo/satellite/entity/RvoteResult.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/exception/RaftNotSupportException.java
...p/ninwoo/satellite/exception/RaftNotSupportException.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/exception/RaftRemotingException.java
...top/ninwoo/satellite/exception/RaftRemotingException.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/nodeCommon/NodeConfig.java
...main/java/top/ninwoo/satellite/nodeCommon/NodeConfig.java
+19
-0
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/nodeCommon/NodeStatus.java
...main/java/top/ninwoo/satellite/nodeCommon/NodeStatus.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/nodeCommon/Peer.java
...e/src/main/java/top/ninwoo/satellite/nodeCommon/Peer.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/nodeCommon/PeerSet.java
...rc/main/java/top/ninwoo/satellite/nodeCommon/PeerSet.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/register/MyApplicationRunner.java
...va/top/ninwoo/satellite/register/MyApplicationRunner.java
+6
-6
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/rpc/RaftUserProcessor.java
...main/java/top/ninwoo/satellite/rpc/RaftUserProcessor.java
+2
-2
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/rpc/Request.java
...llite/src/main/java/top/ninwoo/satellite/rpc/Request.java
+4
-4
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/rpc/Response.java
...lite/src/main/java/top/ninwoo/satellite/rpc/Response.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/rpc/RpcClient.java
...ite/src/main/java/top/ninwoo/satellite/rpc/RpcClient.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/rpc/RpcServer.java
...ite/src/main/java/top/ninwoo/satellite/rpc/RpcServer.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/rpc/impl/DefaultRpcClient.java
.../java/top/ninwoo/satellite/rpc/impl/DefaultRpcClient.java
+5
-5
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/rpc/impl/DefaultRpcServer.java
.../java/top/ninwoo/satellite/rpc/impl/DefaultRpcServer.java
+11
-11
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/service/IPService.java
...src/main/java/top/ninwoo/satellite/service/IPService.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/service/impl/IPServiceImpl.java
...java/top/ninwoo/satellite/service/impl/IPServiceImpl.java
+15
-3
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/util/Consensus.java
...te/src/main/java/top/ninwoo/satellite/util/Consensus.java
+6
-5
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/util/LifeCycle.java
...te/src/main/java/top/ninwoo/satellite/util/LifeCycle.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/util/LogModule.java
...te/src/main/java/top/ninwoo/satellite/util/LogModule.java
+3
-3
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/util/LongConvert.java
.../src/main/java/top/ninwoo/satellite/util/LongConvert.java
+1
-1
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/util/Node.java
...tellite/src/main/java/top/ninwoo/satellite/util/Node.java
+10
-6
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/util/StateMachine.java
...src/main/java/top/ninwoo/satellite/util/StateMachine.java
+3
-2
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/util/impl/DefaultConsensus.java
...java/top/ninwoo/satellite/util/impl/DefaultConsensus.java
+5
-7
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/util/impl/DefaultLogModule.java
...java/top/ninwoo/satellite/util/impl/DefaultLogModule.java
+3
-7
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/util/impl/DefaultNode.java
...main/java/top/ninwoo/satellite/util/impl/DefaultNode.java
+27
-25
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/util/impl/DefaultStateMachine.java
...a/top/ninwoo/satellite/util/impl/DefaultStateMachine.java
+4
-7
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/util/mqttUtils/MqttClientCallback.java
...p/ninwoo/satellite/util/mqttUtils/MqttClientCallback.java
+68
-0
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/util/mqttUtils/MyMqttClient.java
...ava/top/ninwoo/satellite/util/mqttUtils/MyMqttClient.java
+301
-0
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/util/mqttUtils/PublishThread.java
...va/top/ninwoo/satellite/util/mqttUtils/PublishThread.java
+37
-0
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/resources/application.properties
...-node-satellite/src/main/resources/application.properties
+0
-0
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/resources/log4j.xml
...onnection/css-node-satellite/src/main/resources/log4j.xml
+0
-0
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/test/java/top/ninwoo/satellite/impl/DefaultLogModuleTest.java
.../java/top/ninwoo/satellite/impl/DefaultLogModuleTest.java
+4
-4
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/test/java/top/ninwoo/satellite/impl/DefaultStateMachineTest.java
...va/top/ninwoo/satellite/impl/DefaultStateMachineTest.java
+4
-4
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/test/java/top/ninwoo/satellite/impl/RocksDBTest.java
.../src/test/java/top/ninwoo/satellite/impl/RocksDBTest.java
+1
-8
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/test/java/top/ninwoo/satellite/rpc/RpcClientTest.java
...src/test/java/top/ninwoo/satellite/rpc/RpcClientTest.java
+1
-3
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/test/java/top/ninwoo/satellite/rpc/RpcServerTest.java
...src/test/java/top/ninwoo/satellite/rpc/RpcServerTest.java
+1
-4
apps/cnf-spaceiot-shortConnection/pom.xml
apps/cnf-spaceiot-shortConnection/pom.xml
+48
-9
No files found.
apps/cnf-space-iot/space-iot-mqtt/src/main/java/com/jbxie/spaceiotmqtt/service/ipService.java
deleted
100644 → 0
View file @
a0ca07ec
package
com.jbxie.spaceiotmqtt.service
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Service
;
import
top.ninwoo.bishe.starter.service.NetworkService
;
import
top.ninwoo.common.entity.DockerContainer
;
import
top.ninwoo.utils.util.DockerUtils
;
import
top.ninwoo.utils.util.LinuxCtlUtils
;
import
java.util.List
;
@Service
class
IPService
{
@Autowired
private
NetworkService
networkService
;
@Autowired
(
required
=
false
)
private
LinuxCtlUtils
linuxCtlUtils
;
@Autowired
(
required
=
false
)
private
DockerUtils
dockerUtils
;
public
String
getDockerId
()
{
String
cmd
=
"head -1 /proc/self/cgroup|cut -d/ -f3|cut -c1-12"
;
String
res
=
linuxCtlUtils
.
runCmd
(
cmd
);
if
(
res
==
null
)
{
throw
new
RuntimeException
(
"get Docker Id Error"
);
}
return
res
;
}
public
String
getSelfDockerIpById
(
Long
clusterId
)
{
String
id
=
getDockerId
();
DockerContainer
dockerContainer
=
dockerUtils
.
getDockerById
(
id
);
return
getIpByAppName
(
clusterId
,
dockerContainer
.
getName
());
}
public
String
getIpByAppName
(
Long
clusterId
,
String
appName
)
{
List
<
String
>
ipList
=
networkService
.
getIpListByAppName
(
clusterId
,
appName
);
if
(!
ipList
.
isEmpty
()){
String
ip_tmp
=
ipList
.
get
(
0
);
String
[]
split_list
=
ip_tmp
.
split
(
"/"
);
return
split_list
[
0
]
+
":8775"
;
}
return
null
;
}
public
String
[]
getIpList
(
Long
clusterId
,
String
[]
wxName_list
)
{
int
n
=
wxName_list
.
length
;
String
[]
ipList
=
new
String
[
n
];
for
(
int
k
=
0
;
k
<
wxName_list
.
length
;
k
++){
ipList
[
k
]
=
getIpByAppName
(
clusterId
,
wxName_list
[
k
]);
//通过卫星名字获取卫星ip
}
return
ipList
;
}
}
apps/cnf-spaceiot-longConnection/csl-common-api/pom.xml
0 → 100644
View file @
29112de4
<?xml version="1.0" encoding="UTF-8"?>
<project
xmlns=
"http://maven.apache.org/POM/4.0.0"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation=
"http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
>
<parent>
<artifactId>
cnf-spaceiot-longConnection
</artifactId>
<groupId>
top.ninwoo
</groupId>
<version>
1.0-SNAPSHOT
</version>
</parent>
<modelVersion>
4.0.0
</modelVersion>
<artifactId>
csl-common-api
</artifactId>
<dependencies>
<dependency>
<groupId>
org.projectlombok
</groupId>
<artifactId>
lombok
</artifactId>
<scope>
provided
</scope>
</dependency>
</dependencies>
</project>
\ No newline at end of file
apps/cnf-spaceiot-longConnection/csl-common-api/src/main/java/top/ninwoo/common/entity/DataPackage.java
0 → 100644
View file @
29112de4
package
top.ninwoo.common.entity
;
import
lombok.Data
;
import
java.io.Serializable
;
@Data
public
class
DataPackage
implements
Serializable
{
private
String
key
;
private
String
value
;
private
String
subNode
;
// 订阅节点(消息订阅点固定北京,groung3)
private
String
pubNode
;
// 发布节点
private
String
[][]
route
;
// 路由列表
private
int
totalHops
;
// 总跳数
private
int
remainingHops
;
// 剩余跳数
private
String
nextHop
;
// 下一跳
}
apps/cnf-spaceiot-longConnection/csl-node-ground/pom.xml
0 → 100644
View file @
29112de4
<?xml version="1.0" encoding="UTF-8"?>
<project
xmlns=
"http://maven.apache.org/POM/4.0.0"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation=
"http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
>
<parent>
<artifactId>
cnf-spaceiot-longConnection
</artifactId>
<groupId>
top.ninwoo
</groupId>
<version>
1.0-SNAPSHOT
</version>
</parent>
<modelVersion>
4.0.0
</modelVersion>
<artifactId>
csl-node-ground
</artifactId>
<dependencies>
<dependency>
<groupId>
org.python
</groupId>
<artifactId>
jython-standalone
</artifactId>
<version>
2.7.2
</version>
</dependency>
<dependency>
<groupId>
top.ninwoo
</groupId>
<artifactId>
csl-common-api
</artifactId>
<version>
1.0-SNAPSHOT
</version>
<scope>
compile
</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-maven-plugin
</artifactId>
<version>
${springboot.version}
</version>
<configuration>
<mainClass>
top.ninwoo.ground.GroundMain
</mainClass>
</configuration>
<executions>
<execution>
<goals>
<goal>
repackage
</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>
\ No newline at end of file
apps/cnf-spaceiot-longConnection/csl-node-ground/src/main/java/top/ninwoo/ground/GroundMain.java
0 → 100644
View file @
29112de4
package
top.ninwoo.ground
;
import
org.springframework.boot.SpringApplication
;
import
org.springframework.boot.autoconfigure.SpringBootApplication
;
@SpringBootApplication
public
class
GroundMain
{
public
static
void
main
(
String
[]
args
)
{
SpringApplication
.
run
(
GroundMain
.
class
,
args
);
}
}
apps/cnf-spaceiot-longConnection/csl-node-ground/src/main/java/top/ninwoo/ground/register/MyApplicationRunner.java
0 → 100644
View file @
29112de4
package
top.ninwoo.ground.register
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.boot.ApplicationArguments
;
import
org.springframework.boot.ApplicationRunner
;
import
org.springframework.stereotype.Component
;
import
top.ninwoo.common.entity.DataPackage
;
import
top.ninwoo.ground.service.GroundService
;
import
top.ninwoo.ground.service.IPService
;
import
javax.xml.crypto.Data
;
import
java.io.*
;
import
java.net.ServerSocket
;
import
java.net.Socket
;
import
java.util.List
;
@Component
public
class
MyApplicationRunner
implements
ApplicationRunner
{
private
static
final
Logger
logger
=
LoggerFactory
.
getLogger
(
MyApplicationRunner
.
class
);
private
static
final
String
fileName
=
"route_path.txt"
;
//生成的路由保存文件
private
static
final
String
timeSlot
=
"35"
;
//时隙,可修改
private
static
final
String
sourceNode
=
"ground3"
;
private
static
final
String
destinationNode
=
"groung14"
;
@Autowired
GroundService
groundService
;
@Autowired
IPService
ipService
;
@Autowired
DataPackage
dataPackage
;
/*================================订阅节点的run函数=============================================*/
@Override
public
void
run
(
ApplicationArguments
args
)
throws
Exception
{
logger
.
info
(
"BeiJing Node Initiate a request"
);
dataPackage
.
setKey
(
"temperature"
);
dataPackage
.
setSubNode
(
sourceNode
);
dataPackage
.
setPubNode
(
destinationNode
);
groundService
.
execPy
(
timeSlot
,
sourceNode
,
destinationNode
);
String
nextHop
=
groundService
.
readFileContent
(
fileName
);
String
nextIp
=
ipService
.
getIpByAppName
(
nextHop
);
send
(
dataPackage
,
nextIp
,
2021
);
// 接收回传信息
ServerSocket
serverSocket
=
new
ServerSocket
(
8900
);
//获取数据流
Socket
accept
=
serverSocket
.
accept
();
InputStream
inputStream
=
accept
.
getInputStream
();
//读取数据流
ObjectInputStream
objectInputStream
=
new
ObjectInputStream
(
new
BufferedInputStream
(
inputStream
));
Object
object
=
null
;
try
{
object
=
objectInputStream
.
readObject
();
DataPackage
receiveData
=
(
DataPackage
)
object
;
//输出数据流
logger
.
info
(
"BeiJing Node Receive Data"
);
logger
.
info
(
receiveData
.
getKey
()
+
":"
+
receiveData
.
getValue
());
}
catch
(
ClassNotFoundException
e
)
{
e
.
printStackTrace
();
}
serverSocket
.
close
();
accept
.
close
();
System
.
out
.
println
();
}
/*================================其他节点的run函数=============================================*/
// @Override
// public void run(ApplicationArguments args) throws Exception {
// ServerSocket serverSocket = null;
// InputStream inputStream = null;
// ObjectInputStream objectInputStream = null;
// try {
// serverSocket = new ServerSocket(2021);
// while (true) {
// Socket client = serverSocket.accept();
// inputStream = client.getInputStream();
// objectInputStream = new ObjectInputStream(new BufferedInputStream(inputStream));
// Object object = objectInputStream.readObject();
// DataPackage dataPackage = (DataPackage) object;
//
// // 获取当前节点剩余跳数,若为0,则当前节点为目的节点;若不为0,则当前节点为进行转发的地面节点
// int remainingHops = dataPackage.getRemainingHops() - 1;
// if (remainingHops == 0) {
// logger.info("到达消息拥有节点,获取消息然后发送至消息订阅节点");
// dataPackage.setValue(String.valueOf(groundService.getRandom()));
// groundService.execPy(timeSlot, destinationNode, sourceNode);
// String nextHop = groundService.readFileContent(fileName);
// String nextIp = ipService.getIpByAppName(nextHop);
//
// send(dataPackage, nextIp, 2021);
// continue;
// } else {
// logger.info("中间地面节点,转发至下一节点");
// dataPackage.setRemainingHops(remainingHops);
// String[][] route = dataPackage.getRoute();
// String nextHop = route[0][dataPackage.getTotalHops() - remainingHops + 1];
// String nextIp = ipService.getIpByAppName(nextHop);
// send(dataPackage, nextIp, 2021);
// continue;
// }
// }
// } catch (IOException | ClassNotFoundException e) {
// e.printStackTrace();
// } finally {
// try {
// if (objectInputStream != null) {
// objectInputStream.close();
// }
// if (inputStream != null) {
// inputStream.close();
// }
// if (serverSocket != null) {
// serverSocket.close();
// }
// } catch (IOException e) {
// e.printStackTrace();
// }
// }
// }
/**
* 发送数据包到下一节点
* @param dataPackage
* @param ip
* @param port
*/
private
static
void
send
(
DataPackage
dataPackage
,
String
ip
,
int
port
)
{
Socket
socket
=
null
;
try
{
socket
=
new
Socket
(
ip
,
port
);
ObjectOutputStream
objectOutputStream
=
new
ObjectOutputStream
(
socket
.
getOutputStream
());
objectOutputStream
.
writeObject
(
dataPackage
);
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
}
finally
{
try
{
if
(
socket
!=
null
)
{
socket
.
close
();
}
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
}
}
}
}
apps/cnf-spaceiot-longConnection/csl-node-ground/src/main/java/top/ninwoo/ground/service/GroundService.java
0 → 100644
View file @
29112de4
package
top.ninwoo.ground.service
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
top.ninwoo.common.entity.DataPackage
;
import
java.io.*
;
import
java.util.ArrayList
;
import
java.util.Random
;
public
class
GroundService
{
private
static
final
Logger
logger
=
LoggerFactory
.
getLogger
(
GroundService
.
class
);
private
static
final
String
pyFilePath
=
"E:\\xjb\\xjb.py"
;
//如果未指定.py文件的完全路径,则默认从工程当前目录下搜索
private
static
final
String
pyAllPath
=
"E:\\xjb"
;
//注意:当命令行参数分开写的时候,exec后面不用添加一个空格。当命令行参数一起写的时候,exe后面一定要添加一个空格
private
static
final
String
pyRoutePath
=
"E:\\xjb"
;
private
static
Process
proc
=
null
;
//java进程类
@Autowired
DataPackage
dataPackage
;
@Autowired
GroundService
groundService
;
/**
* 执行*.py文件
*/
public
void
execPy
(
String
timeSlot
,
String
sourceNode
,
String
destinationNode
)
{
String
[]
arguments
=
new
String
[]
{
"py"
,
pyFilePath
,
pyAllPath
,
pyRoutePath
,
timeSlot
,
sourceNode
,
destinationNode
};
try
{
proc
=
Runtime
.
getRuntime
().
exec
(
arguments
);
BufferedReader
in
=
new
BufferedReader
(
new
InputStreamReader
(
proc
.
getInputStream
()));
String
line
=
null
;
while
((
line
=
in
.
readLine
())
!=
null
)
{
System
.
out
.
println
(
line
);
}
in
.
close
();
int
re
=
proc
.
waitFor
();
//返回0:成功。其余返回值均表示失败,如:返回错误代码1:操作不允许,表示调用python脚本失败
System
.
out
.
println
(
re
);
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
}
catch
(
InterruptedException
e
)
{
e
.
printStackTrace
();
}
}
/**
* 读取route_path.txt生成路由表,返回下一跳节点
* @param fileName
*/
public
String
readFileContent
(
String
fileName
)
throws
IOException
{
/**
* 文件读入
*/
String
filePath
=
pyRoutePath
+
"\\"
+
fileName
;
// File file = new file(filePath);
FileReader
in
=
null
;
try
{
in
=
new
FileReader
(
filePath
);
}
catch
(
FileNotFoundException
e
)
{
logger
.
error
(
"File doesn't exsit!"
);
return
null
;
}
/**
* 使用BufferedReader读入并保存
*/
BufferedReader
br
=
new
BufferedReader
(
in
);
ArrayList
<
String
>
list
=
new
ArrayList
<
String
>();
String
s
=
null
;
while
(
true
)
{
try
{
s
=
br
.
readLine
();
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
}
list
.
add
(
s
);
if
(
s
==
null
)
break
;
}
/**
* 创建矩阵,将数据写入二维数组
*/
int
colLength
;
//列数
int
rowLength
;
//行数
rowLength
=
list
.
size
()
-
1
;
colLength
=
list
.
get
(
0
).
split
(
" "
).
length
;
String
[][]
square
=
new
String
[
rowLength
][
colLength
];
//幻方
for
(
int
i
=
0
;
i
<
rowLength
;
i
++)
{
String
[]
linex
=
list
.
get
(
i
).
split
(
" "
);
for
(
int
j
=
0
;
j
<
colLength
;
j
++)
{
square
[
i
][
j
]
=
linex
[
j
];
}
}
br
.
close
();
dataPackage
.
setRoute
(
square
);
dataPackage
.
setRemainingHops
(
Integer
.
valueOf
(
square
[
3
][
0
]));
dataPackage
.
setTotalHops
(
Integer
.
valueOf
(
square
[
3
][
0
]));
return
square
[
0
][
1
];
}
/**
* 得到0.5到1的随机数
* @return
*/
public
int
getRandom
(){
// 0<= random and random < n
Random
ran
=
new
Random
();
int
random
=
ran
.
nextInt
(
40
);
return
random
;
}
public
static
void
Print
(
int
colLength
,
int
rowLength
,
String
[][]
square
)
{
for
(
int
i
=
0
;
i
<
rowLength
;
i
++)
{
if
(
i
>
0
)
System
.
out
.
print
(
"\n"
);
for
(
int
j
=
0
;
j
<
colLength
;
j
++)
{
System
.
out
.
print
(
square
[
i
][
j
]
+
"\t"
);
}
}
System
.
out
.
println
(
Integer
.
valueOf
(
square
[
3
][
0
]));
}
public
static
void
main
(
String
[]
args
)
throws
IOException
{
// execPy();
// readFileContent("route_path.txt");
}
}
apps/cnf-space
-iot/space-iot-mqtt/src/main/java/com/jbxie/spaceiotmqtt
/service/IPService.java
→
apps/cnf-space
iot-longConnection/csl-node-ground/src/main/java/top/ninwoo/ground
/service/IPService.java
View file @
29112de4
package
com.jbxie.spaceiotmqtt
.service
;
package
top.ninwoo.ground
.service
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Service
;
...
...
@@ -8,17 +8,17 @@ import java.util.List;
@Service
public
class
IPService
{
@Autowired
private
NetworkService
networkService
;
public
String
getIpByAppName
(
String
appName
)
{
List
<
String
>
ipList
=
networkService
.
getIpListByAppName
(
1111
1
l
,
appName
);
if
(!
ipList
.
isEmpty
())
{
List
<
String
>
ipList
=
networkService
.
getIpListByAppName
(
1111
3
l
,
appName
);
if
(!
ipList
.
isEmpty
())
{
String
ip_tmp
=
ipList
.
get
(
0
);
String
[]
split_list
=
ip_tmp
.
split
(
"/"
);
return
split_list
[
0
];
}
return
null
;
}
}
apps/cnf-spaceiot-longConnection/csl-node-ground/test.py
0 → 100644
View file @
29112de4
from
__future__
import
print_function
from
sklearn
import
datasets
from
sklearn.linear_model
import
LinearRegression
import
matplotlib.pyplot
as
plt
X
,
y
=
datasets
.
make_regression
(
n_samples
=
100
,
n_features
=
1
,
n_targets
=
1
,
noise
=
10
)
plt
.
scatter
(
X
,
y
)
plt
.
show
()
\ No newline at end of file
apps/cnf-spaceiot-longConnection/csl-node-satellite/pom.xml
0 → 100644
View file @
29112de4
<?xml version="1.0" encoding="UTF-8"?>
<project
xmlns=
"http://maven.apache.org/POM/4.0.0"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation=
"http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
>
<parent>
<artifactId>
cnf-spaceiot-longConnection
</artifactId>
<groupId>
top.ninwoo
</groupId>
<version>
1.0-SNAPSHOT
</version>
</parent>
<modelVersion>
4.0.0
</modelVersion>
<artifactId>
csl-node-satellite
</artifactId>
<dependencies>
<dependency>
<groupId>
top.ninwoo
</groupId>
<artifactId>
csl-common-api
</artifactId>
<version>
1.0-SNAPSHOT
</version>
<scope>
compile
</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-maven-plugin
</artifactId>
<version>
${springboot.version}
</version>
<configuration>
<mainClass>
top.ninwoo.satellite.SatelliteMain
</mainClass>
</configuration>
<executions>
<execution>
<goals>
<goal>
repackage
</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>
\ No newline at end of file
apps/cnf-spaceiot-longConnection/csl-node-satellite/src/main/java/top/ninwoo/satellite/SatelliteMain.java
0 → 100644
View file @
29112de4
package
top.ninwoo.satellite
;
import
org.springframework.boot.SpringApplication
;
import
org.springframework.boot.autoconfigure.SpringBootApplication
;
@SpringBootApplication
public
class
SatelliteMain
{
public
static
void
main
(
String
[]
args
)
{
SpringApplication
.
run
(
SatelliteMain
.
class
,
args
);
}
}
apps/cnf-spaceiot-longConnection/csl-node-satellite/src/main/java/top/ninwoo/satellite/register/MyApplicationRunner.java
0 → 100644
View file @
29112de4
package
top.ninwoo.satellite.register
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.boot.ApplicationArguments
;
import
org.springframework.boot.ApplicationRunner
;
import
org.springframework.stereotype.Component
;
import
top.ninwoo.common.entity.DataPackage
;
import
top.ninwoo.satellite.service.IPService
;
import
java.io.*
;
import
java.net.ServerSocket
;
import
java.net.Socket
;
@Component
public
class
MyApplicationRunner
implements
ApplicationRunner
{
private
static
final
Logger
logger
=
LoggerFactory
.
getLogger
(
MyApplicationRunner
.
class
);
@Autowired
IPService
ipService
;
@Autowired
DataPackage
dataPackage
;
/**
* Callback used to run the bean.
*
* @param args incoming application arguments
* @throws Exception on error
*/
@Override
public
void
run
(
ApplicationArguments
args
)
throws
Exception
{
ServerSocket
serverSocket
=
null
;
InputStream
inputStream
=
null
;
ObjectInputStream
objectInputStream
=
null
;
try
{
serverSocket
=
new
ServerSocket
(
2021
);
while
(
true
)
{
Socket
client
=
serverSocket
.
accept
();
inputStream
=
client
.
getInputStream
();
objectInputStream
=
new
ObjectInputStream
(
new
BufferedInputStream
(
inputStream
));
Object
object
=
objectInputStream
.
readObject
();
DataPackage
dataPackage
=
(
DataPackage
)
object
;
//卫星节点转发数据
logger
.
info
(
"中间卫星节点,转发至下一节点"
);
int
remainingHops
=
dataPackage
.
getRemainingHops
()
-
1
;
dataPackage
.
setRemainingHops
(
remainingHops
);
String
[][]
route
=
dataPackage
.
getRoute
();
String
nextHop
=
route
[
0
][
dataPackage
.
getTotalHops
()
-
remainingHops
+
1
];
String
nextIp
=
ipService
.
getIpByAppName
(
nextHop
);
send
(
dataPackage
,
nextIp
,
2021
);
continue
;
}
}
catch
(
IOException
|
ClassNotFoundException
e
)
{
e
.
printStackTrace
();
}
finally
{
try
{
if
(
objectInputStream
!=
null
)
{
objectInputStream
.
close
();
}
if
(
inputStream
!=
null
)
{
inputStream
.
close
();
}
if
(
serverSocket
!=
null
)
{
serverSocket
.
close
();
}
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
}
}
}
/**
* 发送数据包到下一节点
* @param dataPackage
* @param ip
* @param port
*/
private
static
void
send
(
DataPackage
dataPackage
,
String
ip
,
int
port
)
{
Socket
socket
=
null
;
try
{
socket
=
new
Socket
(
ip
,
port
);
ObjectOutputStream
objectOutputStream
=
new
ObjectOutputStream
(
socket
.
getOutputStream
());
objectOutputStream
.
writeObject
(
dataPackage
);
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
}
finally
{
try
{
if
(
socket
!=
null
)
{
socket
.
close
();
}
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
}
}
}
}
apps/cnf-spaceiot-longConnection/csl-node-satellite/src/main/java/top/ninwoo/satellite/service/IPService.java
0 → 100644
View file @
29112de4
package
top.ninwoo.satellite.service
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Service
;
import
top.ninwoo.bishe.starter.service.NetworkService
;
import
java.util.List
;
@Service
public
class
IPService
{
@Autowired
private
NetworkService
networkService
;
public
String
getIpByAppName
(
String
appName
)
{
List
<
String
>
ipList
=
networkService
.
getIpListByAppName
(
11113
l
,
appName
);
if
(!
ipList
.
isEmpty
()){
String
ip_tmp
=
ipList
.
get
(
0
);
String
[]
split_list
=
ip_tmp
.
split
(
"/"
);
return
split_list
[
0
];
}
return
null
;
}
}
\ No newline at end of file
apps/cnf-spaceiot-longConnection/pom.xml
0 → 100644
View file @
29112de4
<?xml version="1.0" encoding="UTF-8"?>
<project
xmlns=
"http://maven.apache.org/POM/4.0.0"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation=
"http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
>
<parent>
<artifactId>
cnf
</artifactId>
<groupId>
top.ninwoo
</groupId>
<version>
1.0-SNAPSHOT
</version>
<relativePath>
../../pom.xml
</relativePath>
</parent>
<modelVersion>
4.0.0
</modelVersion>
<artifactId>
cnf-spaceiot-longConnection
</artifactId>
<packaging>
pom
</packaging>
<modules>
<module>
csl-node-satellite
</module>
<module>
csl-node-ground
</module>
<module>
csl-common-api
</module>
</modules>
<dependencies>
<dependency>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-starter-web
</artifactId>
</dependency>
<dependency>
<groupId>
top.ninwoo
</groupId>
<artifactId>
cnf-client-starter
</artifactId>
</dependency>
<dependency>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-starter-test
</artifactId>
<scope>
test
</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-maven-plugin
</artifactId>
<version>
${springboot.version}
</version>
</plugin>
<plugin>
<groupId>
org.apache.maven.plugins
</groupId>
<artifactId>
maven-compiler-plugin
</artifactId>
<!-- <version>3.7.0</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>-->
</plugin>
</plugins>
</build>
</project>
\ No newline at end of file
apps/cnf-space
-iot/space-
iot-mqtt/pom.xml
→
apps/cnf-spaceiot-mqtt/pom.xml
View file @
29112de4
...
...
@@ -3,13 +3,14 @@
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation=
"http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
>
<parent>
<artifactId>
cnf
-space-iot
</artifactId>
<artifactId>
cnf
</artifactId>
<groupId>
top.ninwoo
</groupId>
<version>
1.0-SNAPSHOT
</version>
<relativePath>
../../pom.xml
</relativePath>
</parent>
<modelVersion>
4.0.0
</modelVersion>
<artifactId>
space-
iot-mqtt
</artifactId>
<artifactId>
cnf-space
iot-mqtt
</artifactId>
<dependencies>
<dependency>
...
...
@@ -73,5 +74,4 @@
</plugin>
</plugins>
</build>
</project>
\ No newline at end of file
apps/cnf-space
-iot/space-iot-mqtt/src/main/java/com/jbxie/spaceiot
mqtt/IotMqttMain.java
→
apps/cnf-space
iot-mqtt/src/main/java/top/ninwoo/
mqtt/IotMqttMain.java
View file @
29112de4
package
com.jbxie.spaceiot
mqtt
;
package
top.ninwoo.
mqtt
;
import
com.jbxie.spaceiotmqtt.mqttUtils.MyMqttClient
;
import
org.springframework.boot.SpringApplication
;
import
org.springframework.boot.autoconfigure.SpringBootApplication
;
import
top.ninwoo.mqtt.mqttUtils.MyMqttClient
;
@SpringBootApplication
public
class
IotMqttMain
{
public
static
void
main
(
String
[]
args
)
{
String
broker
=
"tcp://192.168.
31.198
:1883"
;
public
static
void
main
(
String
[]
args
)
throws
InterruptedException
{
String
broker
=
"tcp://192.168.
43.129
:1883"
;
// MyMqttClient mqttClient_sub = new MyMqttClient();
// MyMqttClient mqttClient_pub = new MyMqttClient();
//
...
...
@@ -21,6 +21,10 @@ public class IotMqttMain {
mqttClient
.
createClient
(
broker
);
mqttClient
.
subTopic
(
"world/test1"
,
1
);
mqttClient
.
pubMessage
(
1
,
"world/test1"
,
"hello:test_1"
);
Thread
.
currentThread
().
sleep
(
100
);
System
.
out
.
println
(
mqttClient
.
payload
);
//System.out.println(mqttClient.subTopic("world/test1", 1));
SpringApplication
.
run
(
IotMqttMain
.
class
,
args
);
}
}
}
\ No newline at end of file
apps/cnf-space
-iot/space-iot-mqtt/src/main/java/com/jbxie/spaceiot
mqtt/controller/MqttController.java
→
apps/cnf-space
iot-mqtt/src/main/java/top/ninwoo/
mqtt/controller/MqttController.java
View file @
29112de4
package
com.jbxie.spaceiot
mqtt.controller
;
package
top.ninwoo.
mqtt.controller
;
import
com.jbxie.spaceiotmqtt.mqttUtils.MyMqttClient
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.web.bind.annotation.GetMapping
;
import
org.springframework.web.bind.annotation.PathVariable
;
import
org.springframework.web.bind.annotation.RequestMapping
;
import
org.springframework.web.bind.annotation.RestController
;
import
top.ninwoo.mqtt.mqttUtils.MyMqttClient
;
import
java.util.Random
;
...
...
@@ -67,6 +67,4 @@ public class MqttController {
myMqttClient
.
pubMessage
(
topics
[
new
Random
().
nextInt
(
5
)],
"测试消息发送"
);
return
"发送成功吗!!!!!!!!"
;
}
}
apps/cnf-space
-iot/space-iot-mqtt/src/main/java/com/jbxie/spaceiot
mqtt/mqttUtils/MqttClientCallback.java
→
apps/cnf-space
iot-mqtt/src/main/java/top/ninwoo/
mqtt/mqttUtils/MqttClientCallback.java
View file @
29112de4
package
com.jbxie.spaceiot
mqtt.mqttUtils
;
package
top.ninwoo.
mqtt.mqttUtils
;
import
com.alibaba.fastjson.JSONObject
;
import
lombok.extern.slf4j.Slf4j
;
...
...
@@ -8,6 +8,7 @@ import org.eclipse.paho.client.mqttv3.MqttException;
import
org.eclipse.paho.client.mqttv3.MqttMessage
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Component
;
import
java.io.UnsupportedEncodingException
;
...
...
@@ -31,12 +32,14 @@ import java.util.Date;
* 由 MqttClient.connect 激活此回调。
*
*/
@Slf4j
@Component
public
class
MqttClientCallback
implements
MqttCallback
{
private
static
final
Logger
logger
=
LoggerFactory
.
getLogger
(
MqttClientCallback
.
class
);
@Autowired
MyMqttClient
myMqttClient
;
@Override
public
void
connectionLost
(
Throwable
arg0
)
{
//logger.info("连接断开,可以做重连");
...
...
@@ -57,6 +60,7 @@ public class MqttClientCallback implements MqttCallback {
// logger.info("接收消息Qos : " + mqttMessage.getQos());
// logger.info("接收消息内容 : " + new String(mqttMessage.getPayload()));
String
messages
=
new
String
(
mqttMessage
.
getPayload
());
myMqttClient
.
payload
=
messages
;
if
(!
messages
.
equals
(
"close"
)){
System
.
out
.
println
(
"{"
);
System
.
out
.
println
(
"接收消息主题 : "
+
topic
);
...
...
@@ -65,14 +69,8 @@ public class MqttClientCallback implements MqttCallback {
System
.
out
.
println
(
"}"
);
SimpleDateFormat
df
=
new
SimpleDateFormat
(
"yyyy-MM-dd HH:mm:ss"
);
//设置日期格式
logger
.
info
(
"接收时间========"
+
df
.
format
(
new
Date
())
+
" "
+
System
.
currentTimeMillis
());
// try {
// perform(topic,json);
// }catch (Exception e){
// }
}
// if (MyMqttClient.executorService != null) {
// MyMqttClient.executorService.execute(new HandlerThread(topic, content));
// }
}
public
void
perform
(
String
topicP
,
JSONObject
json
)
throws
MqttException
,
UnsupportedEncodingException
{
...
...
apps/cnf-space
-iot/space-iot-mqtt/src/main/java/com/jbxie/spaceiot
mqtt/mqttUtils/MyMqttClient.java
→
apps/cnf-space
iot-mqtt/src/main/java/top/ninwoo/
mqtt/mqttUtils/MyMqttClient.java
View file @
29112de4
package
com.jbxie.spaceiot
mqtt.mqttUtils
;
package
top.ninwoo.
mqtt.mqttUtils
;
import
org.eclipse.paho.client.mqttv3.*
;
import
org.eclipse.paho.client.mqttv3.persist.MemoryPersistence
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Component
;
import
java.text.SimpleDateFormat
;
...
...
@@ -33,6 +32,7 @@ public class MyMqttClient {
private
static
LinkedBlockingQueue
<
String
[]>
queue
=
new
LinkedBlockingQueue
<
String
[]>();
public
static
ExecutorService
executorService
=
Executors
.
newFixedThreadPool
(
2
*
Runtime
.
getRuntime
().
availableProcessors
()
+
1
);
public
static
String
payload
;
/**
* mqtt broker 连接配置,填自己的mqtt地址,及账号密码
*/
...
...
@@ -58,9 +58,10 @@ public class MyMqttClient {
System
.
out
.
println
(
"create mqtt clientConnection"
);
try
{
mqttConnectOptions
=
new
MqttConnectOptions
();
mqttConnectOptions
.
setCleanSession
(
tru
e
);
//true可以安全地使用内存持久性作为客户端断开连接时清除的所有状态
mqttConnectOptions
.
setCleanSession
(
fals
e
);
//true可以安全地使用内存持久性作为客户端断开连接时清除的所有状态
mqttConnectOptions
.
setMaxInflight
(
100000
);
mqttConnectOptions
.
setConnectionTimeout
(
30
);
//设置连接超时,单位为秒
//mqttConnectOptions.setKeepAliveInterval(20); //保持连接数,设置会话心跳时间 单位为秒 服务器会每隔1.5*20秒的时间向客户端发送个消息判断客户端是否在线,但这个方法并没有重连的机制
if
(
username
!=
null
&&
!
""
.
equals
(
username
))
{
mqttConnectOptions
.
setUserName
(
username
);
...
...
@@ -137,7 +138,7 @@ public class MyMqttClient {
/**
* 订阅主题
*/
public
static
void
subTopic
(
String
topic
,
int
qos
)
{
public
static
String
subTopic
(
String
topic
,
int
qos
)
{
if
(
mqttClient
!=
null
&&
mqttClient
.
isConnected
())
{
try
{
mqttConnectOptions
.
setWill
(
topic
,
"close"
.
getBytes
(),
2
,
true
);
...
...
@@ -145,7 +146,10 @@ public class MyMqttClient {
SimpleDateFormat
df
=
new
SimpleDateFormat
(
"yyyy-MM-dd HH:mm:ss"
);
//设置日期格式
logger
.
info
(
"订阅时间========"
+
df
.
format
(
new
Date
())
+
" "
+
System
.
currentTimeMillis
());
mqttClient
.
subscribe
(
topic
,
qos
);
mqttClient
.
setCallback
(
mqttClientCallback
);
//mqttClient.setCallback(mqttClientCallback);
// MqttMessage mqttMessage = new MqttMessage();
// String messages = new String(mqttMessage.getPayload());
// return messages;
//logger.info("订阅成功");
}
catch
(
MqttException
me
)
{
me
.
printStackTrace
();
...
...
@@ -153,6 +157,7 @@ public class MyMqttClient {
}
else
{
System
.
out
.
println
(
"mqttClient is Error"
);
}
return
null
;
}
/**
* 订阅主题
...
...
@@ -228,7 +233,7 @@ public class MyMqttClient {
}
MqttDeliveryToken
token
;
SimpleDateFormat
df
=
new
SimpleDateFormat
(
"yyyy-MM-dd HH:mm:ss"
);
//设置日期格式
logger
.
info
(
"发送时间========"
+
df
.
format
(
new
Date
()));
logger
.
info
(
"发送时间========"
+
df
.
format
(
new
Date
())
+
" "
+
System
.
currentTimeMillis
()
);
logger
.
info
(
"clientId: "
+
mqttClient
.
getClientId
()
+
"发送主题:"
+
topic
+
"成功,内容:"
+
message
);
try
{
token
=
topic
.
publish
(
mqttMessage
);
...
...
@@ -288,3 +293,4 @@ public class MyMqttClient {
return
(
String
[])
queue
.
poll
();
}
}
apps/cnf-space
-iot/space-iot-mqtt/src/main/java/com/jbxie/spaceiot
mqtt/mqttUtils/PublishThread.java
→
apps/cnf-space
iot-mqtt/src/main/java/top/ninwoo/
mqtt/mqttUtils/PublishThread.java
View file @
29112de4
package
com.jbxie.spaceiot
mqtt.mqttUtils
;
package
top.ninwoo.
mqtt.mqttUtils
;
import
org.eclipse.paho.client.mqttv3.MqttException
;
import
org.springframework.stereotype.Component
;
import
static
com
.
jbxie
.
spaceiotmqtt
.
mqttUtils
.
MyMqttClient
.*
;
import
static
top
.
ninwoo
.
mqtt
.
mqttUtils
.
MyMqttClient
.
poll
;
@Component
public
class
PublishThread
implements
Runnable
{
...
...
apps/cnf-spaceiot-shortConnection/css-common-api/pom.xml
0 → 100644
View file @
29112de4
<?xml version="1.0" encoding="UTF-8"?>
<project
xmlns=
"http://maven.apache.org/POM/4.0.0"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation=
"http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
>
<parent>
<artifactId>
cnf-spaceiot-shortConnection
</artifactId>
<groupId>
top.ninwoo
</groupId>
<version>
1.0-SNAPSHOT
</version>
</parent>
<modelVersion>
4.0.0
</modelVersion>
<artifactId>
css-common-api
</artifactId>
<dependencies>
<dependency>
<groupId>
org.projectlombok
</groupId>
<artifactId>
lombok
</artifactId>
<scope>
provided
</scope>
</dependency>
</dependencies>
</project>
\ No newline at end of file
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft/client
/ClientKVAck.java
→
apps/cnf-space
iot-shortConnection/css-common-api/src/main/java/top/ninwoo/common/entity
/ClientKVAck.java
View file @
29112de4
package
top.
jbxie.raft.client
;
package
top.
ninwoo.common.entity
;
import
lombok.Data
;
...
...
@@ -10,7 +10,7 @@ import java.io.Serializable;
@Data
public
class
ClientKVAck
implements
Serializable
{
Object
result
;
// logEntry.getCommand();
public
Object
result
;
// logEntry.getCommand();
public
ClientKVAck
(
Object
result
)
{
this
.
result
=
result
;
...
...
@@ -49,4 +49,4 @@ public class ClientKVAck implements Serializable {
}
}
}
\ No newline at end of file
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft/client
/ClientKVReq.java
→
apps/cnf-space
iot-shortConnection/css-common-api/src/main/java/top/ninwoo/common/entity
/ClientKVReq.java
View file @
29112de4
package
top.
jbxie.raft.client
;
package
top.
ninwoo.common.entity
;
import
lombok.Data
;
...
...
@@ -15,9 +15,9 @@ public class ClientKVReq implements Serializable {
int
type
;
String
key
;
public
String
key
;
String
value
;
public
String
value
;
private
ClientKVReq
(
Builder
builder
)
{
setType
(
builder
.
type
);
...
...
@@ -77,3 +77,4 @@ public class ClientKVReq implements Serializable {
}
}
}
apps/cnf-space
-iot/space-iot-flooding
/pom.xml
→
apps/cnf-space
iot-shortConnection/css-node-ground
/pom.xml
View file @
29112de4
...
...
@@ -3,32 +3,25 @@
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation=
"http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
>
<parent>
<artifactId>
cnf-space
-iot
</artifactId>
<artifactId>
cnf-space
iot-shortConnection
</artifactId>
<groupId>
top.ninwoo
</groupId>
<version>
1.0-SNAPSHOT
</version>
</parent>
<modelVersion>
4.0.0
</modelVersion>
<artifactId>
space-iot-flooding
</artifactId>
<artifactId>
css-node-ground
</artifactId>
<dependencies>
<dependency>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-starter-web
</artifactId>
</dependency>
<dependency>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-starter
</artifactId>
</dependency>
<dependency>
<groupId>
top.ninwoo
</groupId>
<artifactId>
cnf-client-starter
</artifactId>
<artifactId>
css-common-api
</artifactId>
<version>
1.0-SNAPSHOT
</version>
</dependency>
<dependency>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-starter-test
</artifactId>
<
scope>
test
</scope
>
<groupId>
top.ninwoo
</groupId>
<artifactId>
css-node-satellite
</artifactId>
<
version>
1.0-SNAPSHOT
</version
>
</dependency>
</dependencies>
...
...
@@ -38,6 +31,9 @@
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-maven-plugin
</artifactId>
<version>
${springboot.version}
</version>
<configuration>
<mainClass>
top.ninwoo.ground.GroundMain
</mainClass>
</configuration>
<executions>
<execution>
<goals>
...
...
apps/cnf-spaceiot-shortConnection/css-node-ground/src/main/java/top/ninwoo/ground/GroundMain.java
0 → 100644
View file @
29112de4
package
top.ninwoo.ground
;
import
org.springframework.boot.SpringApplication
;
import
org.springframework.boot.autoconfigure.SpringBootApplication
;
@SpringBootApplication
public
class
GroundMain
{
public
static
void
main
(
String
[]
args
)
{
SpringApplication
.
run
(
GroundMain
.
class
,
args
);
}
}
apps/cnf-spaceiot-shortConnection/css-node-ground/src/main/java/top/ninwoo/ground/register/RaftClient.java
0 → 100644
View file @
29112de4
//package top.ninwoo.ground.register;
//
//import com.alipay.remoting.exception.RemotingException;
//import com.google.common.collect.Lists;
//import org.slf4j.Logger;
//import org.slf4j.LoggerFactory;
//import top.ninwoo.common.entity.ClientKVReq;
//import top.ninwoo.satellite.current.SleepHelper;
//import top.ninwoo.satellite.entity.LogEntry;
//import top.ninwoo.satellite.rpc.Request;
//import top.ninwoo.satellite.rpc.Response;
//import top.ninwoo.satellite.rpc.RpcClient;
//import top.ninwoo.satellite.rpc.impl.DefaultRpcClient;
//
//import java.util.List;
//import java.util.concurrent.atomic.AtomicLong;
//
//public class RaftClient {
// private static final Logger LOGGER = LoggerFactory.getLogger(RaftClient.class);
//
// private final static RpcClient client = new DefaultRpcClient();
//
// static String addr = "localhost:8775";
// static List<String> list = Lists.newArrayList("localhost:8775","localhost:8776","localhost:8777", "localhost:8778", "localhost:8779");
//
// public static void main(String[] args) throws RemotingException, InterruptedException {
//
// AtomicLong count = new AtomicLong(5);
//
// for (int i = 3; ; i++) {
// try {
// int index = (int) (count.incrementAndGet() % list.size());
// addr = list.get(index);
//
// ClientKVReq obj = ClientKVReq.newBuilder().key("hello:" + i).value("world:" + i).type(ClientKVReq.PUT).build();
//
// Request<ClientKVReq> r = new Request<>();
// r.setObj(obj);
// r.setUrl(addr);
// r.setCmd(Request.CLIENT_REQ);
// Response<String> response;
// try {
// response = client.send(r);
// } catch (Exception e) {
// r.setUrl(list.get((int) ((count.incrementAndGet()) % list.size())));
// response = client.send(r);
// }
//
// LOGGER.info("request content : {}, url : {}, put response : {}", obj.key + "=" + obj.getValue(), r.getUrl(), response.getResult());
//
// SleepHelper.sleep(1000);
//
// obj = ClientKVReq.newBuilder().key("hello:" + i).type(ClientKVReq.GET).build();
//
// addr = list.get(index);
// r.setUrl(addr);
// r.setObj(obj);
//
// Response<LogEntry> response2;
// try {
// response2 = client.send(r);
// } catch (Exception e) {
// r.setUrl(list.get((int) ((count.incrementAndGet()) % list.size())));
// response2 = client.send(r);
// }
//
// LOGGER.info("request content : {}, url : {}, get response : {}", obj.key + "=" + obj.getValue(), r.getUrl(), response2.getResult());
// } catch (Exception e) {
// e.printStackTrace();
// i = i - 1;
// }
//
// SleepHelper.sleep(5000);
// }
//
// }
//}
apps/cnf-spaceiot-shortConnection/css-node-ground/src/main/java/top/ninwoo/ground/register/RaftClient2.java
0 → 100644
View file @
29112de4
//package top.ninwoo.ground.register;
//
//import com.google.common.collect.Lists;
//import org.slf4j.Logger;
//import org.slf4j.LoggerFactory;
//import top.ninwoo.common.entity.ClientKVReq;
//import top.ninwoo.satellite.entity.LogEntry;
//import top.ninwoo.satellite.rpc.Request;
//import top.ninwoo.satellite.rpc.Response;
//import top.ninwoo.satellite.rpc.RpcClient;
//import top.ninwoo.satellite.rpc.impl.DefaultRpcClient;
//
//import java.util.List;
//
//public class RaftClient2 {
// private static final Logger LOGGER = LoggerFactory.getLogger(RaftClient2.class);
//
//
// private final static RpcClient client = new DefaultRpcClient();
//
// static String addr = "localhost:8778";
// static List<String> list3 = Lists.newArrayList("localhost:8777", "localhost:8778", "localhost:8779");
// static List<String> list2 = Lists.newArrayList( "localhost:8777", "localhost:8779");
// static List<String> list1 = Lists.newArrayList( "localhost:8779");
//
// public static void main(String[] args) throws InterruptedException {
// for (int i = 3; ; i++) {
//
// try {
// Request<ClientKVReq> r = new Request<>();
//
// int size = list2.size();
//
// ClientKVReq obj = ClientKVReq.newBuilder().key("hello:" + i).type(ClientKVReq.GET).build();
// int index = (i) % size;
// addr = list2.get(index);
// r.setUrl(addr);
// r.setObj(obj);
// r.setCmd(Request.CLIENT_REQ);
//
// Response<LogEntry> response2 = client.send(r);
//
// LOGGER.info("request content : {}, url : {}, get response : {}", obj.key + "=" + obj.getValue(), r.getUrl(), response2.getResult());
// } catch (Exception e) {
// e.printStackTrace();
// } finally {
// Thread.sleep(1000);
//
// }
//
// }
// }
//}
\ No newline at end of file
apps/cnf-spaceiot-shortConnection/css-node-ground/src/main/java/top/ninwoo/ground/register/RaftClient3.java
0 → 100644
View file @
29112de4
//package top.ninwoo.ground.register;
//
//import com.alipay.remoting.exception.RemotingException;
//import com.google.common.collect.Lists;
//import org.slf4j.Logger;
//import org.slf4j.LoggerFactory;
//import top.ninwoo.common.entity.ClientKVReq;
//import top.ninwoo.satellite.current.SleepHelper;
//import top.ninwoo.satellite.entity.LogEntry;
//import top.ninwoo.satellite.rpc.Request;
//import top.ninwoo.satellite.rpc.Response;
//import top.ninwoo.satellite.rpc.RpcClient;
//import top.ninwoo.satellite.rpc.impl.DefaultRpcClient;
//
//import java.util.List;
//import java.util.concurrent.atomic.AtomicLong;
//
//public class RaftClient3 {
// private static final Logger LOGGER = LoggerFactory.getLogger(RaftClient3.class);
//
//
// private final static RpcClient client = new DefaultRpcClient();
//
// static String addr = "localhost:8777";
// static List<String> list = Lists.newArrayList("localhost:8777", "localhost:8778", "localhost:8779");
//
// public static void main(String[] args) throws RemotingException, InterruptedException {
//
// AtomicLong count = new AtomicLong(3);
//
// int keyNum = 4;
// try {
// int index = (int) (count.incrementAndGet() % list.size());
// index = 1;
// addr = list.get(index);
//
// ClientKVReq obj = ClientKVReq.newBuilder().key("hello:" + keyNum).value("world:" + keyNum).type(ClientKVReq.PUT).build();
//
// Request<ClientKVReq> r = new Request<>();
// r.setObj(obj);
// r.setUrl(addr);
// r.setCmd(Request.CLIENT_REQ);
// Response<String> response = null;
// try {
// response = client.send(r);
// } catch (Exception e) {
// }
//
// LOGGER.info("request content : {}, url : {}, put response : {}", obj.key + "=" + obj.getValue(), r.getUrl(), response.getResult());
//
// SleepHelper.sleep(1000);
//
// obj = ClientKVReq.newBuilder().key("hello:" + keyNum).type(ClientKVReq.GET).build();
//
// addr = list.get(index);
// addr = list.get(index);
// r.setUrl(addr);
// r.setObj(obj);
//
// Response<LogEntry> response2;
// try {
// response2 = client.send(r);
// } catch (Exception e) {
// r.setUrl(list.get((int) ((count.incrementAndGet()) % list.size())));
// response2 = client.send(r);
// }
//
// if (response.getResult() == null) {
// LOGGER.error("request content : {}, url : {}, get response : {}", obj.key + "=" + obj.getValue(), r.getUrl(), response2.getResult());
// System.exit(1);
// return;
// }
// LOGGER.info("request content : {}, url : {}, get response : {}", obj.key + "=" + obj.getValue(), r.getUrl(), response2.getResult());
// } catch (Exception e) {
// e.printStackTrace();
// }
//
// System.exit(1);
//
// }
//}
apps/cnf-space
-iot/space-iot-raft
/Dockerfile
→
apps/cnf-space
iot-shortConnection/css-node-satellite
/Dockerfile
View file @
29112de4
File moved
apps/cnf-spaceiot-shortConnection/css-node-satellite/pom.xml
0 → 100644
View file @
29112de4
<?xml version="1.0" encoding="UTF-8"?>
<project
xmlns=
"http://maven.apache.org/POM/4.0.0"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation=
"http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
>
<parent>
<artifactId>
cnf-spaceiot-shortConnection
</artifactId>
<groupId>
top.ninwoo
</groupId>
<version>
1.0-SNAPSHOT
</version>
</parent>
<modelVersion>
4.0.0
</modelVersion>
<artifactId>
css-node-satellite
</artifactId>
<dependencies>
<dependency>
<groupId>
top.ninwoo
</groupId>
<artifactId>
css-common-api
</artifactId>
<version>
1.0-SNAPSHOT
</version>
<scope>
compile
</scope>
</dependency>
<!--mqtt-->
<dependency>
<groupId>
org.springframework.integration
</groupId>
<artifactId>
spring-integration-stream
</artifactId>
<version>
5.3.2.RELEASE
</version>
</dependency>
<dependency>
<groupId>
org.springframework.integration
</groupId>
<artifactId>
spring-integration-mqtt
</artifactId>
<version>
5.3.2.RELEASE
</version>
</dependency>
<dependency>
<groupId>
com.fasterxml.jackson.core
</groupId>
<artifactId>
jackson-databind
</artifactId>
<version>
2.11.0
</version>
</dependency>
<dependency>
<groupId>
org.eclipse.paho
</groupId>
<artifactId>
org.eclipse.paho.client.mqttv3
</artifactId>
<version>
1.2.0
</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-maven-plugin
</artifactId>
<version>
${springboot.version}
</version>
<configuration>
<mainClass>
top.ninwoo.satellite.RaftNodeBootStrap
</mainClass>
</configuration>
<executions>
<execution>
<goals>
<goal>
repackage
</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>
\ No newline at end of file
apps/cnf-space
-iot/space-iot-raft
/readme.md
→
apps/cnf-space
iot-shortConnection/css-node-satellite
/readme.md
View file @
29112de4
File moved
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/RaftNodeBootStrap.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/RaftNodeBootStrap.java
View file @
29112de4
package
top.
jbxie.raft
;
package
top.
ninwoo.satellite
;
import
org.springframework.boot.SpringApplication
;
import
org.springframework.boot.autoconfigure.SpringBootApplication
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/clusterService/ClusterMembershipChanges.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/clusterService/ClusterMembershipChanges.java
View file @
29112de4
package
top.
jbxie.raft
.clusterService
;
package
top.
ninwoo.satellite
.clusterService
;
import
top.jbxie.raft.nodeCommon.Peer
;
import
top.ninwoo.satellite.nodeCommon.Peer
;
/**
* 集群配置变更接口.
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/clusterService/Result.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/clusterService/Result.java
View file @
29112de4
package
top.
jbxie.raft
.clusterService
;
package
top.
ninwoo.satellite
.clusterService
;
import
lombok.Getter
;
import
lombok.Setter
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/clusterService/Server.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/clusterService/Server.java
View file @
29112de4
package
top.
jbxie.raft
.clusterService
;
package
top.
ninwoo.satellite
.clusterService
;
import
lombok.Getter
;
import
lombok.Setter
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/clusterService/impl/ClusterMembershipChangesImpl.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/clusterService/impl/ClusterMembershipChangesImpl.java
View file @
29112de4
package
top.
jbxie.raft
.clusterService.impl
;
package
top.
ninwoo.satellite
.clusterService.impl
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
top.
jbxie.raft
.clusterService.ClusterMembershipChanges
;
import
top.
jbxie.raft
.clusterService.Result
;
import
top.
jbxie.raft
.entity.LogEntry
;
import
top.
jbxie.raft
.nodeCommon.NodeStatus
;
import
top.
jbxie.raft
.nodeCommon.Peer
;
import
top.
jbxie.raft
.rpc.Request
;
import
top.
jbxie.raft
.rpc.Response
;
import
top.
jbxie.raft
.util.impl.DefaultNode
;
import
top.
ninwoo.satellite
.clusterService.ClusterMembershipChanges
;
import
top.
ninwoo.satellite
.clusterService.Result
;
import
top.
ninwoo.satellite
.entity.LogEntry
;
import
top.
ninwoo.satellite
.nodeCommon.NodeStatus
;
import
top.
ninwoo.satellite
.nodeCommon.Peer
;
import
top.
ninwoo.satellite
.rpc.Request
;
import
top.
ninwoo.satellite
.rpc.Response
;
import
top.
ninwoo.satellite
.util.impl.DefaultNode
;
/**
* 集群配置变更接口默认实现.
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/current/RaftThread.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/current/RaftThread.java
View file @
29112de4
package
top.
jbxie.raft
.current
;
package
top.
ninwoo.satellite
.current
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/current/RaftThreadPool.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/current/RaftThreadPool.java
View file @
29112de4
package
top.
jbxie.raft
.current
;
package
top.
ninwoo.satellite
.current
;
import
java.util.concurrent.*
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/current/RaftThreadPoolExecutor.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/current/RaftThreadPoolExecutor.java
View file @
29112de4
package
top.
jbxie.raft
.current
;
package
top.
ninwoo.satellite
.current
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/current/SleepHelper.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/current/SleepHelper.java
View file @
29112de4
package
top.
jbxie.raft
.current
;
package
top.
ninwoo.satellite
.current
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/entity/AentryParam.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/entity/AentryParam.java
View file @
29112de4
package
top.
jbxie.raft
.entity
;
package
top.
ninwoo.satellite
.entity
;
import
lombok.Getter
;
import
lombok.Setter
;
import
top.jbxie.raft.util.Consensus
;
import
top.ninwoo.satellite.util.Consensus
;
import
java.util.Arrays
;
/**
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/entity/AentryResult.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/entity/AentryResult.java
View file @
29112de4
package
top.
jbxie.raft
.entity
;
package
top.
ninwoo.satellite
.entity
;
import
lombok.Data
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/entity/BaseParam.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/entity/BaseParam.java
View file @
29112de4
package
top.
jbxie.raft
.entity
;
package
top.
ninwoo.satellite
.entity
;
import
lombok.Data
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/entity/Command.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/entity/Command.java
View file @
29112de4
package
top.
jbxie.raft
.entity
;
package
top.
ninwoo.satellite
.entity
;
import
lombok.Getter
;
import
lombok.Setter
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/entity/LogEntry.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/entity/LogEntry.java
View file @
29112de4
package
top.
jbxie.raft
.entity
;
package
top.
ninwoo.satellite
.entity
;
import
lombok.Getter
;
import
lombok.Setter
;
import
top.ninwoo.satellite.util.LogModule
;
import
java.io.Serializable
;
import
java.util.Objects
;
import
top.jbxie.raft.util.LogModule
;
/**
* 日志条目
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/entity/ReplicationFailModel.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/entity/ReplicationFailModel.java
View file @
29112de4
package
top.
jbxie.raft
.entity
;
package
top.
ninwoo.satellite
.entity
;
import
top.
jbxie.raft
.nodeCommon.Peer
;
import
top.
ninwoo.satellite
.nodeCommon.Peer
;
import
java.util.concurrent.Callable
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/entity/RvoteParam.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/entity/RvoteParam.java
View file @
29112de4
package
top.
jbxie.raft
.entity
;
package
top.
ninwoo.satellite
.entity
;
import
top.jbxie.raft.util.Consensus
;
import
lombok.Getter
;
import
lombok.Setter
;
import
top.ninwoo.satellite.util.Consensus
;
/**
* 请求投票RPC参数(候选人).
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/entity/RvoteResult.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/entity/RvoteResult.java
View file @
29112de4
package
top.
jbxie.raft
.entity
;
package
top.
ninwoo.satellite
.entity
;
import
lombok.Data
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/exception/RaftNotSupportException.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/exception/RaftNotSupportException.java
View file @
29112de4
package
top.
jbxie.raft
.exception
;
package
top.
ninwoo.satellite
.exception
;
public
class
RaftNotSupportException
extends
RuntimeException
{
public
RaftNotSupportException
()
{
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/exception/RaftRemotingException.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/exception/RaftRemotingException.java
View file @
29112de4
package
top.
jbxie.raft
.exception
;
package
top.
ninwoo.satellite
.exception
;
public
class
RaftRemotingException
extends
RuntimeException
{
public
RaftRemotingException
()
{
...
...
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/nodeCommon/NodeConfig.java
0 → 100644
View file @
29112de4
package
top.ninwoo.satellite.nodeCommon
;
import
lombok.Data
;
import
java.util.List
;
/**
* 节点配置
*/
@Data
public
class
NodeConfig
{
// 自身节点地址
public
String
selfAddr
;
//所有节点地址
public
List
<
String
>
peerAddrs
;
}
\ No newline at end of file
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/nodeCommon/NodeStatus.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/nodeCommon/NodeStatus.java
View file @
29112de4
package
top.
jbxie.raft
.nodeCommon
;
package
top.
ninwoo.satellite
.nodeCommon
;
import
lombok.Getter
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/nodeCommon/Peer.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/nodeCommon/Peer.java
View file @
29112de4
package
top.
jbxie.raft
.nodeCommon
;
package
top.
ninwoo.satellite
.nodeCommon
;
import
lombok.Getter
;
import
lombok.Setter
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/nodeCommon/PeerSet.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/nodeCommon/PeerSet.java
View file @
29112de4
package
top.
jbxie.raft
.nodeCommon
;
package
top.
ninwoo.satellite
.nodeCommon
;
import
java.io.Serializable
;
import
java.util.ArrayList
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/register/MyApplicationRunner.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/register/MyApplicationRunner.java
View file @
29112de4
package
top.
jbxie.raft
.register
;
package
top.
ninwoo.satellite
.register
;
import
lombok.SneakyThrows
;
import
org.springframework.boot.ApplicationArguments
;
import
org.springframework.boot.ApplicationRunner
;
import
org.springframework.stereotype.Component
;
import
top.
jbxie.raft
.nodeCommon.NodeConfig
;
import
top.
jbxie.raft
.service.impl.IPServiceImpl
;
import
top.
jbxie.raft
.util.Node
;
import
top.
jbxie.raft
.util.impl.DefaultNode
;
import
top.
ninwoo.satellite
.nodeCommon.NodeConfig
;
import
top.
ninwoo.satellite
.service.impl.IPServiceImpl
;
import
top.
ninwoo.satellite
.util.Node
;
import
top.
ninwoo.satellite
.util.impl.DefaultNode
;
import
java.util.Arrays
;
...
...
@@ -51,7 +51,7 @@ public class MyApplicationRunner implements ApplicationRunner {
Thread
.
currentThread
().
sleep
(
20000
);
// 自身节点地址
config
.
setSelfAddr
(
ipServiceImpl
.
getSelfIp
());
config
.
setSelfAddr
(
ipServiceImpl
.
getSelfIp
()
+
":8775"
);
// 所有节点地址
// Long clusterId = 11113l;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/rpc/RaftUserProcessor.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/rpc/RaftUserProcessor.java
View file @
29112de4
package
top.
jbxie.raft
.rpc
;
package
top.
ninwoo.satellite
.rpc
;
import
com.alipay.remoting.AsyncContext
;
import
com.alipay.remoting.BizContext
;
import
com.alipay.remoting.rpc.protocol.AbstractUserProcessor
;
import
top.
jbxie.raft
.exception.RaftNotSupportException
;
import
top.
ninwoo.satellite
.exception.RaftNotSupportException
;
public
abstract
class
RaftUserProcessor
<
T
>
extends
AbstractUserProcessor
<
T
>
{
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/rpc/Request.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/rpc/Request.java
View file @
29112de4
package
top.
jbxie.raft
.rpc
;
package
top.
ninwoo.satellite
.rpc
;
import
lombok.Data
;
import
top.
jbxie.raft.client.ClientKVReq
;
import
top.
jbxie.raft.entity.Aentry
Param
;
import
top.
jbxie.raft.entity.RvoteParam
;
import
top.
ninwoo.satellite.entity.AentryParam
;
import
top.
ninwoo.satellite.entity.Rvote
Param
;
import
top.
ninwoo.common.entity.ClientKVReq
;
import
java.io.Serializable
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/rpc/Response.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/rpc/Response.java
View file @
29112de4
package
top.
jbxie.raft
.rpc
;
package
top.
ninwoo.satellite
.rpc
;
import
lombok.Getter
;
import
lombok.Setter
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/rpc/RpcClient.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/rpc/RpcClient.java
View file @
29112de4
package
top.
jbxie.raft
.rpc
;
package
top.
ninwoo.satellite
.rpc
;
public
interface
RpcClient
{
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/rpc/RpcServer.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/rpc/RpcServer.java
View file @
29112de4
package
top.
jbxie.raft
.rpc
;
package
top.
ninwoo.satellite
.rpc
;
public
interface
RpcServer
{
void
start
();
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/rpc/impl/DefaultRpcClient.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/rpc/impl/DefaultRpcClient.java
View file @
29112de4
package
top.
jbxie.raft
.rpc.impl
;
package
top.
ninwoo.satellite
.rpc.impl
;
import
com.alipay.remoting.exception.RemotingException
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
top.
jbxie.raft
.exception.RaftRemotingException
;
import
top.
jbxie.raft
.rpc.Request
;
import
top.
jbxie.raft
.rpc.Response
;
import
top.
jbxie.raft
.rpc.RpcClient
;
import
top.
ninwoo.satellite
.exception.RaftRemotingException
;
import
top.
ninwoo.satellite
.rpc.Request
;
import
top.
ninwoo.satellite
.rpc.Response
;
import
top.
ninwoo.satellite
.rpc.RpcClient
;
public
class
DefaultRpcClient
implements
RpcClient
{
public
static
Logger
logger
=
LoggerFactory
.
getLogger
(
DefaultRpcClient
.
class
.
getName
());
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/rpc/impl/DefaultRpcServer.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/rpc/impl/DefaultRpcServer.java
View file @
29112de4
package
top.
jbxie.raft
.rpc.impl
;
package
top.
ninwoo.satellite
.rpc.impl
;
import
com.alipay.remoting.BizContext
;
import
top.
jbxie.raft.client
.ClientKVReq
;
import
top.
jbxie.raft
.clusterService.ClusterMembershipChanges
;
import
top.
jbxie.raft
.entity.AentryParam
;
import
top.
jbxie.raft
.entity.RvoteParam
;
import
top.
jbxie.raft
.nodeCommon.Peer
;
import
top.
jbxie.raft
.rpc.RaftUserProcessor
;
import
top.
jbxie.raft
.rpc.Request
;
import
top.
jbxie.raft
.rpc.Response
;
import
top.
jbxie.raft
.rpc.RpcServer
;
import
top.
jbxie.raft
.util.impl.DefaultNode
;
import
top.
ninwoo.common.entity
.ClientKVReq
;
import
top.
ninwoo.satellite
.clusterService.ClusterMembershipChanges
;
import
top.
ninwoo.satellite
.entity.AentryParam
;
import
top.
ninwoo.satellite
.entity.RvoteParam
;
import
top.
ninwoo.satellite
.nodeCommon.Peer
;
import
top.
ninwoo.satellite
.rpc.RaftUserProcessor
;
import
top.
ninwoo.satellite
.rpc.Request
;
import
top.
ninwoo.satellite
.rpc.Response
;
import
top.
ninwoo.satellite
.rpc.RpcServer
;
import
top.
ninwoo.satellite
.util.impl.DefaultNode
;
public
class
DefaultRpcServer
implements
RpcServer
{
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/service/IPService.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/service/IPService.java
View file @
29112de4
package
top.
jbxie.raft
.service
;
package
top.
ninwoo.satellite
.service
;
import
java.net.UnknownHostException
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/service/impl/IPServiceImpl.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/service/impl/IPServiceImpl.java
View file @
29112de4
package
top.
jbxie.raft
.service.impl
;
package
top.
ninwoo.satellite
.service.impl
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Service
;
import
top.jbxie.raft.service.IPService
;
import
top.ninwoo.bishe.starter.service.NetworkService
;
import
top.ninwoo.satellite.service.IPService
;
import
java.net.Inet4Address
;
import
java.net.InetAddress
;
import
java.net.UnknownHostException
;
...
...
@@ -18,7 +19,7 @@ public class IPServiceImpl implements IPService {
@Override
public
String
getSelfIp
()
throws
UnknownHostException
{
InetAddress
addr
=
Inet4Address
.
getLocalHost
();
return
addr
.
getHostAddress
()
+
":8775"
;
return
addr
.
getHostAddress
();
}
@Override
...
...
@@ -36,4 +37,15 @@ public class IPServiceImpl implements IPService {
return
ipList
;
}
// @Autowired(required=false)
// private LinuxCtlUtils linuxCtlUtils;
//
// public String getDockerId() {
// String cmd = "head -1 /proc/self/cgroup|cut -d/ -f3|cut -c1-12";
// String res = linuxCtlUtils.runCmd(cmd);
// if(res == null) {
// throw new RuntimeException("get Docker Id Error");
// }
// return res;
// }
}
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/util/Consensus.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/util/Consensus.java
View file @
29112de4
package
top.
jbxie.raft
.util
;
package
top.
ninwoo.satellite
.util
;
import
top.jbxie.raft.entity.AentryParam
;
import
top.jbxie.raft.entity.AentryResult
;
import
top.jbxie.raft.entity.RvoteParam
;
import
top.jbxie.raft.entity.RvoteResult
;
import
top.ninwoo.satellite.entity.AentryParam
;
import
top.ninwoo.satellite.entity.AentryResult
;
import
top.ninwoo.satellite.entity.RvoteParam
;
import
top.ninwoo.satellite.entity.RvoteResult
;
/**
* raft一致性模块
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/util/LifeCycle.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/util/LifeCycle.java
View file @
29112de4
package
top.
jbxie.raft
.util
;
package
top.
ninwoo.satellite
.util
;
public
interface
LifeCycle
{
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/util/LogModule.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/util/LogModule.java
View file @
29112de4
package
top.
jbxie.raft
.util
;
package
top.
ninwoo.satellite
.util
;
import
top.
jbxie.raft
.entity.LogEntry
;
import
top.
ninwoo.satellite
.entity.LogEntry
;
/**
* @see
top.jbxie.raft.entity.LogEntry
;
* @see
LogEntry
;
*/
public
interface
LogModule
{
void
write
(
LogEntry
logEntry
);
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/util/LongConvert.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/util/LongConvert.java
View file @
29112de4
package
top.
jbxie.raft
.util
;
package
top.
ninwoo.satellite
.util
;
public
class
LongConvert
{
public
static
long
convert
(
Long
l
)
{
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/util/Node.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/util/Node.java
View file @
29112de4
package
top.
jbxie.raft
.util
;
package
top.
ninwoo.satellite
.util
;
import
top.jbxie.raft.client.ClientKVAck
;
import
top.jbxie.raft.client.ClientKVReq
;
import
top.jbxie.raft.entity.*
;
import
top.jbxie.raft.nodeCommon.NodeConfig
;
import
org.eclipse.paho.client.mqttv3.MqttException
;
import
top.ninwoo.common.entity.ClientKVAck
;
import
top.ninwoo.common.entity.ClientKVReq
;
import
top.ninwoo.satellite.entity.AentryParam
;
import
top.ninwoo.satellite.entity.AentryResult
;
import
top.ninwoo.satellite.entity.RvoteParam
;
import
top.ninwoo.satellite.entity.RvoteResult
;
import
top.ninwoo.satellite.nodeCommon.NodeConfig
;
/**
* 节点功能
...
...
@@ -14,7 +18,7 @@ public interface Node<T> extends LifeCycle {
* 设置配置文件.
* @param config
*/
void
setConfig
(
NodeConfig
config
);
void
setConfig
(
NodeConfig
config
)
throws
MqttException
;
/**
* 处理请求投票 RPC.
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/util/StateMachine.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/util/StateMachine.java
View file @
29112de4
package
top.
jbxie.raft
.util
;
package
top.
ninwoo.satellite
.util
;
import
top.jbxie.raft.entity.LogEntry
;
import
top.ninwoo.satellite.entity.LogEntry
;
/**
* 状态机接口
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/util/impl/DefaultConsensus.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/util/impl/DefaultConsensus.java
View file @
29112de4
package
top.
jbxie.raft
.util.impl
;
package
top.
ninwoo.satellite
.util.impl
;
import
io.netty.util.internal.StringUtil
;
import
lombok.Data
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
org.springframework.http.server.ServerHttpRequest
;
import
top.jbxie.raft.clusterService.Server
;
import
top.jbxie.raft.entity.*
;
import
top.jbxie.raft.nodeCommon.NodeStatus
;
import
top.jbxie.raft.nodeCommon.Peer
;
import
top.jbxie.raft.util.Consensus
;
import
top.ninwoo.satellite.entity.*
;
import
top.ninwoo.satellite.nodeCommon.NodeStatus
;
import
top.ninwoo.satellite.nodeCommon.Peer
;
import
top.ninwoo.satellite.util.Consensus
;
import
java.util.concurrent.locks.ReentrantLock
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/util/impl/DefaultLogModule.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/util/impl/DefaultLogModule.java
View file @
29112de4
package
top.
jbxie.raft
.util.impl
;
package
top.
ninwoo.satellite
.util.impl
;
import
com.alibaba.fastjson.JSON
;
import
lombok.Getter
;
import
lombok.Setter
;
import
org.rocksdb.Options
;
...
...
@@ -9,11 +8,8 @@ import org.rocksdb.RocksDB;
import
org.rocksdb.RocksDBException
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.core.env.Environment
;
import
top.jbxie.raft.entity.LogEntry
;
import
top.jbxie.raft.nodeCommon.NodeConfig
;
import
top.jbxie.raft.util.LogModule
;
import
top.ninwoo.satellite.entity.LogEntry
;
import
top.ninwoo.satellite.util.LogModule
;
import
java.io.File
;
import
java.util.concurrent.locks.ReentrantLock
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/util/impl/DefaultNode.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/util/impl/DefaultNode.java
View file @
29112de4
package
top.
jbxie.raft
.util.impl
;
package
top.
ninwoo.satellite
.util.impl
;
import
lombok.Data
;
import
lombok.Getter
;
import
lombok.Setter
;
import
org.eclipse.paho.client.mqttv3.MqttException
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
top.
jbxie.raft.client
.ClientKVAck
;
import
top.
jbxie.raft.client
.ClientKVReq
;
import
top.
jbxie.raft
.clusterService.ClusterMembershipChanges
;
import
top.
jbxie.raft
.clusterService.Result
;
import
top.
jbxie.raft.clusterService.impl.ClusterMembershipChangesImp
l
;
import
top.
jbxie.raft.current.RaftThreadPool
;
import
top.
jbxie.raft.entity.*
;
import
top.
jbxie.raft.exception.RaftRemotingException
;
import
top.
jbxie.raft.nodeCommon.NodeConfig
;
import
top.
jbxie.raft.nodeCommon.NodeStatus
;
import
top.
jbxie.raft.nodeCommon.Peer
;
import
top.
jbxie.raft.nodeCommon.PeerSe
t
;
import
top.
jbxie.raft.rpc.Request
;
import
top.
jbxie.raft.rpc.Response
;
import
top.
jbxie.raft.rpc.RpcClient
;
import
top.
jbxie.raft.rpc.RpcServer
;
import
top.
jbxie.raft.rpc.impl.DefaultRpcClient
;
import
top.
jbxie.raft.rpc.impl.DefaultRpcServer
;
import
top.
jbxie.raft
.util.*
;
import
top.
ninwoo.common.entity
.ClientKVAck
;
import
top.
ninwoo.common.entity
.ClientKVReq
;
import
top.
ninwoo.satellite
.clusterService.ClusterMembershipChanges
;
import
top.
ninwoo.satellite
.clusterService.Result
;
import
top.
ninwoo.satellite.current.RaftThreadPoo
l
;
import
top.
ninwoo.satellite.entity.*
;
import
top.
ninwoo.satellite.exception.RaftRemotingException
;
import
top.
ninwoo.satellite.nodeCommon.NodeConfig
;
import
top.
ninwoo.satellite.nodeCommon.NodeStatus
;
import
top.
ninwoo.satellite.nodeCommon.Peer
;
import
top.
ninwoo.satellite.nodeCommon.PeerSet
;
import
top.
ninwoo.satellite.rpc.Reques
t
;
import
top.
ninwoo.satellite.rpc.Response
;
import
top.
ninwoo.satellite.rpc.RpcClient
;
import
top.
ninwoo.satellite.rpc.RpcServer
;
import
top.
ninwoo.satellite.rpc.impl.DefaultRpcClient
;
import
top.
ninwoo.satellite.rpc.impl.DefaultRpcServer
;
import
top.
ninwoo.satellite.util.mqttUtils.MyMqttClient
;
import
top.
ninwoo.satellite
.util.*
;
import
java.util.*
;
import
java.util.concurrent.*
;
import
java.util.concurrent.atomic.AtomicInteger
;
import
static
java
.
util
.
concurrent
.
TimeUnit
.
MILLISECONDS
;
import
static
top
.
jbxie
.
raft
.
nodeCommon
.
NodeStatus
.
LEADER
;
import
static
top
.
ninwoo
.
satellite
.
nodeCommon
.
NodeStatus
.
LEADER
;
/**
* 抽象机器节点, 初始为 follower, 角色随时变化.
...
...
@@ -101,6 +100,8 @@ public class DefaultNode<T> implements Node<T>, LifeCycle, ClusterMembershipChan
public
RpcClient
rpcClient
=
new
DefaultRpcClient
();
public
MyMqttClient
myMqttClient
;
public
StateMachine
stateMachine
;
/* ============================== */
...
...
@@ -128,16 +129,17 @@ public class DefaultNode<T> implements Node<T>, LifeCycle, ClusterMembershipChan
* @param config
*/
@Override
public
void
setConfig
(
NodeConfig
config
)
{
public
void
setConfig
(
NodeConfig
config
)
throws
MqttException
{
this
.
config
=
config
;
stateMachine
=
DefaultStateMachine
.
getInstance
();
// myMqttClient = new MyMqttClient();
logModule
=
DefaultLogModule
.
getInstance
();
peerSet
=
PeerSet
.
getInstance
();
for
(
String
s
:
config
.
getPeerAddrs
())
{
Peer
peer
=
new
Peer
(
s
);
peerSet
.
addPeer
(
peer
);
//if (s.equals("localhost:" + config.getSelfAddr())) {
//
if (s.equals("localhost:" + config.getSelfAddr())) {
if
(
s
.
equals
(
config
.
getSelfAddr
()))
{
peerSet
.
setSelf
(
peer
);
}
...
...
apps/cnf-space
-iot/space-iot-raft/src/main/java/top/jbxie/raft
/util/impl/DefaultStateMachine.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite
/util/impl/DefaultStateMachine.java
View file @
29112de4
package
top.
jbxie.raft
.util.impl
;
package
top.
ninwoo.satellite
.util.impl
;
import
com.alibaba.fastjson.JSON
;
import
lombok.Getter
;
...
...
@@ -8,12 +8,9 @@ import org.rocksdb.RocksDB;
import
org.rocksdb.RocksDBException
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.core.env.Environment
;
import
top.jbxie.raft.entity.Command
;
import
top.jbxie.raft.entity.LogEntry
;
import
top.jbxie.raft.nodeCommon.NodeConfig
;
import
top.jbxie.raft.util.StateMachine
;
import
top.ninwoo.satellite.entity.Command
;
import
top.ninwoo.satellite.entity.LogEntry
;
import
top.ninwoo.satellite.util.StateMachine
;
import
java.io.File
;
...
...
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/util/mqttUtils/MqttClientCallback.java
0 → 100644
View file @
29112de4
package
top.ninwoo.satellite.util.mqttUtils
;
import
com.alibaba.fastjson.JSONObject
;
import
lombok.extern.slf4j.Slf4j
;
import
org.eclipse.paho.client.mqttv3.IMqttDeliveryToken
;
import
org.eclipse.paho.client.mqttv3.MqttCallback
;
import
org.eclipse.paho.client.mqttv3.MqttException
;
import
org.eclipse.paho.client.mqttv3.MqttMessage
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
org.springframework.stereotype.Component
;
import
java.io.UnsupportedEncodingException
;
import
java.text.SimpleDateFormat
;
import
java.util.Date
;
/**
* 发布消息的回调类
*
* 必须实现MqttCallback的接口并实现对应的相关接口方法CallBack 类将实现 MqttCallBack。
* 每个客户机标识都需要一个回调实例。在此示例中,构造函数传递客户机标识以另存为实例数据。
* 在回调中,将它用来标识已经启动了该回调的哪个实例。
* 必须在回调类中实现三个方法:
*
* public void messageArrived(MqttTopic topic, MqttMessage message)接收已经预订的发布。
*
* public void connectionLost(Throwable cause)在断开连接时调用。
*
* public void deliveryComplete(MqttDeliveryToken token))
* 接收到已经发布的 QoS 1 或 QoS 2 消息的传递令牌时调用。
* 由 MqttClient.connect 激活此回调。
*
*/
@Slf4j
@Component
public
class
MqttClientCallback
implements
MqttCallback
{
private
static
final
Logger
logger
=
LoggerFactory
.
getLogger
(
MqttClientCallback
.
class
);
@Override
public
void
connectionLost
(
Throwable
arg0
)
{
logger
.
info
(
"mqtt连接断开,可以做重连"
);
MyMqttClient
.
reConnect
();
}
@Override
public
void
deliveryComplete
(
IMqttDeliveryToken
iMqttDeliveryToken
)
{
logger
.
info
(
"deliveryComplete---------"
+
iMqttDeliveryToken
.
isComplete
());
}
@Override
public
void
messageArrived
(
String
topic
,
MqttMessage
mqttMessage
)
throws
Exception
{
String
messages
=
new
String
(
mqttMessage
.
getPayload
());
if
(!
messages
.
equals
(
"close"
))
{
System
.
out
.
println
(
"{"
);
System
.
out
.
println
(
"接收消息主题 : "
+
topic
);
System
.
out
.
println
(
"接收消息Qos : "
+
mqttMessage
.
getQos
());
System
.
out
.
println
(
"接收消息内容 : "
+
messages
);
System
.
out
.
println
(
"}"
);
SimpleDateFormat
df
=
new
SimpleDateFormat
(
"yyyy-MM-dd HH:mm:ss"
);
//设置日期格式
logger
.
info
(
"接收时间========"
+
df
.
format
(
new
Date
())
+
" "
+
System
.
currentTimeMillis
());
}
}
public
void
perform
(
String
topicP
,
JSONObject
json
)
throws
MqttException
,
UnsupportedEncodingException
{
//你的业务模块
}
}
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/util/mqttUtils/MyMqttClient.java
0 → 100644
View file @
29112de4
package
top.ninwoo.satellite.util.mqttUtils
;
import
org.eclipse.paho.client.mqttv3.*
;
import
org.eclipse.paho.client.mqttv3.persist.MemoryPersistence
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Component
;
import
top.ninwoo.satellite.service.IPService
;
import
java.net.UnknownHostException
;
import
java.text.SimpleDateFormat
;
import
java.util.Date
;
import
java.util.concurrent.ExecutorService
;
import
java.util.concurrent.Executors
;
import
java.util.concurrent.LinkedBlockingQueue
;
/**
* mqtt订阅消息客户端
*/
@Component
public
class
MyMqttClient
{
private
static
final
Logger
logger
=
LoggerFactory
.
getLogger
(
MyMqttClient
.
class
);
@Autowired
private
static
MqttClientCallback
mqttClientCallback
;
@Autowired
private
static
IPService
ipService
;
public
static
MqttClient
mqttClient
=
null
;
private
static
MemoryPersistence
memoryPersistence
=
null
;
private
static
MqttConnectOptions
mqttConnectOptions
=
null
;
/**
* 要发布的消息队列
*/
private
static
LinkedBlockingQueue
<
String
[]>
queue
=
new
LinkedBlockingQueue
<
String
[]>();
public
static
ExecutorService
executorService
=
Executors
.
newFixedThreadPool
(
2
*
Runtime
.
getRuntime
().
availableProcessors
()
+
1
);
/**
* mqtt broker 连接配置,填自己的mqtt地址,及账号密码
*/
private
static
String
broker
;
static
{
try
{
broker
=
"tcp://"
+
ipService
.
getSelfIp
()
+
":1883"
;
}
catch
(
UnknownHostException
e
)
{
e
.
printStackTrace
();
}
}
private
static
String
clientId
;
private
static
String
username
=
"jbxie"
;
private
static
String
password
=
"123456"
;
public
MyMqttClient
()
throws
MqttException
{
connect
();
}
/**
* 客户端连接broker
*/
public
void
connect
()
{
clientId
=
"mqttClient"
+
String
.
valueOf
(
System
.
currentTimeMillis
());
logger
.
info
(
"create mqttClient connect "
+
broker
+
", mqtt clientId = "
+
clientId
);
try
{
memoryPersistence
=
new
MemoryPersistence
();
//设置持久化方式
mqttClient
=
new
MqttClient
(
broker
,
clientId
,
memoryPersistence
);
//MemoryPersistence设置clientid的保存形式,默认为以内存保存
if
(!
mqttClient
.
isConnected
())
{
logger
.
info
(
"create mqtt clientConnection"
);
try
{
mqttConnectOptions
=
new
MqttConnectOptions
();
mqttConnectOptions
.
setCleanSession
(
false
);
// 是否清空客户端的连接记录。若为true,则断开后,broker将自动清除该客户端连接信息
mqttConnectOptions
.
setMaxInflight
(
100000
);
// 允许同时发送几条消息(未收到broker确认信息)
mqttConnectOptions
.
setConnectionTimeout
(
30
);
// 设置连接超时,单位为秒
mqttConnectOptions
.
setKeepAliveInterval
(
20
);
// 保持连接数,设置会话心跳时间 单位为秒 服务器会每隔1.5*20秒的时间向客户端发送个消息判断客户端是否在线,但这个方法并没有重连的机制
if
(
username
!=
null
&&
!
""
.
equals
(
username
))
{
mqttConnectOptions
.
setUserName
(
username
);
mqttConnectOptions
.
setPassword
(
password
.
toCharArray
());
}
mqttClient
.
setCallback
(
mqttClientCallback
);
//客户端添加回调函数
mqttClient
.
connect
(
mqttConnectOptions
);
logger
.
info
(
"客户端连接状态:"
+
mqttClient
.
isConnected
());
}
catch
(
MqttException
me
)
{
System
.
out
.
println
(
"reason "
+
me
.
getReasonCode
());
System
.
out
.
println
(
"msg "
+
me
.
getMessage
());
System
.
out
.
println
(
"loc "
+
me
.
getLocalizedMessage
());
System
.
out
.
println
(
"cause "
+
me
.
getCause
());
System
.
out
.
println
(
"excep "
+
me
);
me
.
printStackTrace
();
}
}
}
catch
(
Exception
e
)
{
e
.
printStackTrace
();
}
}
/**
* 重新连接
*/
public
static
void
reConnect
()
{
while
(
true
)
{
try
{
if
(
mqttClient
!=
null
&&
!
mqttClient
.
isConnected
()
&&
mqttConnectOptions
!=
null
)
{
Thread
.
sleep
(
1000
);
clientId
=
"mqttClient"
+
String
.
valueOf
(
System
.
currentTimeMillis
());
mqttClient
=
new
MqttClient
(
broker
,
clientId
,
memoryPersistence
);
mqttClient
.
connect
(
mqttConnectOptions
);
logger
.
info
(
"=======尝试重新连接=============="
);
break
;
}
}
catch
(
MqttException
|
InterruptedException
e
)
{
logger
.
info
(
"=======重新连接失败:{}=============="
,
e
.
toString
());
continue
;
}
}
}
/**
* 关闭连接
*/
public
void
closeConnect
()
{
//关闭存储方式
if
(
null
!=
memoryPersistence
)
{
try
{
memoryPersistence
.
close
();
}
catch
(
MqttPersistenceException
e
)
{
e
.
printStackTrace
();
}
}
else
{
logger
.
warn
(
"memoryPersistence is null"
);
}
//关闭连接
if
(
mqttClient
!=
null
)
{
if
(
mqttClient
.
isConnected
())
{
try
{
mqttClient
.
disconnect
();
mqttClient
.
close
();
}
catch
(
MqttException
me
)
{
me
.
printStackTrace
();
}
}
else
{
logger
.
warn
(
"mqttClient is not connect"
);
}
}
else
{
logger
.
warn
(
"mqttClient is null"
);
}
}
/**
* 订阅主题
*/
public
static
void
subTopic
(
String
topic
,
int
qos
)
{
if
(
mqttClient
!=
null
&&
mqttClient
.
isConnected
())
{
try
{
mqttConnectOptions
.
setWill
(
topic
,
"close"
.
getBytes
(),
2
,
true
);
logger
.
info
(
"clientId: "
+
mqttClient
.
getClientId
()
+
"订阅主题"
+
topic
);
SimpleDateFormat
df
=
new
SimpleDateFormat
(
"yyyy-MM-dd HH:mm:ss"
);
//设置日期格式
logger
.
info
(
"订阅时间========"
+
df
.
format
(
new
Date
())
+
" "
+
System
.
currentTimeMillis
());
mqttClient
.
subscribe
(
topic
,
qos
);
mqttClient
.
setCallback
(
mqttClientCallback
);
logger
.
info
(
"订阅成功"
);
}
catch
(
MqttException
me
)
{
me
.
printStackTrace
();
}
}
else
{
logger
.
error
(
"mqttClient is Error"
);
}
}
/**
* 订阅主题
*/
public
static
void
subTopic
(
String
[]
topic
,
int
[]
qos
)
{
if
(
mqttClient
!=
null
&&
mqttClient
.
isConnected
())
{
try
{
logger
.
info
(
"clientId: "
+
mqttClient
.
getClientId
()
+
"订阅主题"
+
topic
);
mqttClient
.
subscribe
(
topic
,
qos
);
mqttClient
.
setCallback
(
mqttClientCallback
);
logger
.
info
(
"订阅成功"
);
}
catch
(
MqttException
me
)
{
me
.
printStackTrace
();
}
}
else
{
System
.
out
.
println
(
"mqttClient is Error"
);
}
}
/**
* 清空主题
*/
public
static
void
cleanTopic
(
String
topic
)
{
if
(
mqttClient
!=
null
&&
!
mqttClient
.
isConnected
())
{
try
{
mqttClient
.
unsubscribe
(
topic
);
}
catch
(
MqttException
me
)
{
me
.
printStackTrace
();
}
}
else
{
logger
.
error
(
"mqttClient is Error"
);
}
}
/**
* 发布,默认qos为0,非持久化
* @param topic
* @param message
*/
public
static
void
pubMessage
(
String
topic
,
String
message
)
{
pubMessage
(
0
,
false
,
topic
,
message
);
}
/**
* 发布消息的服务质量(推荐为:2-确保消息到达一次。0-至多一次到达;1-至少一次到达,可能重复),
* retained 默认:false-非持久化(是指一条消息消费完,就会被删除;持久化,消费完,还会保存在服务器中,当新的订阅者出现,继续给新订阅者消费)
* @param topic
* @param message
*/
public
static
void
pubMessage
(
int
qos
,
String
topic
,
String
message
){
pubMessage
(
qos
,
false
,
topic
,
message
);
}
/**
* 发布消息
* @param pubTopic
* @param message
* @param qos
* @param retained
*/
public
static
void
pubMessage
(
int
qos
,
boolean
retained
,
String
pubTopic
,
String
message
)
{
if
(
mqttClient
!=
null
&&
mqttClient
.
isConnected
())
{
MqttMessage
mqttMessage
=
new
MqttMessage
();
mqttMessage
.
setQos
(
qos
);
mqttMessage
.
setRetained
(
retained
);
mqttMessage
.
setPayload
(
message
.
getBytes
());
MqttTopic
topic
=
mqttClient
.
getTopic
(
pubTopic
);
if
(
topic
==
null
)
{
logger
.
error
(
"topic not exist"
);
}
MqttDeliveryToken
token
;
SimpleDateFormat
df
=
new
SimpleDateFormat
(
"yyyy-MM-dd HH:mm:ss"
);
//设置日期格式
logger
.
info
(
"发送时间========"
+
df
.
format
(
new
Date
())
+
" "
+
System
.
currentTimeMillis
());
logger
.
info
(
"clientId: "
+
mqttClient
.
getClientId
()
+
"发送主题:"
+
topic
+
"成功,内容:"
+
message
);
try
{
token
=
topic
.
publish
(
mqttMessage
);
token
.
waitForCompletion
();
logger
.
info
(
"message is published completely! "
+
token
.
isComplete
());
}
catch
(
MqttPersistenceException
me
)
{
logger
.
error
(
"publish fail"
,
me
);
me
.
printStackTrace
();
}
catch
(
MqttException
e
)
{
e
.
printStackTrace
();
}
}
else
{
reConnect
();
}
}
/**
* 发布消息
*/
public
static
void
pubMessage
(
MqttTopic
topic
,
MqttMessage
message
)
throws
MqttPersistenceException
,
MqttException
{
if
(
topic
==
null
)
{
logger
.
error
(
"topic not exist"
);
}
MqttDeliveryToken
token
=
topic
.
publish
(
message
);
token
.
waitForCompletion
();
logger
.
info
(
"message is published completely!"
+
token
.
isComplete
());
}
/**
* 循环从队列queue获取要发布的消息发布
*/
public
void
pubMessageFromQueue
()
{
//启动发布消息的线程, 循环从队列queue获取要发布的消息发布。也就是说要发消息,只要将消息写入队列queue。
new
Thread
(
new
PublishThread
()).
start
();
}
/**
* 将要发布的消息添加到队列
* @param topic
* @param content
*/
public
static
void
publish_common
(
String
topic
,
String
content
,
int
qos
)
{
String
[]
array
=
{
topic
,
content
,
String
.
valueOf
(
qos
)};
//要发布的消息,入队列。
//PublishThread会循环从这个队列获取消息发布.
queue
.
offer
(
array
);
}
/**
* 从队列获取要发布的信息
*/
public
static
String
[]
poll
()
{
return
(
String
[])
queue
.
poll
();
}
}
apps/cnf-spaceiot-shortConnection/css-node-satellite/src/main/java/top/ninwoo/satellite/util/mqttUtils/PublishThread.java
0 → 100644
View file @
29112de4
package
top.ninwoo.satellite.util.mqttUtils
;
import
org.springframework.stereotype.Component
;
import
static
top
.
ninwoo
.
satellite
.
util
.
mqttUtils
.
MyMqttClient
.
poll
;
@Component
public
class
PublishThread
implements
Runnable
{
@Override
public
void
run
()
{
String
[]
obj
=
null
;
System
.
out
.
println
(
"mqtt publish thread start"
);
while
(
true
)
{
obj
=
poll
();
if
(
obj
!=
null
)
{
String
topic
=
obj
[
0
];
String
content
=
obj
[
1
];
int
qos
=
Integer
.
valueOf
(
obj
[
2
]);
System
.
out
.
println
(
"mqtt从队列取出topic:"
+
topic
+
",content:"
+
content
+
",qos"
+
qos
);
try
{
MyMqttClient
.
pubMessage
(
1
,
true
,
topic
,
content
);
System
.
out
.
println
(
"发送mqtt消息,topic: "
+
topic
+
" ,content: "
+
content
);
}
catch
(
Exception
e
)
{
System
.
out
.
println
(
"发消息给设备,topic:"
+
topic
+
",content:"
+
content
);
e
.
printStackTrace
();
}
}
else
{
try
{
Thread
.
sleep
(
1000L
);
}
catch
(
InterruptedException
e
)
{
e
.
printStackTrace
();
}
}
}
}
}
apps/cnf-space
-iot/space-iot-raft
/src/main/resources/application.properties
→
apps/cnf-space
iot-shortConnection/css-node-satellite
/src/main/resources/application.properties
View file @
29112de4
File moved
apps/cnf-space
-iot/space-iot-raft
/src/main/resources/log4j.xml
→
apps/cnf-space
iot-shortConnection/css-node-satellite
/src/main/resources/log4j.xml
View file @
29112de4
File moved
apps/cnf-space
-iot/space-iot-raft/src/test/java/top/jbxie/raft
/impl/DefaultLogModuleTest.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/test/java/top/ninwoo/satellite
/impl/DefaultLogModuleTest.java
View file @
29112de4
package
top.
jbxie.raft
.impl
;
package
top.
ninwoo.satellite
.impl
;
import
org.junit.After
;
import
org.junit.Assert
;
import
org.junit.Before
;
import
org.junit.Test
;
import
top.
jbxie.raft
.entity.Command
;
import
top.
jbxie.raft
.entity.LogEntry
;
import
top.
jbxie.raft
.util.impl.DefaultLogModule
;
import
top.
ninwoo.satellite
.entity.Command
;
import
top.
ninwoo.satellite
.entity.LogEntry
;
import
top.
ninwoo.satellite
.util.impl.DefaultLogModule
;
public
class
DefaultLogModuleTest
{
static
{
...
...
apps/cnf-space
-iot/space-iot-raft/src/test/java/top/jbxie/raft
/impl/DefaultStateMachineTest.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/test/java/top/ninwoo/satellite
/impl/DefaultStateMachineTest.java
View file @
29112de4
package
top.
jbxie.raft
.impl
;
package
top.
ninwoo.satellite
.impl
;
import
org.junit.Before
;
import
org.junit.Test
;
import
org.rocksdb.RocksDBException
;
import
top.
jbxie.raft
.entity.Command
;
import
top.
jbxie.raft
.entity.LogEntry
;
import
top.
jbxie.raft
.util.impl.DefaultStateMachine
;
import
top.
ninwoo.satellite
.entity.Command
;
import
top.
ninwoo.satellite
.entity.LogEntry
;
import
top.
ninwoo.satellite
.util.impl.DefaultStateMachine
;
public
class
DefaultStateMachineTest
{
static
{
...
...
apps/cnf-space
-iot/space-iot-raft/src/test/java/top/jbxie/raft
/impl/RocksDBTest.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/test/java/top/ninwoo/satellite
/impl/RocksDBTest.java
View file @
29112de4
package
top.
jbxie.raft
.impl
;
package
top.
ninwoo.satellite
.impl
;
import
com.alibaba.fastjson.JSON
;
import
lombok.Getter
;
import
lombok.Setter
;
import
lombok.ToString
;
import
org.junit.Before
;
import
org.junit.Test
;
import
org.rocksdb.Options
;
import
org.rocksdb.RocksDB
;
import
org.rocksdb.RocksDBException
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
top.jbxie.raft.util.impl.DefaultLogModule
;
import
java.io.File
;
...
...
apps/cnf-space
-iot/space-iot-raft/src/test/java/top/jbxie/raft
/rpc/RpcClientTest.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/test/java/top/ninwoo/satellite
/rpc/RpcClientTest.java
View file @
29112de4
package
top.
jbxie.raft
.rpc
;
package
top.
ninwoo.satellite
.rpc
;
import
com.alipay.remoting.exception.RemotingException
;
import
top.jbxie.raft.rpc.Request
;
import
top.jbxie.raft.rpc.Response
;
public
class
RpcClientTest
{
private
final
static
com
.
alipay
.
remoting
.
rpc
.
RpcClient
CLIENT
=
new
com
.
alipay
.
remoting
.
rpc
.
RpcClient
();
...
...
apps/cnf-space
-iot/space-iot-raft/src/test/java/top/jbxie/raft
/rpc/RpcServerTest.java
→
apps/cnf-space
iot-shortConnection/css-node-satellite/src/test/java/top/ninwoo/satellite
/rpc/RpcServerTest.java
View file @
29112de4
package
top.
jbxie.raft
.rpc
;
package
top.
ninwoo.satellite
.rpc
;
import
com.alipay.remoting.BizContext
;
import
top.jbxie.raft.rpc.RaftUserProcessor
;
import
top.jbxie.raft.rpc.Request
;
import
top.jbxie.raft.rpc.Response
;
public
class
RpcServerTest
{
private
static
com
.
alipay
.
remoting
.
rpc
.
RpcServer
rpcServer
;
...
...
apps/cnf-space
-iot
/pom.xml
→
apps/cnf-space
iot-shortConnection
/pom.xml
View file @
29112de4
...
...
@@ -10,21 +10,18 @@
</parent>
<modelVersion>
4.0.0
</modelVersion>
<groupId>
top.jbxie
</groupId>
<artifactId>
cnf-space-iot
</artifactId>
<artifactId>
cnf-spaceiot-shortConnection
</artifactId>
<packaging>
pom
</packaging>
<modules>
<module>
space-iot-mqtt
</module>
<module>
space-iot-flooding
</module>
<module>
space-iot-raft
</module>
<module>
css-node-satellite
</module>
<module>
css-node-ground
</module>
<module>
css-common-api
</module>
</modules>
<dependencies>
<dependency>
<groupId>
top.ninwoo
</groupId>
<artifactId>
cnf-client-starter
</artifactId>
<version>
1.0-SNAPSHOT
</version>
</dependency>
<dependency>
<groupId>
org.projectlombok
</groupId>
...
...
@@ -60,13 +57,56 @@
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>
org.springframework
</groupId>
<artifactId>
spring-context
</artifactId>
<version>
${spring.version}
</version>
<scope>
compile
</scope>
</dependency>
<dependency>
<groupId>
junit
</groupId>
<artifactId>
junit
</artifactId>
<version>
4.13.1
</version>
<scope>
test
</scope>
</dependency>
<dependency>
<groupId>
com.google.guava
</groupId>
<artifactId>
guava
</artifactId>
<version>
30.0-jre
</version>
</dependency>
<dependency>
<groupId>
org.rocksdb
</groupId>
<artifactId>
rocksdbjni
</artifactId>
<version>
6.13.3
</version>
</dependency>
<dependency>
<groupId>
com.alibaba
</groupId>
<artifactId>
fastjson
</artifactId>
<version>
1.2.75
</version>
</dependency>
<dependency>
<groupId>
com.alipay.sofa
</groupId>
<artifactId>
hessian
</artifactId>
<version>
4.0.4
</version>
</dependency>
<dependency>
<groupId>
com.alipay.sofa
</groupId>
<artifactId>
bolt
</artifactId>
<version>
1.6.3
</version>
<exclusions>
<exclusion>
<artifactId>
slf4j2-api
</artifactId>
<groupId>
org.slf4j2
</groupId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
<build>
...
...
@@ -88,5 +128,4 @@
</plugins>
</build>
</project>
\ No newline at end of file
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment