1 安装Nacos
在0.7版本之前,在单机模式时nacos使用嵌入式数据库实现数据的存储,不方便观察数据存储的基本情况。0.7版本增加了支持mysql数据源能力,具体的操作步骤:
- 1.安装数据库,版本要求:5.6.5+
- 2.初始化mysql数据库,数据库初始化文件:nacos-mysql.sql
- 3.修改conf/application.properties文件,增加支持mysql数据源配置(目前只支持mysql),添加mysql数据源的url、用户名和密码。
spring.datasource.platform=mysql
db.num=1
db.url.0=jdbc:mysql://11.162.196.16:3306/nacos_devtest?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=nacos_devtest
db.password=youdontknow
在当前目录使用命令运行单机模式,startup.cmd -m standalone(windows),startup.sh -m standalone(linux),运行后会看到html链接,用户名密码nacos进入。
2 加入依赖
<dependencyManagement>
<dependencies>
<!-- spring cloud -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Hoxton.SR8</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>2.2.3.RELEASE</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<!-- 服务注册 -->
<!-- https://mvnrepository.com/artifact/com.alibaba.cloud/spring-cloud-starter-alibaba-nacos-discovery -->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
<version>2.2.3.RELEASE</version>
</dependency>
<!-- 服务调用 -->
<!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-openfeign -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
<version>2.2.5.RELEASE</version>
</dependency>
3 每个微服务设置application.properties
#nacos配置
spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848
4 使用
启动类上的注解
@EnableDiscoveryClient // nacos注册
@EnableFeignClients //feign服务调用
@SpringBootApplication
@ComponentScan(basePackages = {"com.test"})
public class Appl {
public static void main(String[] args) {
SpringApplication.run(App.class, args);
}
}
此时nacos已经注册了该微服务,@EnableFeignClients是需要在调用端加入的。
调用代码:
创建需要调用的微服务方法接口:
@FeignClient("service-external")
@Component
public interface DoSomeThing {
@GetMapping(value = "/app/service/getinfo/{videoId}")
public String getInfo(@PathVariable("Id") String Id);
}
@FeignClient名称是要调用的服务名
@GetMapping是要调用的服务url
@PathVariable注解指定参数名称
在当前微服务实现中实现引用的微服务代码调用
@Override
public voud test(String id)
{
DoSomeThing.getInfo(id);
}