nacos整合openfeign

公司一直使用的都是dubbo,很少使用springcloud,自學(xué)下

安裝nacos

nacos即是配置中心也是注冊(cè)中心,安裝參考nacas大致如下

  1. 修改conf/application.properties文件,nacos支持mysql數(shù)據(jù)源配置(目前只支持mysql),添加mysql數(shù)據(jù)源的url、用戶名和密碼。不知道怎么安裝mysql參考安裝mysql
  2. sh startup.sh -m standalone 啟動(dòng)

1.構(gòu)建provider

整體是比較簡(jiǎn)單的,大家照著下面的配置直接貼代碼就行。注意x替換為自己的ip或者包名

pom.xml

  <properties>
        <java.version>1.8</java.version>
        <jackson.version>2.12.4</jackson.version>
        <project.version>1.0.0</project.version>
        <maven-compiler-plugin.version>3.8.1</maven-compiler-plugin.version>
        <maven-source.version>3.2.1</maven-source.version>
        <lombok.version>1.18.12</lombok.version>
        <spring.boot.version>2.3.2.RELEASE</spring.boot.version>
        <spring.cloud.version>Hoxton.SR9</spring.cloud.version>
        <spring.cloud.alibaba.version>2.2.6.RELEASE</spring.cloud.alibaba.version>
    </properties>

 <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>${spring.boot.version}</version>
        <relativePath/>
    </parent>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
    </properties>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring.cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>${spring.cloud.alibaba.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>

        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
    </dependencies>
  <!-- 一般只要在項(xiàng)目的root下的pom.xml中加上上面那些配置 而只需要保留下面的-->
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

啟動(dòng)類(lèi)

@SpringBootApplication
/**這個(gè)注解非常重要**/
@EnableDiscoveryClient
public class ProviderApplication {

    public static void main(String[] args) {
        SpringApplication.run(ProviderApplication.class, args);
    }

    @RestController
    public class EchoController {
        @GetMapping(value = "/echo/{string}")
        public String echo(@PathVariable String string) {
            return "Hello Nacos Discovery " + string;
        }
    }
}

application.properties

server.port=8082
spring.application.name=demo-provider
server.servlet.context-path:/provider
spring.cloud.nacos.discovery.server-addr=你的nacosIp地址:8848
management.endpoints.web.exposure.include=*

2.構(gòu)建consumer的配置

啟動(dòng)類(lèi)配置

@SpringBootApplication
@MapperScan("com.xxx.demo.dao.mapper")
@ComponentScan(basePackages = {"com.xxx.demo"})
@RestController
@Slf4j
@EnableDiscoveryClient
@EnableFeignClients(basePackages = {"com.xxx.demo.service.feign"})
public class DemoApplication {

    public static void main(String[] args) {
        SpringApplication.run(DemoApplication.class, args);
    }
}

上圖中@EnableDiscoveryClient @EnableFeignClients 這兩個(gè)注解注意

申明feign的調(diào)用

注意這邊的要跟provider寫(xiě)的一摸一樣,當(dāng)人也可以把provider的抽象出來(lái)提取為api接口,在消費(fèi)者這邊繼承。

@FeignClient(name = "demo-provider", path = "/provider")
public interface ProviderClient {

    @GetMapping("/echo/{string}")
    String hello(@PathVariable String string);
}

pom的配置

與consumer一樣

服務(wù)端controller

能夠調(diào)用成功

public class FeignController {
    @Resource
    private ProviderClient providerClient;

    /**
     *  openfeign示例
     * @param string 請(qǐng)求入?yún)?     * @return 返回參數(shù)
     */
    @RequestMapping(value = "/consumer/{string}",method = RequestMethod.GET)
    public String consume(@PathVariable String string){
        return providerClient.hello(string);
    }

}

消費(fèi)者application.properties

# 新增如下配置 替換為自己的nacos地址
spring.cloud.nacos.discovery.server-addr=x.x.x.x:8848
management.endpoints.web.exposure.include=*

3.整個(gè)項(xiàng)目結(jié)構(gòu)

image.png

4.參考

1.springcloud-alibaba
2.Spring Boot 整合 OpenFeign + Nacos 的坑

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容