Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
H
holmes
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
QA
holmes
Commits
f2cee012
Commit
f2cee012
authored
Aug 17, 2021
by
黎博
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
update
parent
fb35e450
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
92 additions
and
1 deletion
+92
-1
K8sController.java
src/main/java/cn/qg/holmes/controller/k8s/K8sController.java
+19
-0
ImageService.java
src/main/java/cn/qg/holmes/service/k8s/ImageService.java
+1
-1
MqService.java
src/main/java/cn/qg/holmes/service/k8s/MqService.java
+72
-0
No files found.
src/main/java/cn/qg/holmes/controller/k8s/K8sController.java
View file @
f2cee012
...
...
@@ -5,6 +5,7 @@ import cn.qg.holmes.entity.k8s.DockerProject;
import
cn.qg.holmes.entity.k8s.ServiceCreateVo
;
import
cn.qg.holmes.service.k8s.DockerProjectService
;
import
cn.qg.holmes.service.k8s.ImageService
;
import
cn.qg.holmes.service.k8s.MqService
;
import
cn.qg.holmes.service.k8s.TkeService
;
import
com.baomidou.mybatisplus.core.conditions.query.QueryWrapper
;
import
org.springframework.beans.factory.annotation.Autowired
;
...
...
@@ -31,6 +32,9 @@ public class K8sController {
@Autowired
DockerProjectService
dockerProjectService
;
@Autowired
MqService
mqService
;
/**
* 获取namespace列表
* @return
...
...
@@ -197,4 +201,19 @@ public class K8sController {
public
JsonResult
deletePodByName
(
String
namespace
,
String
serviceName
)
{
return
JsonResult
.
buildSuccessResult
(
tkeService
.
deleteDeployment
(
namespace
,
serviceName
));
}
/**
* 根据类型获取所有的镜像名
* @param namespace qa-base,qa-ui,qa-java等
* @return
*/
@GetMapping
(
"/getSingleTypeApp"
)
public
JsonResult
getSingleTypeApp
(
@RequestParam
String
namespace
)
{
return
JsonResult
.
buildSuccessResult
(
imageService
.
getSingleTypeApp
(
namespace
));
}
@PostMapping
(
"/sync/mq"
)
public
JsonResult
syncOnlineMqToTest
(
String
host
)
{
return
JsonResult
.
buildSuccessResult
(
mqService
.
setDefinitions
(
host
));
}
}
src/main/java/cn/qg/holmes/service/k8s/ImageService.java
View file @
f2cee012
...
...
@@ -56,7 +56,7 @@ public class ImageService {
/**
* 获取腾讯镜像仓库的镜像
* @param namespace
* @param namespace
qa-base, qa-java, qa-ui 等等
* @return
*/
public
Map
<
String
,
Object
>
getSingleTypeApp
(
String
namespace
)
{
...
...
src/main/java/cn/qg/holmes/service/k8s/MqService.java
0 → 100644
View file @
f2cee012
package
cn
.
qg
.
holmes
.
service
.
k8s
;
import
cn.qg.holmes.utils.HttpClientUtils
;
import
com.alibaba.fastjson.JSON
;
import
lombok.extern.slf4j.Slf4j
;
import
org.springframework.stereotype.Component
;
import
java.util.ArrayList
;
import
java.util.HashMap
;
import
java.util.List
;
import
java.util.Map
;
@Slf4j
@Component
public
class
MqService
{
/**
* 获取MQ信息
* @param host
* @param auth
* @return
*/
public
Map
<
String
,
Object
>
getDefinitionsOfHost
(
String
host
,
String
auth
)
{
Map
<
String
,
String
>
headers
=
new
HashMap
<>();
headers
.
put
(
"Authorization"
,
auth
);
String
response
=
HttpClientUtils
.
doGet
(
host
+
"/api/definitions"
,
headers
,
null
);
return
JSON
.
parseObject
(
response
,
Map
.
class
);
}
/**
* 同步线上MQ到测试
* @param host
* @return
*/
public
boolean
setDefinitions
(
String
host
)
{
try
{
String
ONLINE_MQ_URL
=
"http://172.30.3.140:15672"
;
String
ONLINE_MQ_AUTH
=
"Basic cmFiYml0X2FkbWluOmFiYzEyMzQ="
;
Map
<
String
,
Object
>
onlineDefinitions
=
getDefinitionsOfHost
(
ONLINE_MQ_URL
,
ONLINE_MQ_AUTH
);
List
<
Map
<
String
,
String
>>
permissionList
=
(
List
<
Map
<
String
,
String
>>)
onlineDefinitions
.
get
(
"permissions"
);
List
<
Map
<
String
,
String
>>
qaPermissionList
=
new
ArrayList
<>();
for
(
Map
<
String
,
String
>
permission:
permissionList
)
{
if
(
permission
.
get
(
"user"
).
equals
(
"rabbit_admin"
))
{
qaPermissionList
.
add
(
permission
);
permission
.
put
(
"user"
,
"qa"
);
qaPermissionList
.
add
(
permission
);
}
if
(!
permission
.
get
(
"user"
).
equals
(
"qa"
)
&&
!
permission
.
get
(
"user"
).
equals
(
"rabbit_admin"
))
{
qaPermissionList
.
add
(
permission
);
}
}
onlineDefinitions
.
put
(
"permissions"
,
qaPermissionList
);
String
QA_MQ_AUTH
=
"Basic cWE6cWF0ZXN0"
;
String
qaMqUrl
=
"http://"
+
host
+
"/api/definitions"
;
Map
<
String
,
String
>
headers
=
new
HashMap
<>();
headers
.
put
(
"Authorization"
,
QA_MQ_AUTH
);
headers
.
put
(
"Content-Type"
,
"application/json"
);
HttpClientUtils
.
doPostJson
(
qaMqUrl
,
headers
,
JSON
.
toJSONString
(
JSON
.
toJSONString
(
onlineDefinitions
)));
log
.
info
(
"MQ同步成功:{}"
,
host
);
return
true
;
}
catch
(
Exception
e
)
{
log
.
info
(
"MQ同步失败:{}"
,
host
);
e
.
printStackTrace
();
return
false
;
}
}
public
static
void
main
(
String
[]
args
)
{
MqService
mqService
=
new
MqService
();
mqService
.
setDefinitions
(
"172.17.5.17:31426"
);
}
}
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