腾讯犀牛鸟开源人才培养计划Tars实战笔记目录


前言

在2021年夏,笔者参加了腾讯首届开源人才培养计划的Tars项目,负责Subset流量管理规则的Java语言JDK实现。其中写作几篇开源实战笔记,将其总结在以下文章中。

大标题可以跳转至对应博文。


第1篇 Win10下Docker部署TarsJava(SpringBoot)全过程及踩坑记录

  • 相关环境版本

    坑点一:VMware与Win10 Docker冲突

    坑点二:20.版本TarsJava(SpringBoot)依赖文件缺失
  • Docker安装

    坑点三:Docker的镜像默认安装在C盘
  • Tars部署

    坑点四:Tars框架MySQL密码错误
  • 代码处理

    坑点五:发布包与服务名不匹配

    坑点六:[alarm] down, server is inactive
  • 接口调试

第2篇 TarsJava SpingBoot启动与负载均衡源码初探

  • Tars客户端启动
  • Communicator通信器
  • 本客户端的负载均衡调用器LoadBalance

第3篇 Tars中期汇报测试文档(Java语言实现Subset路由规则)

  • 任务介绍
  • 测试模拟方案
  • 按比例路由规则 - 单次测试
  • 按比例路由规则 - 多次测试
  • 按参数路由规则测试
  • 按无路由规则测试

第4篇 Subset路由规则业务分析与源码探索

  • Subset不是负载均衡
  • 从头开始源码分析
  • Subset应该添加在哪
  • 总结

第5篇 基于TarsGo Subset路由规则的Java JDK实现方式(上)

  • 修改.tars协议文件
  • 【核心】增添Subset核心功能
  • 添加常量与获取染色key的方法
  • 【核心】修改获取服务IP规则
  • 实现透传染色Key功能(客户端)
  • 实现透传染色Key功能(服务端)
  • 给节点信息增添Subset字段
  • *新增工具类

第6篇 基于TarsGo Subset路由规则的Java JDK实现方式(下)

  • 修改.tars协议文件
  • 【核心】增添Subset核心功能
  • 添加常量与获取染色key的方法
  • 【核心】修改获取服务IP规则
  • 实现透传染色Key功能(客户端)
  • 实现透传染色Key功能(服务端)
  • 给节点信息增添Subset字段
  • *正则算法的实现
  • *添加测试代码

第7篇 TarsJava Subset最终代码的测试方案设计

  • SubsetConf配置项的结构
  • 测试方案设计
  • 按比例路由规则 - 单次测试
  • 按比例路由规则 - 多次测试
  • 按参数路由规则 - 精确匹配测试
  • 按参数路由规则 - 正则匹配测试
  • 无路由规则测试

第8篇 TarsJava Subset最终代码的执行流程与原理分析

  • SubsetConf配置项的结构
  • 过滤节点的方法入口
  • subsetEndpointFilter()方法解析
  • getSubset()方法解析
  • getSubsetConfig()方法解析
  • 按比例路由的findSubet()方法解析
  • 按参数路由的findSubet()方法解析
  • 总结:Subset业务执行流程结构图

最后

新人制作,如有错误,欢迎指出,感激不尽!
欢迎关注公众号,会分享一些更日常的东西!
如需转载,请标注出处!

