SpringCloud+Nacos搭建使用

Nacos【Dynamic Naming and Configuration Service】提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。

1.搭建Nocos服务

01.下载服务

下载地址:Releases · alibaba/nacos · GitHub

 在window环境学习我下载了zip包

02.生成数据库

03.修改文件

a.编辑application

b.复制文件

复制cluster.conf.example 去掉后缀【.example】生成配置文件

04.执行启动

 启动成功

05.访问服务后台

在浏览器上访问     

 账号密码默认为:nacos 

 Nacos环境搭建完成


2.创建服务

01.创建父级

a.创建服务

b.添加依赖

<spring-boot.version>2.0.4.RELEASE</spring-boot.version>
<spring-cloud.version>Finchley.RELEASE</spring-cloud.version>
<nacos.version>0.2.2.RELEASE</nacos.version>

    <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>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>${spring-boot.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>${nacos.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

02.创建提供者服务模块

a.创建服务

 b.添加依赖

 <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
 </dependency>
 <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
            <version>2.2.5.RELEASE</version>
 </dependency>

为了springboot版本和springcloud版本兼容,这里我修改了

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.9.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

 c.添加注解

@EnableDiscoveryClient

d.添加配置 

server.port=8087
spring.application.name=provider
spring.cloud.nacos.discovery.server-addr=192.168.110.179:8848

 e.创建接口提供服务

@RestController
public class ProviderController {

    @GetMapping("/helloProvider")
    public String helloProvider(){
        return "你好,我是提供服务者";
    }
}

03.创建消费者服务

a.创建服务

b.添加依赖

        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
            <version>2.2.5.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>com.netflix.archaius</groupId>
            <artifactId>archaius-core</artifactId>
            <version>0.7.6</version>
            <exclusions>
                <exclusion>
                    <groupId>com.google.guava</groupId>
                    <artifactId>guava</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <!-- 服务调用  -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
            <version>2.1.1.RELEASE</version>
        </dependency>

为了springboot版本和springcloud版本兼容,这里我修改了

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.9.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

c.添加注解

@EnableDiscoveryClient
@EnableFeignClients

d.添加配置

server.port=8099
spring.application.name=consumer
spring.cloud.nacos.discovery.server-addr=192.168.110.179:8848

e.创建service

@FeignClient(name = "provider", fallback = ConsumerServiceImpl.class)
@Service
public interface ConsumerService {

    @GetMapping("/helloProvider")
    String getHello();
}
@Component
public class ConsumerServiceImpl implements ConsumerService {
    @Override
    public String getHello() {
        return "服务出错";
    }
}

f.创建接口

@RestController
public class ConsumerController {
    @Resource
    private ConsumerService consumerService;

    @GetMapping("/getHello")
    public String getHello(){
        return consumerService.getHello();
    }
}

3.运行

把创建的提供者服务与消费者服务运行起来,再回到nacos服务管理后台页面看

我们会看到有两个服务在nacos服务上注册成功了 

4.调用服务

我们创建一个网页访问消费者服务的接口

 我们会发现成功调用了提供者服务

5.配置中心接入

在这里我把消费者实现配置中心功能

01.创建配置项

在nacos服务后台中的配置列表中创建一个配置文件相当于application.properties或者yaml等配置

 这里我使用的是application.properties并配置了

 2.添加依赖

        <!-- ****************************************************   -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
            <version>2.2.1.RELEASE</version>
        </dependency>

        <dependency>
            <groupId>com.alibaba.nacos</groupId>
            <artifactId>nacos-client</artifactId>
            <version>1.2.0</version>
        </dependency>

        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
            <version>3.7</version>
        </dependency>
        <!-- ****************************************************   -->

3.添加注解

@NacosPropertySource(dataId = "test-dev.properties", autoRefreshed = true)

 4.添加配置

spring.cloud.nacos.config.server-addr=192.168.110.179:8848
spring.profiles.active=dev
spring.cloud.nacos.config.file-extension=properties
spring.cloud.nacos.config.group=DEFAULT_GROUP

 5.修改接口

@RestController
@RefreshScope
@Validated
public class ConsumerController {

    @NacosValue(value = "${datasource.url:123}", autoRefreshed = true)
    private String url;

    @NacosValue(value = "${datasource.username:123}", autoRefreshed = true)
    private String username;

    @NacosValue(value = "${datasource.password:123}", autoRefreshed = true)
    private String password;

    @Autowired
    private RestTemplate restTemplate;
    @Resource
    private ConsumerService consumerService;

    @GetMapping("/getHello")
    public String getHello(){
        System.out.println(url);
        System.out.println(username);
        System.out.println(password);
        return consumerService.getHello();

    }
}

6.启动调用

01.访问接口

 02.监听输出

服务输出为

 03.修改服务配置

 04.访问接口

05.监听输出

服务输出为

项目源码

链接:https://pan.baidu.com/s/12yC3cjK12_izzFO9imcPjQ 
提取码:k5sj

  • 3
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,以下是基于 Spring Cloud+Spring Boot+Nacos+Dubbo+mybatis plus+RocketMQ+Sentinel+Seata+mysql 的项目手脚架的搭建步骤: 1. 创建 Spring Boot 项目 使用 Spring Initializr 创建一个 Spring Boot 项目,选择需要的依赖,包括 Spring Web、Spring Cloud Discovery、Dubbo Starter、Mybatis Plus Starter、RocketMQ Starter、Sentinel Starter、Seata Starter、MySQL Driver 等。 2. 配置 Nacos 注册中心和配置中心 在 application.properties 文件中添加以下配置: ``` spring.cloud.nacos.discovery.server-addr=localhost:8848 spring.cloud.nacos.config.server-addr=localhost:8848 spring.cloud.nacos.config.namespace= spring.cloud.nacos.config.group=DEFAULT_GROUP spring.cloud.nacos.config.prefix=${spring.application.name} spring.cloud.nacos.config.file-extension=properties ``` 其中,server-addr 为 Nacos 的地址,namespace 为命名空间,group 为配置组,prefix 为配置文件前缀,file-extension 为配置文件后缀。 3. 配置 Dubbo 服务提供者和消费者 在 application.properties 文件中添加以下配置: ``` # Dubbo Provider spring.dubbo.application.name=${spring.application.name} spring.dubbo.registry.address=nacos://${spring.cloud.nacos.discovery.server-addr} spring.dubbo.scan=tech.chitosh.oceanus.service # Dubbo Consumer spring.dubbo.consumer.check=false spring.dubbo.consumer.registry=nacos://${spring.cloud.nacos.discovery.server-addr} spring.dubbo.consumer.timeout=5000 ``` 其中,application.name 为应用名称,scan 为扫描的 Dubbo 服务接口包名,check 为是否启用 Dubbo 健康检查,timeout 为 Dubbo 超时时间。 4. 配置 Mybatis Plus 和 MySQL 在 application.properties 文件中添加以下配置: ``` # Mybatis Plus mybatis-plus.mapper-locations=classpath:mapper/*.xml mybatis-plus.configuration.map-underscore-to-camel-case=true mybatis-plus.configuration.cache-enabled=true # MySQL spring.datasource.url=jdbc:mysql://localhost:3306/oceanus?useUnicode=true&characterEncoding=utf8&useSSL=false&allowMultiQueries=true&serverTimezone=Asia/Shanghai spring.datasource.username=root spring.datasource.password=root spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver ``` 其中,mapper-locations 为 Mybatis Plus 的 Mapper.xml 文件路径,map-underscore-to-camel-case 为下划线转驼峰的配置,url 为 MySQL 的连接字符串,username 和 password 为数据库用户名和密码。 5. 配置 RocketMQ 在 application.properties 文件中添加以下配置: ``` # RocketMQ rocketmq.name-server=localhost:9876 rocketmq.producer.group=oceanus rocketmq.consumer.group=oceanus ``` 其中,name-server 为 RocketMQ 的地址,producer.group 为生产者组,consumer.group 为消费者组。 6. 配置 Sentinel 在 application.properties 文件中添加以下配置: ``` # Sentinel spring.cloud.sentinel.transport.dashboard=localhost:8080 spring.cloud.sentinel.transport.port=8719 spring.cloud.sentinel.datasource.ds.nacos.server-addr=localhost:8848 spring.cloud.sentinel.datasource.ds.nacos.data-id=${spring.cloud.nacos.config.prefix}-sentinel spring.cloud.sentinel.datasource.ds.nacos.group=SENTINEL_GROUP ``` 其中,transport.dashboard 为 Sentinel 控制台地址,transport.port 为 Sentinel 所用的端口,datasource.ds.nacos.server-addr 为 Nacos 的地址,data-id 为 Sentinel 数据源的名称,group 为 Sentinel 数据源所在的组。 7. 配置 Seata 在 application.properties 文件中添加以下配置: ``` # Seata spring.cloud.alibaba.seata.tx-service-group=my_test_tx_group spring.cloud.alibaba.seata.enable-auto-data-source-proxy=true spring.cloud.alibaba.seata.config.type=nacos spring.cloud.alibaba.seata.config.nacos.server-addr=localhost:8848 spring.cloud.alibaba.seata.config.nacos.namespace= spring.cloud.alibaba.seata.config.nacos.group=SEATA_GROUP ``` 其中,tx-service-group 为 Seata 分布式事务组名称,enable-auto-data-source-proxy 为是否启用 Seata 数据源代理,config.type 为 Seata 配置类型,config.nacos.server-addr 为 Nacos 的地址,config.nacos.namespace 为命名空间,config.nacos.group 为 Seata 配置所在的组。 8. 编写代码 按照业务需求编写 Dubbo 服务接口和实现、Mybatis Plus DAO 层、RocketMQ 生产者和消费者、Sentinel 熔断降级规则等代码。 以上就是基于 Spring Cloud+Spring Boot+Nacos+Dubbo+mybatis plus+RocketMQ+Sentinel+Seata+mysql 的项目手脚架的搭建步骤,希望对你有所帮助。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值