在Kubernetes中,一个API对象在Etcd里的完整资源路径,是由:Group(API组).Version(API版本)和Resource(API资源类型)三个部分组成的. 通过这样的结构,整个Kubernetes里的所有API对象,可以用如下的树形结构表示出来 如果现在要声明一个CronJob对象,那么YAML的开始部分会这么写 apiVersion: batch/v2alpha1 kind: CronJob ... CronJob就是这个API对象的资源类型,Batch就是它们的组,v…
什么是声明式API呢? 答案是,kubectl apply命令. 举个栗子 在本地编写一个Deployment的YAML文件: apiVersion: apps/v1 kind: Deployment metadata: name: nginx-deployment spec: selector: matchLabels: app: nginx replicas: template: metadata: labels: app: nginx spec: containers: - name: n…
声明式API vs 命令时API 计算机系统是分层的,也就是下层做一些支持的工作,暴露接口给上层用.注意:语言的本质是一种接口. 计算机的最下层是CPU指令,其本质就是用"变量定义+顺序执行+分支判断+循环"所表达的逻辑过程.计算机应用的最上层是实现人类社会的某种功能.所以所有计算机编码的过程,就是用逻辑表达现实的过程.层与层之间定义的借口,越接近现实的表达就叫越"声明式"(declarative),越接近计算机的执行过程就叫越"命令式"(imp…
1.在命令式API中,你可以直接发出服务器要执行的命令,例如: “运行容器”.“停止容器”等. 在声明性API中,你声明系统要执行的操作,系统将不断向该状态驱动. 可以想象成手动驾驶和自动驾驶系统.(多了会删除,少了会自动增加) 因此,在Kubernetes中,你创建一个API对象(使用CLI或REST API)来表示你希望系统执行的操作.系统中的所有组件都会向该状态发展,直到删除该对象. 例如,如果要调度容器化工作负载,不是发出“运行容器”命令,而是创建描述所需状态的API对象.pod: 创建…
1. Feign简介 Feign采用声明式API接口的风格,将Java HTTP客户端绑定到它的内部. Feign的首要目标是简化Java HTTP客户端调用过程. 2.Feign客户端示例 Feign依赖:spring-cloud-starter-feign Eureka Client依赖:spring-cloud-starter-eureka Web依赖:spring-cloud-starter-web Spring Boot测试依赖:spring-boot-starter-test <?x…
基本概念 1.Registe 一一服务注册当eureka Client向Eureka Server注册时,Eureka Client提供自身的元数据,比如IP地址.端口.运行状况指标的Uri.主页地址等信息.2.Renew一一服务续约Eureka lient在默认的情况下会每隔30秒发送一次心跳来进行服务续约,代表自己依然存活.如果eureka server在90秒内没有收到心跳消息,将eureka client从实例注册列表中删除.3.Fetch Registries一一获取服务注册列表信息E…
SpringCloud 源码系列(1)-- 注册中心 Eureka(上) SpringCloud 源码系列(2)-- 注册中心 Eureka(中) SpringCloud 源码系列(3)-- 注册中心 Eureka(下) SpringCloud 源码系列(4)-- 负载均衡 Ribbon(上) SpringCloud 源码系列(5)-- 负载均衡 Ribbon(下) SpringCloud 源码系列(6)-- 声明式服务调用 Feign 一.Feign 基础入门 1.Feign 概述 在使用 S…
Feign受Retrofix.JAXRS-2.0和WebSocket影响,采用了声明式API接口的风格,将Java Http客户端绑定到他的内部.Feign的首要目标是将Java Http客户端调用过程变得简单. 源码地址:https://github.com/OpenFeign/feign 本章案例基于上一章,可参考: spring boot 2.0.3+spring cloud (Finchley)1.搭建Eureka 以及构建高可用Eureka Server集群 spring boot 2…
使用Replication Controller . Replica Set管理Pod Replication Controller (RC) 简写为RC,可以使用rc作为kubectl工具的快速管理对象,用来管理多个Pod资源对象,不止针对一个pod对象.如果pod数量过多,则删除多的,如果pod数量减少,有pod不健康或者宕掉时,会重新启动一个pod,保证pod的总数不变,主要用来部署.升级Pod 使用RC管理Pod apiVersion: v1 kind: ReplicationContr…
Spring提供两种事务方式:编程式和声明式(重点) 前者需要手写代码,后者通过配置实现. 事务的回顾: 事务:逻辑上的一组操作,组成这组事务的各个单元,要么全部成功,要么全部失败 事务的特性:ACID 原子性(Atomicity):事务不可分割 一致性(Consistency):事务执行前后数据完整性保持一致 隔离性(Isolation):一个事务执行不应该受到其他事务的干扰 持久性(Durability):一旦事务结束,数据就持久化到数据库 如果不考虑隔离性引发安全问题: 读问题: 脏读:一…