腾讯犀牛鸟开源人才培养计划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. Android音视频开发(1):H264 基本原理

    前言 H264 视频压缩算法现在无疑是所有视频压缩技术中使用最广泛,最流行的.随着 x264/openh264 以及 ffmpeg 等开源库的推出,大多数使用者无需再对H264的细节做过多的研究,这大 ...

  2. 如何将代码优雅的插入到word中

    介:写博客或者word时需要插入代码,但如何更优雅的将代码插入到word中呢? 反面教材如下: 技巧步骤1:插入表格,设置表格无边框: 技巧步骤2:使用Notepad++的高级功能: 大部分代码编辑器 ...

  3. Vue-cli4 唤醒摄像头扫描二维码

    <template> <div class="scan"> <div id="bcid"> <div id=" ...

  4. STP进阶版MSTP

    一.MSTP简介 1.1.MSTP工作原理 mstp是一个公有生成树协议,在实际生产环境中得到了广泛的应用.传统的生成树只运行一个实例,且收敛速度慢,RSTP在传统的STP基础上通过改进达到了加速网络 ...

  5. filebeat+ELK配置及常用操作

    背景介绍 最近工作涉及几台新服务器的日志需要接入ELK系统,配置思路如下: 使用Filebeat收集本地日志数据,Filebeat监视日志目录或特定的日志文件,再发送到消息队列到kafka,然后log ...

  6. DHCP服务-自动管理IP地址和分配固定IP

    dhcp服务 端口:67 配置文件:/etc/dhcp/dhcpd.conf 自动分配IP: 一. 安装服务:yum install dhcp 安装过程省略 二.首先,看到配置文件中啥也没有,他的配置 ...

  7. xml的约束

    一.DTD约束xml 1.约束介绍 由于xml的标签由用户自己定义,因此在开发的时候,每个人都可以根据自己的需求来定义xml标签,这样导致项目中的xml难以维护,因此需要使用一定的规范机制来约束xml ...

  8. java批量下载文件为zip包

    批量下载文件为zip包的工具类 package com.meeno.trainsys.util; import javax.servlet.http.HttpServletRequest; impor ...

  9. SQL Server中的group by(分组)

    参考网址: https://blog.csdn.net/tswc_byy/article/details/81909052 sql 查询不必需和聚合函数一起使用 ,通常来说一般是要和聚合函数一起使用来 ...

  10. springboot中@Mapper和@Repository的区别

    @Mapper和@Repository是常用的两个注解,两者都是用在dao上,两者功能差不多,容易混淆,有必要清楚其细微区别: 区别: @Repository需要在Spring中配置扫描地址,然后生成 ...