zoukankan      html  css  js  c++  java
  • springcloud~服务发现之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>
    

    注意点

    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
    
  • 相关阅读:
    多说社交评论插件学习《一》
    《转》每天起床时,优秀创业者都会问自己这3个问题
    老赵面试题参考答案(二)《转》
    老赵面试题参考答案(一)《转》
    20个开源项目托管站点推荐
    .NET面试题(二)
    .NET面试题(一)
    Python笔记(28)-----继承
    pytorch实战(2)-----回归例子
    深度学习之入门Pytorch(1)------基础
  • 原文地址:https://www.cnblogs.com/lori/p/12922197.html
Copyright © 2011-2022 走看看