[转帖]springboot+k8s+抛弃springcloud.eureka

Posted jinanxiaolaohu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[转帖]springboot+k8s+抛弃springcloud.eureka相关的知识,希望对你有一定的参考价值。

 
https://www.cnblogs.com/lori/p/12048743.html

 

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>

注意点

  1. application.name与k8s的服务名相同,即feign里的服务名称
  2. 必须要开启@EnableDiscoveryClient注解
  3. springcloud的配置中心需要和项目在一个namespace里,即k8s的clusterIp不能跨namespace,如果是多个namespace需要用nodeport模式
  4. 使用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

以上是关于[转帖]springboot+k8s+抛弃springcloud.eureka的主要内容,如果未能解决你的问题,请参考以下文章

[转帖] K8S 常用命令

[转帖]理解k8s 的 Ingress

转帖K8S Deployment 命令

[转帖] k8s kubectl 命令行技巧

[转帖]k8s.gcr.io/pause的作用

[转帖]k8s.gcr.io镜像无法下载的问题