• springboot+k8s+抛弃springcloud.eureka


    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
    
  • 相关阅读:
    区块链,去中心化应用基本知识与开发实践学习
    服务铝料门窗基本资料
    微信小游戏发布注意事项
    2018阿里云短信发送DEMO接入简单实例
    #SQL1242错误
    百度站内搜索
    jqGrid 手册
    4步 —— 快速开始运行直播小程序
    数字平滑 前端插件JS&CSS库
    jqGrid 中文配置
  • 原文地址:https://www.cnblogs.com/lori/p/12048743.html
Copyright © 2020-2023  润新知