springboot+k8s+抛弃springcloud.eureka
程序员文章站
2022-08-21 17:47:46
springboot开发微服务框架一般使用springcloud全家桶,而整个项目都是容器化的,通过k8s进行编排,而k8s自己也有服务发现机制,所以我们也可以抛弃springcloud里的eureka,而直接使用k8s自己的服务。 添加组件 注意点 1. application.name与k8s的 ......
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>
注意点
- application.name与k8s的服务名相同,即feign里的服务名称
- 必须要开启@enablediscoveryclient注解
- springcloud的配置中心需要和项目在一个namespace里,即k8s的clusterip不能跨namespace,如果是多个namespace需要用nodeport模式
- 使用feign时,它的服务同样需要是同一个namespace下的
spring: application: name: hello-world-service cloud: config: uri: http://config-server-service #集群内部的端口,需要是一个namespace里的,目前配置中心的端口为80 fail-fast: true
# 添加k8s里用户权限
默认情况下,进行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
下一篇: 桂圆价格是多少?一天吃几个桂圆合适呢?