Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
D
discovery
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
谢捷峰
discovery
Commits
ce072160
Commit
ce072160
authored
Aug 03, 2018
by
Nepxion
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
总算找到一个方法支持跟E版类似的Endpoint方式
parent
4a071551
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
80 additions
and
0 deletions
+80
-0
discovery-console/src/main/java/com/nepxion/discovery/console/configuration/ConsoleAutoConfiguration.java
+3
-0
discovery-console/src/main/java/com/nepxion/discovery/console/endpoint/ConsoleEndpoint.java
+30
-0
discovery-plugin-admin-center/src/main/java/com/nepxion/discovery/plugin/admincenter/configuration/AdminAutoConfiguration.java
+3
-0
discovery-plugin-admin-center/src/main/java/com/nepxion/discovery/plugin/admincenter/endpoint/ConfigEndpoint.java
+14
-0
discovery-plugin-admin-center/src/main/java/com/nepxion/discovery/plugin/admincenter/endpoint/RouterEndpoint.java
+18
-0
discovery-plugin-admin-center/src/main/java/com/nepxion/discovery/plugin/admincenter/endpoint/VersionEndpoint.java
+12
-0
No files found.
discovery-console/src/main/java/com/nepxion/discovery/console/configuration/ConsoleAutoConfiguration.java
View file @
ce072160
...
...
@@ -9,6 +9,8 @@ package com.nepxion.discovery.console.configuration;
* @version 1.0
*/
import
org.springframework.boot.actuate.endpoint.web.annotation.RestControllerEndpoint
;
import
org.springframework.boot.autoconfigure.condition.ConditionalOnClass
;
import
org.springframework.context.annotation.Bean
;
import
org.springframework.context.annotation.Configuration
;
import
org.springframework.context.annotation.Import
;
...
...
@@ -34,6 +36,7 @@ public class ConsoleAutoConfiguration {
System
.
out
.
println
(
""
);
}
@ConditionalOnClass
(
RestControllerEndpoint
.
class
)
protected
static
class
ConsoleEndpointConfiguration
{
@Bean
public
ConsoleEndpoint
consoleEndpoint
()
{
...
...
discovery-console/src/main/java/com/nepxion/discovery/console/endpoint/ConsoleEndpoint.java
View file @
ce072160
...
...
@@ -21,14 +21,18 @@ import java.util.Map;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.boot.actuate.endpoint.web.annotation.RestControllerEndpoint
;
import
org.springframework.cloud.client.ServiceInstance
;
import
org.springframework.cloud.client.discovery.DiscoveryClient
;
import
org.springframework.http.HttpStatus
;
import
org.springframework.http.ResponseEntity
;
import
org.springframework.jmx.export.annotation.ManagedOperation
;
import
org.springframework.jmx.export.annotation.ManagedResource
;
import
org.springframework.web.bind.annotation.PathVariable
;
import
org.springframework.web.bind.annotation.RequestBody
;
import
org.springframework.web.bind.annotation.RequestMapping
;
import
org.springframework.web.bind.annotation.RequestMethod
;
import
org.springframework.web.bind.annotation.ResponseBody
;
import
org.springframework.web.bind.annotation.RestController
;
import
org.springframework.web.client.RestTemplate
;
...
...
@@ -43,6 +47,8 @@ import com.nepxion.discovery.console.rest.VersionUpdateRestInvoker;
@RestController
@RequestMapping
(
path
=
"/console"
)
@Api
(
tags
=
{
"控制台接口"
})
@RestControllerEndpoint
(
id
=
"console"
)
@ManagedResource
(
description
=
"Console Endpoint"
)
public
class
ConsoleEndpoint
{
private
static
final
Logger
LOG
=
LoggerFactory
.
getLogger
(
ConsoleEndpoint
.
class
);
...
...
@@ -57,72 +63,96 @@ public class ConsoleEndpoint {
@RequestMapping
(
path
=
"/services"
,
method
=
RequestMethod
.
GET
)
@ApiOperation
(
value
=
"获取服务注册中心的服务列表"
,
notes
=
""
,
response
=
List
.
class
,
httpMethod
=
"GET"
)
@ResponseBody
@ManagedOperation
public
List
<
String
>
services
()
{
return
getServices
();
}
@RequestMapping
(
path
=
"/instances/{serviceId}"
,
method
=
RequestMethod
.
GET
)
@ApiOperation
(
value
=
"获取服务注册中心服务的实例列表"
,
notes
=
""
,
response
=
List
.
class
,
httpMethod
=
"GET"
)
@ResponseBody
@ManagedOperation
public
List
<
ServiceInstance
>
instances
(
@PathVariable
(
value
=
"serviceId"
)
@ApiParam
(
value
=
"服务名"
,
required
=
true
)
String
serviceId
)
{
return
getInstances
(
serviceId
);
}
@RequestMapping
(
path
=
"/instance-list/{serviceId}"
,
method
=
RequestMethod
.
GET
)
@ApiOperation
(
value
=
"获取服务注册中心服务的实例列表(精简数据)"
,
notes
=
""
,
response
=
List
.
class
,
httpMethod
=
"GET"
)
@ResponseBody
@ManagedOperation
public
List
<
InstanceEntity
>
instanceList
(
@PathVariable
(
value
=
"serviceId"
)
@ApiParam
(
value
=
"服务名"
,
required
=
true
)
String
serviceId
)
{
return
getInstanceList
(
serviceId
);
}
@RequestMapping
(
path
=
"/instance-map"
,
method
=
RequestMethod
.
GET
)
@ApiOperation
(
value
=
"获取服务注册中心的服务和实例的Map(精简数据)"
,
notes
=
""
,
response
=
Map
.
class
,
httpMethod
=
"GET"
)
@ResponseBody
@ManagedOperation
public
Map
<
String
,
List
<
InstanceEntity
>>
instanceMap
()
{
return
getInstanceMap
();
}
@RequestMapping
(
path
=
"/remote-config/update/{group}/{serviceId}"
,
method
=
RequestMethod
.
POST
)
@ApiOperation
(
value
=
"推送更新规则配置信息到远程配置中心"
,
notes
=
""
,
response
=
ResponseEntity
.
class
,
httpMethod
=
"POST"
)
@ResponseBody
@ManagedOperation
public
ResponseEntity
<?>
remoteConfigUpdate
(
@PathVariable
(
value
=
"group"
)
@ApiParam
(
value
=
"组名"
,
required
=
true
)
String
group
,
@PathVariable
(
value
=
"serviceId"
)
@ApiParam
(
value
=
"服务名"
,
required
=
true
)
String
serviceId
,
@RequestBody
@ApiParam
(
value
=
"规则配置内容,XML格式"
,
required
=
true
)
String
config
)
{
return
executeRemoteConfigUpdate
(
group
,
serviceId
,
config
);
}
@RequestMapping
(
path
=
"/remote-config/clear/{group}/{serviceId}"
,
method
=
RequestMethod
.
POST
)
@ApiOperation
(
value
=
"清除规则配置信息到远程配置中心"
,
notes
=
""
,
response
=
ResponseEntity
.
class
,
httpMethod
=
"POST"
)
@ResponseBody
@ManagedOperation
public
ResponseEntity
<?>
remoteConfigClear
(
@PathVariable
(
value
=
"group"
)
@ApiParam
(
value
=
"组名"
,
required
=
true
)
String
group
,
@PathVariable
(
value
=
"serviceId"
)
@ApiParam
(
value
=
"服务名"
,
required
=
true
)
String
serviceId
)
{
return
executeRemoteConfigClear
(
group
,
serviceId
);
}
@RequestMapping
(
path
=
"/remote-config/view/{group}/{serviceId}"
,
method
=
RequestMethod
.
GET
)
@ApiOperation
(
value
=
"查看远程配置中心的规则配置信息"
,
notes
=
""
,
response
=
ResponseEntity
.
class
,
httpMethod
=
"GET"
)
@ResponseBody
@ManagedOperation
public
ResponseEntity
<?>
remoteConfigView
(
@PathVariable
(
value
=
"group"
)
@ApiParam
(
value
=
"组名"
,
required
=
true
)
String
group
,
@PathVariable
(
value
=
"serviceId"
)
@ApiParam
(
value
=
"服务名"
,
required
=
true
)
String
serviceId
)
{
return
executeRemoteConfigView
(
group
,
serviceId
);
}
@RequestMapping
(
path
=
"/config/update-async/{serviceId}"
,
method
=
RequestMethod
.
POST
)
@ApiOperation
(
value
=
"批量异步推送更新规则配置信息"
,
notes
=
""
,
response
=
ResponseEntity
.
class
,
httpMethod
=
"POST"
)
@ResponseBody
@ManagedOperation
public
ResponseEntity
<?>
configUpdateAsync
(
@PathVariable
(
value
=
"serviceId"
)
@ApiParam
(
value
=
"服务名"
,
required
=
true
)
String
serviceId
,
@RequestBody
@ApiParam
(
value
=
"规则配置内容,XML格式"
,
required
=
true
)
String
config
)
{
return
executeConfigUpdate
(
serviceId
,
config
,
true
);
}
@RequestMapping
(
path
=
"/config/update-sync/{serviceId}"
,
method
=
RequestMethod
.
POST
)
@ApiOperation
(
value
=
"批量同步推送更新规则配置信息"
,
notes
=
""
,
response
=
ResponseEntity
.
class
,
httpMethod
=
"POST"
)
@ResponseBody
@ManagedOperation
public
ResponseEntity
<?>
configUpdateSync
(
@PathVariable
(
value
=
"serviceId"
)
@ApiParam
(
value
=
"服务名"
,
required
=
true
)
String
serviceId
,
@RequestBody
@ApiParam
(
value
=
"规则配置内容,XML格式"
,
required
=
true
)
String
config
)
{
return
executeConfigUpdate
(
serviceId
,
config
,
false
);
}
@RequestMapping
(
path
=
"/config/clear/{serviceId}"
,
method
=
RequestMethod
.
POST
)
@ApiOperation
(
value
=
"批量清除更新的规则配置信息"
,
notes
=
""
,
response
=
ResponseEntity
.
class
,
httpMethod
=
"POST"
)
@ResponseBody
@ManagedOperation
public
ResponseEntity
<?>
configClear
(
@PathVariable
(
value
=
"serviceId"
)
@ApiParam
(
value
=
"服务名"
,
required
=
true
)
String
serviceId
)
{
return
executeConfigClear
(
serviceId
);
}
@RequestMapping
(
path
=
"/version/update/{serviceId}"
,
method
=
RequestMethod
.
POST
)
@ApiOperation
(
value
=
"批量更新服务的动态版本"
,
notes
=
"根据指定的localVersion更新服务的dynamicVersion。如果输入的localVersion不匹配服务的localVersion,则忽略;如果如果输入的localVersion为空,则直接更新服务的dynamicVersion"
,
response
=
ResponseEntity
.
class
,
httpMethod
=
"POST"
)
@ResponseBody
@ManagedOperation
public
ResponseEntity
<?>
versionUpdate
(
@PathVariable
(
value
=
"serviceId"
)
@ApiParam
(
value
=
"服务名"
,
required
=
true
)
String
serviceId
,
@RequestBody
@ApiParam
(
value
=
"版本号,格式为[dynamicVersion]或者[dynamicVersion];[localVersion]"
,
required
=
true
)
String
version
)
{
return
executeVersionUpdate
(
serviceId
,
version
);
}
@RequestMapping
(
path
=
"/version/clear/{serviceId}"
,
method
=
RequestMethod
.
POST
)
@ApiOperation
(
value
=
"批量清除服务的动态版本"
,
notes
=
"根据指定的localVersion清除服务的dynamicVersion。如果输入的localVersion不匹配服务的localVersion,则忽略;如果如果输入的localVersion为空,则直接清除服务的dynamicVersion"
,
response
=
ResponseEntity
.
class
,
httpMethod
=
"POST"
)
@ResponseBody
@ManagedOperation
public
ResponseEntity
<?>
versionClear
(
@PathVariable
(
value
=
"serviceId"
)
@ApiParam
(
value
=
"服务名"
,
required
=
true
)
String
serviceId
,
@RequestBody
(
required
=
false
)
@ApiParam
(
value
=
"版本号,指localVersion,可以为空"
)
String
version
)
{
return
executeVersionClear
(
serviceId
,
version
);
}
...
...
discovery-plugin-admin-center/src/main/java/com/nepxion/discovery/plugin/admincenter/configuration/AdminAutoConfiguration.java
View file @
ce072160
...
...
@@ -9,6 +9,8 @@ package com.nepxion.discovery.plugin.admincenter.configuration;
* @version 1.0
*/
import
org.springframework.boot.actuate.endpoint.web.annotation.RestControllerEndpoint
;
import
org.springframework.boot.autoconfigure.condition.ConditionalOnClass
;
import
org.springframework.context.annotation.Bean
;
import
org.springframework.context.annotation.Configuration
;
import
org.springframework.context.annotation.Import
;
...
...
@@ -21,6 +23,7 @@ import com.nepxion.discovery.plugin.admincenter.endpoint.VersionEndpoint;
@Configuration
@Import
(
SwaggerConfiguration
.
class
)
public
class
AdminAutoConfiguration
{
@ConditionalOnClass
(
RestControllerEndpoint
.
class
)
protected
static
class
AdminEndpointConfiguration
{
@Bean
public
ConfigEndpoint
configEndpoint
()
{
...
...
discovery-plugin-admin-center/src/main/java/com/nepxion/discovery/plugin/admincenter/endpoint/ConfigEndpoint.java
View file @
ce072160
...
...
@@ -19,11 +19,15 @@ import java.util.List;
import
org.apache.commons.lang3.StringUtils
;
import
org.apache.commons.lang3.exception.ExceptionUtils
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.boot.actuate.endpoint.web.annotation.RestControllerEndpoint
;
import
org.springframework.http.HttpStatus
;
import
org.springframework.http.ResponseEntity
;
import
org.springframework.jmx.export.annotation.ManagedOperation
;
import
org.springframework.jmx.export.annotation.ManagedResource
;
import
org.springframework.web.bind.annotation.RequestBody
;
import
org.springframework.web.bind.annotation.RequestMapping
;
import
org.springframework.web.bind.annotation.RequestMethod
;
import
org.springframework.web.bind.annotation.ResponseBody
;
import
org.springframework.web.bind.annotation.RestController
;
import
com.nepxion.discovery.common.entity.RuleEntity
;
...
...
@@ -36,6 +40,8 @@ import com.nepxion.discovery.plugin.framework.event.RuleUpdatedEvent;
@RestController
@RequestMapping
(
path
=
"/config"
)
@Api
(
tags
=
{
"配置接口"
})
@RestControllerEndpoint
(
id
=
"config"
)
@ManagedResource
(
description
=
"Config Endpoint"
)
public
class
ConfigEndpoint
{
@Autowired
private
PluginContextAware
pluginContextAware
;
...
...
@@ -48,18 +54,24 @@ public class ConfigEndpoint {
@RequestMapping
(
path
=
"/update-async"
,
method
=
RequestMethod
.
POST
)
@ApiOperation
(
value
=
"异步推送更新规则配置信息"
,
notes
=
""
,
response
=
ResponseEntity
.
class
,
httpMethod
=
"POST"
)
@ResponseBody
@ManagedOperation
public
ResponseEntity
<?>
updateAsync
(
@RequestBody
@ApiParam
(
value
=
"规则配置内容,XML格式"
,
required
=
true
)
String
config
)
{
return
update
(
config
,
true
);
}
@RequestMapping
(
path
=
"/update-sync"
,
method
=
RequestMethod
.
POST
)
@ApiOperation
(
value
=
"同步推送更新规则配置信息"
,
notes
=
""
,
response
=
ResponseEntity
.
class
,
httpMethod
=
"POST"
)
@ResponseBody
@ManagedOperation
public
ResponseEntity
<?>
updateSync
(
@RequestBody
@ApiParam
(
value
=
"规则配置内容,XML格式"
,
required
=
true
)
String
config
)
{
return
update
(
config
,
false
);
}
@RequestMapping
(
path
=
"/clear"
,
method
=
RequestMethod
.
POST
)
@ApiOperation
(
value
=
"清除更新的规则配置信息"
,
notes
=
""
,
response
=
ResponseEntity
.
class
,
httpMethod
=
"POST"
)
@ResponseBody
@ManagedOperation
public
ResponseEntity
<?>
clear
()
{
Boolean
discoveryControlEnabled
=
pluginContextAware
.
isDiscoveryControlEnabled
();
if
(!
discoveryControlEnabled
)
{
...
...
@@ -78,6 +90,8 @@ public class ConfigEndpoint {
@RequestMapping
(
path
=
"/view"
,
method
=
RequestMethod
.
GET
)
@ApiOperation
(
value
=
"查看本地和更新的规则配置信息"
,
notes
=
""
,
response
=
ResponseEntity
.
class
,
httpMethod
=
"GET"
)
@ResponseBody
@ManagedOperation
public
ResponseEntity
<
List
<
String
>>
view
()
{
List
<
String
>
ruleList
=
new
ArrayList
<
String
>(
2
);
...
...
discovery-plugin-admin-center/src/main/java/com/nepxion/discovery/plugin/admincenter/endpoint/RouterEndpoint.java
View file @
ce072160
...
...
@@ -21,12 +21,16 @@ import java.util.Map;
import
org.apache.commons.collections4.CollectionUtils
;
import
org.apache.commons.lang3.StringUtils
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.boot.actuate.endpoint.web.annotation.RestControllerEndpoint
;
import
org.springframework.cloud.client.ServiceInstance
;
import
org.springframework.cloud.client.discovery.DiscoveryClient
;
import
org.springframework.jmx.export.annotation.ManagedOperation
;
import
org.springframework.jmx.export.annotation.ManagedResource
;
import
org.springframework.web.bind.annotation.PathVariable
;
import
org.springframework.web.bind.annotation.RequestBody
;
import
org.springframework.web.bind.annotation.RequestMapping
;
import
org.springframework.web.bind.annotation.RequestMethod
;
import
org.springframework.web.bind.annotation.ResponseBody
;
import
org.springframework.web.bind.annotation.RestController
;
import
org.springframework.web.client.RestClientException
;
import
org.springframework.web.client.RestTemplate
;
...
...
@@ -40,6 +44,8 @@ import com.nepxion.discovery.plugin.framework.adapter.PluginAdapter;
@RestController
@RequestMapping
(
path
=
"/router"
)
@Api
(
tags
=
{
"路由接口"
})
@RestControllerEndpoint
(
id
=
"router"
)
@ManagedResource
(
description
=
"Router Endpoint"
)
public
class
RouterEndpoint
{
@Autowired
private
PluginAdapter
pluginAdapter
;
...
...
@@ -52,36 +58,48 @@ public class RouterEndpoint {
@RequestMapping
(
path
=
"/services"
,
method
=
RequestMethod
.
GET
)
@ApiOperation
(
value
=
"获取服务注册中心的服务列表"
,
notes
=
""
,
response
=
List
.
class
,
httpMethod
=
"GET"
)
@ResponseBody
@ManagedOperation
public
List
<
String
>
services
()
{
return
getServices
();
}
@RequestMapping
(
path
=
"/instances/{serviceId}"
,
method
=
RequestMethod
.
GET
)
@ApiOperation
(
value
=
"获取本地节点可访问其他节点(根据服务名)的实例列表"
,
notes
=
""
,
response
=
List
.
class
,
httpMethod
=
"GET"
)
@ResponseBody
@ManagedOperation
public
List
<
ServiceInstance
>
instances
(
@PathVariable
(
value
=
"serviceId"
)
@ApiParam
(
value
=
"目标服务名"
,
required
=
true
)
String
serviceId
)
{
return
getInstanceList
(
serviceId
);
}
@RequestMapping
(
path
=
"/info"
,
method
=
RequestMethod
.
GET
)
@ApiOperation
(
value
=
"获取本地节点信息"
,
notes
=
"获取当前节点的简单信息"
,
response
=
RouterEntity
.
class
,
httpMethod
=
"GET"
)
@ResponseBody
@ManagedOperation
public
RouterEntity
info
()
{
return
getRouterEntity
();
}
@RequestMapping
(
path
=
"/route/{routeServiceId}"
,
method
=
RequestMethod
.
GET
)
@ApiOperation
(
value
=
"获取本地节点可访问其他节点(根据服务名)的路由信息列表"
,
notes
=
""
,
response
=
List
.
class
,
httpMethod
=
"GET"
)
@ResponseBody
@ManagedOperation
public
List
<
RouterEntity
>
route
(
@PathVariable
(
value
=
"routeServiceId"
)
@ApiParam
(
value
=
"目标服务名"
,
required
=
true
)
String
routeServiceId
)
{
return
getRouterEntityList
(
routeServiceId
);
}
@RequestMapping
(
path
=
"/route/{routeServiceId}/{routeHost}/{routePort}/{routeContextPath}"
,
method
=
RequestMethod
.
GET
)
@ApiOperation
(
value
=
"获取指定节点(根据IP和端口)可访问其他节点(根据服务名)的路由信息列表"
,
notes
=
""
,
response
=
List
.
class
,
httpMethod
=
"GET"
)
@ResponseBody
@ManagedOperation
public
List
<
RouterEntity
>
route
(
@PathVariable
(
value
=
"routeServiceId"
)
@ApiParam
(
value
=
"目标服务名"
,
required
=
true
)
String
routeServiceId
,
@PathVariable
(
value
=
"routeHost"
)
@ApiParam
(
value
=
"目标服务所在机器的IP地址"
,
required
=
true
)
String
routeHost
,
@PathVariable
(
value
=
"routePort"
)
@ApiParam
(
value
=
"目标服务所在机器的端口号"
,
required
=
true
)
int
routePort
,
@PathVariable
(
value
=
"routeContextPath"
)
@ApiParam
(
value
=
"目标服务的调用路径前缀"
,
required
=
true
,
defaultValue
=
"/"
)
String
routeContextPath
)
{
return
getRouterEntityList
(
routeServiceId
,
routeHost
,
routePort
,
routeContextPath
);
}
@RequestMapping
(
path
=
"/routes"
,
method
=
RequestMethod
.
POST
)
@ApiOperation
(
value
=
"获取全路径的路由信息树"
,
notes
=
"参数按调用服务名的前后次序排列,起始节点的服务名不能加上去。如果多个用“;”分隔,不允许出现空格"
,
response
=
RouterEntity
.
class
,
httpMethod
=
"POST"
)
@ResponseBody
@ManagedOperation
public
RouterEntity
routes
(
@RequestBody
@ApiParam
(
value
=
"例如:service-a;service-b"
,
required
=
true
)
String
routeServiceIds
)
{
return
routeTree
(
routeServiceIds
);
}
...
...
discovery-plugin-admin-center/src/main/java/com/nepxion/discovery/plugin/admincenter/endpoint/VersionEndpoint.java
View file @
ce072160
...
...
@@ -18,11 +18,15 @@ import java.util.List;
import
org.apache.commons.lang3.StringUtils
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.boot.actuate.endpoint.web.annotation.RestControllerEndpoint
;
import
org.springframework.http.HttpStatus
;
import
org.springframework.http.ResponseEntity
;
import
org.springframework.jmx.export.annotation.ManagedOperation
;
import
org.springframework.jmx.export.annotation.ManagedResource
;
import
org.springframework.web.bind.annotation.RequestBody
;
import
org.springframework.web.bind.annotation.RequestMapping
;
import
org.springframework.web.bind.annotation.RequestMethod
;
import
org.springframework.web.bind.annotation.ResponseBody
;
import
org.springframework.web.bind.annotation.RestController
;
import
com.nepxion.discovery.common.constant.DiscoveryConstant
;
...
...
@@ -35,6 +39,8 @@ import com.nepxion.discovery.plugin.framework.event.VersionUpdatedEvent;
@RestController
@RequestMapping
(
path
=
"/version"
)
@Api
(
tags
=
{
"版本接口"
})
@RestControllerEndpoint
(
id
=
"version"
)
@ManagedResource
(
description
=
"Version Endpoint"
)
public
class
VersionEndpoint
{
@Autowired
private
PluginContextAware
pluginContextAware
;
...
...
@@ -47,6 +53,8 @@ public class VersionEndpoint {
@RequestMapping
(
path
=
"/update"
,
method
=
RequestMethod
.
POST
)
@ApiOperation
(
value
=
"更新服务的动态版本"
,
notes
=
"根据指定的localVersion更新服务的dynamicVersion。如果输入的localVersion不匹配服务的localVersion,则忽略;如果如果输入的localVersion为空,则直接更新服务的dynamicVersion"
,
response
=
ResponseEntity
.
class
,
httpMethod
=
"POST"
)
@ResponseBody
@ManagedOperation
public
ResponseEntity
<?>
update
(
@RequestBody
@ApiParam
(
value
=
"版本号,格式为[dynamicVersion]或者[dynamicVersion];[localVersion]"
,
required
=
true
)
String
version
)
{
Boolean
discoveryControlEnabled
=
pluginContextAware
.
isDiscoveryControlEnabled
();
if
(!
discoveryControlEnabled
)
{
...
...
@@ -76,6 +84,8 @@ public class VersionEndpoint {
@RequestMapping
(
path
=
"/clear"
,
method
=
RequestMethod
.
POST
)
@ApiOperation
(
value
=
"清除服务的动态版本"
,
notes
=
"根据指定的localVersion清除服务的dynamicVersion。如果输入的localVersion不匹配服务的localVersion,则忽略;如果如果输入的localVersion为空,则直接清除服务的dynamicVersion"
,
response
=
ResponseEntity
.
class
,
httpMethod
=
"POST"
)
@ResponseBody
@ManagedOperation
public
ResponseEntity
<?>
clear
(
@RequestBody
(
required
=
false
)
@ApiParam
(
value
=
"版本号,指localVersion,可以为空"
)
String
version
)
{
Boolean
discoveryControlEnabled
=
pluginContextAware
.
isDiscoveryControlEnabled
();
if
(!
discoveryControlEnabled
)
{
...
...
@@ -94,6 +104,8 @@ public class VersionEndpoint {
@RequestMapping
(
path
=
"/view"
,
method
=
RequestMethod
.
GET
)
@ApiOperation
(
value
=
"查看服务的本地版本和动态版本"
,
notes
=
""
,
response
=
ResponseEntity
.
class
,
httpMethod
=
"GET"
)
@ResponseBody
@ManagedOperation
public
ResponseEntity
<
List
<
String
>>
view
()
{
List
<
String
>
versionList
=
new
ArrayList
<
String
>(
2
);
...
...
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