Tars | 第0篇 腾讯犀牛鸟开源人才培养计划Tars实战笔记目录的更多相关文章

  1. ArcGIS API for JavaScript 4.2学习笔记[0] AJS4.2概述、新特性、未来产品线计划与AJS笔记目录

    放着好好的成熟的AJS 3.19不学,为什么要去碰乳臭未干的AJS 4.2? 4.2全线基础学习请点击[直达] 4.3及更高版本的补充学习请关注我的博客. ArcGIS API for JavaScr ...

  2. 2020腾讯犀牛鸟网络安全T-Star高校挑战赛writeup

    签到 浏览器禁用js,在www目录下有 key 命令执行基础 使用 | 可以执行其他命令,在 ../目录下有 key.php cat 一下读出来 你能爆破吗 一开始随便输了个账号的时候不是这个页面,抓 ...

  3. Tars | 第6篇 基于TarsGo Subset路由规则的Java JDK实现方式(下)

    目录 前言 1. 修改.tars协议文件 1.1 Java源码位置及逻辑分析 1.2 Java语言实现方式 1.3 通过协议文件自动生成代码 1.4 变更代码的路径 2. [核心]增添Subset核心 ...

  4. 使用多种客户端消费WCF RestFul服务(二)——.net4.0篇

    .net 4.0篇 在.net 4.0下面微软并没有提供类似Net.Http的Rest访问组件,而是在codeplex上面提供的WCF REST Starter Kit Preview 2 里面可以找 ...

  5. 【Unity3D技术文档翻译】第1.0篇 AssetBundles

    前言 "Unity圣典"是目前对官方文档翻译比较详细的,然而文档的最新更新日期是2013年,已经远远落后最新版本,参考意义有限.官方文档.脚本手册是学习Unity3D最直接有效的途 ...

  6. Python 全栈开发【第0篇】:目录

    Python 全栈开发[第0篇]:目录   第一阶段:Python 开发入门 Python 全栈开发[第一篇]:计算机原理&Linux系统入门 Python 全栈开发[第二篇]:Python基 ...

  7. 腾讯两大开源项目Tars、TSeer

    6月25日,在LC3(LinuxCon + ContainerCon + CloudOpen)中国2018大会上,腾讯宣布其两大开源项目——RPC开发框架Tars.轻量化名字服务方案TSeer,加入L ...

  8. RHEL7.0 Docker离线安装以及实战笔记

    1.概述 最近在琢磨一个事--在RHEL 7.0系统上离线安装使用Docker.然后配置JAVAEE环境,发布Web服务.在网上查了资料,大多数是在线安装的,其他的要么是环境不同,要么资料包找不到了. ...

  9. MySQL之父造访腾讯云 为腾讯云数据库开源点赞

    近日,技术大牛 MariaDB 公司创始人兼CTO Michael Widenius(又名Monty).MariaDB 基金会主席 Kaj 来到中国,针对MariaDB与腾讯云的技术合作进行回访.去年 ...

随机推荐

  1. Linux上搭建zookeeper服务注册中心

    .personSunflowerP { background: rgba(51, 153, 0, 0.66); border-bottom: 1px solid rgba(0, 102, 0, 1); ...

  2. Notes about "Exploring Expect"

    Chapter 3 Section "The expect Command": expect_out(0,string) can NOT be written as "e ...

  3. Woc,考场(面试)忘记打平衡树怎么办,Trie救你命

    Woc,考场(面试)忘记打平衡树怎么办,Trie救你命 文本只发布于博客园,其他地方出现本文均是未经许可的盗版. 算法导入 众所周知平衡树很难打(大佬除外),还老是调错.万一这种事情发生在关键时刻你就 ...

  4. 【笔记】模型泛化与岭回归与LASSO

    模型泛化与岭回归与LASSO 模型正则化 模型正则化,简单来说就是限制参数大小 模型正则化是用什么思路来解决先前过拟合的由于过于拟合导致的曲线抖动(线性方程前的系数都很大) 线性回归的目标就是求一个最 ...

  5. S3C2440—3.用点亮LED来熟悉裸机开发的详细流程

    文章目录 一.硬件知识 1.LED原理图 2.芯片手册 Ⅰ.找LED原理图 Ⅱ.找对应引脚 Ⅲ.在芯片手册中查找引脚信息 Ⅳ.查看寄存器说明 Ⅴ.配置寄存器 二.S3C2440框架与启动过程 三.要用 ...

  6. 单链表(Java--尚硅谷)

    基础知识 大体结构和C++的链表差不多 补充之前不知道的:链表分两类,带和不带头结点的链表 现在才知道,Java没有像C/C++那样的指针 首先创建一个LinkList类,然后把链表的各个功能添加进去 ...

  7. xxx.pch(No such file or directory)

    今天在写一个组件的Demo,发现把一个现象. 我把stdafx.h和stdafx.cpp从工程删除了(本地也被我删除了).后来又想把它加回去,就用新的工程生成这两个文件.然后拷贝过来,增加到工程. 但 ...

  8. 03.SpringMVC之器

    整体结构介绍 在Servlet的继承结构中一共有5个类,GenericServlet和HttpServlet在java中剩下的三个类HttpServletBean.FrameworkServlet和D ...

  9. 十二:Servlet3.0的注解

    1.@WebListener注解 表示的就是我们之前的在xml中配置的 <listener> <listener-class>ListenerClass</listene ...

  10. 传统JIT和java9新特性AOT理解

    java慢的原因 1.  除了少量基本类型用栈存储外,所有对象都使用堆存储.堆的性能低于栈. 2.  很多强制类型转换(cast)或加查,耗用内存大.java运行时对类型检测,如果类型不正确会抛出Cl ...