初始化

master
yangpeng 2024-08-08 19:35:03 +08:00
commit 5d5022b734
10 changed files with 279 additions and 0 deletions

35
.gitignore vendored 100644
View File

@ -0,0 +1,35 @@
target/
!.mvn/wrapper/maven-wrapper.jar
!**/src/main/**/target/
!**/src/test/**/target/
### IntelliJ IDEA ###
.idea
*.iws
*.iml
*.ipr
### Eclipse ###
.apt_generated
.classpath
.factorypath
.project
.settings
.springBeans
.sts4-cache
### NetBeans ###
/nbproject/private/
/nbbuild/
/dist/
/nbdist/
/.nb-gradle/
build/
!**/src/main/**/build/
!**/src/test/**/build/
### VS Code ###
.vscode/
### Mac OS ###
.DS_Store

30
pom.xml 100644
View File

@ -0,0 +1,30 @@
<?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">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.muyu</groupId>
<artifactId>cloud-common</artifactId>
<version>3.6.3</version>
</parent>
<artifactId>cloud-common-nacos-remote</artifactId>
<version>1.0.0</version>
<properties>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<!-- 公共核心包依赖 -->
<dependency>
<groupId>com.muyu</groupId>
<artifactId>cloud-common-core</artifactId>
</dependency>
</dependencies>
</project>

View File

@ -0,0 +1,21 @@
package com.muyu.common.nacos;
import com.dtflys.forest.springboot.annotation.ForestScan;
import com.muyu.common.nacos.remote.interceptor.NacosNamespaceInterceptor;
import com.muyu.common.nacos.service.NacosServerService;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Import;
/**
* @Author: by
* @Date 2024/8/7 22:07
* @Description nacos
*/
@Configuration
@ForestScan(basePackages = "com.muyu.common.nacos.remote")
@Import(value = {
NacosNamespaceInterceptor.class,
NacosServerService.class
})
public class NacosRemoteConfig {
}

View File

@ -0,0 +1,24 @@
package com.muyu.common.nacos.remote;
import com.dtflys.forest.annotation.BaseRequest;
import com.dtflys.forest.annotation.Body;
import com.dtflys.forest.annotation.GetRequest;
import com.muyu.common.core.constant.Constants;
import com.muyu.common.nacos.remote.interceptor.NacosNamespaceInterceptor;
import com.muyu.common.nacos.remote.req.ServiceListReq;
import com.muyu.common.nacos.remote.resp.ServiceListResp;
/**
* @Author: by
* @Date 2024/8/6 21:19
* @Description nacosapi
*/
@BaseRequest(
baseURL = Constants.HTTP + "#{nacos.addr}/nacos/v1/ns/service",
interceptor = {NacosNamespaceInterceptor.class}
)
public interface NacosServiceRemote {
@GetRequest(url = "/list")
public ServiceListResp serviceList(@Body ServiceListReq serviceListReq);
}

View File

@ -0,0 +1,43 @@
package com.muyu.common.nacos.remote.interceptor;
import com.dtflys.forest.http.ForestRequest;
import com.dtflys.forest.interceptor.Interceptor;
import com.muyu.common.core.text.Convert;
import com.muyu.common.core.utils.StringUtils;
import lombok.extern.log4j.Log4j2;
import org.springframework.beans.factory.annotation.Value;
/**
* @Author: by
* @Date 2024/8/10 8:03
* @Description nacos
*/
@Log4j2
public class NacosNamespaceInterceptor<T> implements Interceptor<T> {
@Value("${nacos.namespace}")
private String namespaceId;
/**
* , false
* @Param request Forest
*/
@Override
public boolean beforeExecute(ForestRequest req) {
if (StringUtils.isNotBlank(namespaceId)) {
String reqNamespaceId = Convert.utf8Str(req.getQuery("namespaceId"));
if (reqNamespaceId == null) {
log.warn("本次请求nacos的namespaceId未携带已添加[{}]", namespaceId);
req.addQuery("namespaceId", namespaceId); // 添加URL的Query参数
} else {
if(StringUtils.equals(reqNamespaceId, namespaceId)) {
log.warn("本次请求nacos的namespaceId和项目ID不相符现已更改[{}->{}]", reqNamespaceId, namespaceId);
req.addQuery("namespaceId", namespaceId); // 添加URL的Query参数
}
}
}
return true; // 继续执行请求返回true
}
}

View File

@ -0,0 +1,25 @@
package com.muyu.common.nacos.remote.req;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.SuperBuilder;
/**
* @Author: by
* @Date 2024/8/6 23:47
* @Description
*/
@Data
@SuperBuilder
@NoArgsConstructor
@AllArgsConstructor
public class BaseReq {
/**
* ID
*/
private String namespaceId;
}

View File

@ -0,0 +1,33 @@
package com.muyu.common.nacos.remote.req;
import lombok.*;
import lombok.experimental.SuperBuilder;
/**
* @Author: by
* @Date 2024/8/6 23:48
* @Description
*/
@Data
@SuperBuilder
@NoArgsConstructor
@AllArgsConstructor
@EqualsAndHashCode(callSuper = true)
public class ServiceListReq extends BaseReq {
/**
*
*/
private int pageNo;
/**
*
*/
@Builder.Default
private int pageSize = 10;
/**
*
*/
private String groupName;
}

View File

@ -0,0 +1,30 @@
package com.muyu.common.nacos.remote.resp;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.util.List;
/**
* @Author: by
* @Date 2024/8/6 23:55
* @Description nacos
*/
@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class ServiceListResp {
/**
*
*/
private int count;
/**
*
*/
private List<String> doms;
}

View File

@ -0,0 +1,37 @@
package com.muyu.common.nacos.service;
import com.muyu.common.nacos.remote.NacosServiceRemote;
import com.muyu.common.nacos.remote.req.ServiceListReq;
import com.muyu.common.nacos.remote.resp.ServiceListResp;
import jakarta.annotation.Resource;
import org.springframework.beans.factory.annotation.Autowired;
import java.util.ArrayList;
import java.util.List;
/**
* @Author: by
* @Date 2024/8/7 0:49
* @Description TODO nacos
*/
public class NacosServerService {
@Autowired
private NacosServiceRemote nacosServiceRemote;
public List<String> nacosServerAllList() {
ArrayList<String> serverList = new ArrayList<>();
ServiceListResp serviceListResp = null;
int pageNo = 1, pageSize = 2;
do {
nacosServiceRemote.serviceList(
ServiceListReq.builder()
.pageNo(++pageNo)
.pageSize(pageSize)
.build()
);
serverList.addAll(serviceListResp.getDoms());
} while (serviceListResp.getCount() > pageNo * pageSize);
return serverList;
}
}

View File

@ -0,0 +1 @@
com.muyu.common.nacos.NacosRemoteConfig