springboot开发微服务框架一般使用springcloud全家桶,而整个项目都是容器化的,通过k8s进行编排,而k8s自己也有服务发现机制,所以我们也可以抛弃springcloud里的eureka,而直接使用k8s自己的服务。
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-kubernetes-ribbon</artifactId>
<version>0.3.0.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-kubernetes</artifactId>
<version>0.3.0.RELEASE</version>
</dependency>
spring:
application:
name: hello-world-service
cloud:
config:
uri: http://config-server-service #集群内部的端口,需要是一个namespace里的,目前配置中心的端口为80
fail-fast: true
默认情况下,进行k8s服务调用里会出现用户权限的错误Message: Forbidden!Configured service account doesn‘t have access.
这时需要为k8s账号角色添加权限
kubectl create clusterrolebinding permissive-binding --clusterrole=cluster-admin --user=admin --user=kubelet --group=system:serviceaccounts
原文:https://www.cnblogs.com/lori/p/12922197.html