springboot+k8s+抛弃springcloud.eureka

springboot开发微服务框架一般使用springcloud全家桶,而整个项目都是容器化的,通过k8s进行编排,而k8s自己也有服务发现机制,所以我们也可以抛弃springcloud里的eureka,而直接使用k8s自己的服务。

添加组件


    org.springframework.cloud
    spring-cloud-starter-netflix-ribbon


    org.springframework.cloud
    spring-cloud-starter-kubernetes-ribbon
    0.3.0.RELEASE


    org.springframework.cloud
    spring-cloud-starter-kubernetes
    0.3.0.RELEASE

注意点

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

在此我向大家推荐一个架构学习交流圈。交流学习微信:539413949(里面有大量的面试题及答案)里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化、分布式架构等这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多

你可能感兴趣的:(java,spring,程序人生,struts,学习)