[dubbo 源码之 ]2. 服务消费方如何启动服务

2020-02-29
阅读 10 分钟
2.4k
消费者在启动之后,会通过ReferenceConfig#get()来生成远程调用代理类。在get方法中,会启动一系列调用函数,我们来一个个解析。

[springboot 开发单体web shop] 8. 商品详情和评价展示

2019-11-25
阅读 15 分钟
2.7k
上节 我们实现了根据搜索关键词查询商品列表和根据商品分类查询,并且使用到了mybatis-pagehelper插件,讲解了如何使用插件来帮助我们快速实现分页数据查询。本文我们将继续开发商品详情页面和商品留言功能的开发。

[springboot 开发单体web shop] 7. 多种形式提供商品列表

2019-11-22
阅读 17 分钟
3.8k
上文回顾 上节 我们实现了仿jd的轮播广告以及商品分类的功能,并且讲解了不同的注入方式,本节我们将继续实现我们的电商主业务,商品信息的展示。 需求分析 首先,在我们开始本节编码之前,我们先来分析一下都有哪些地方会对商品进行展示,打开jd首页,鼠标下拉可以看到如下: 可以看到,在大类型下查询了部分商品在首页...

[springboot 开发单体web shop] 5. 用户登录及首页展示

2019-11-12
阅读 9 分钟
4.4k
Error Tips:这里有一个小小的坑点,大家一定要注意,在使用selectOneByExample()查询的时候,该方法传入的参数一定注意是tk.mybatis.mapper.entity.Example实例,而不是tk.mybatis.mapper.entity.Example.Criteria,否则会报动态SQL生成查询错误,信息如下:

[springboot 开发单体web shop] 4. Swagger生成Javadoc

2019-11-08
阅读 9 分钟
3.6k
在日常的工作中,特别是现在前后端分离模式之下,接口的提供造成了我们前后端开发人员的沟通成本大量提升,因为沟通不到位,不及时而造成的[撕币]事件都成了日常工作。特别是很多的开发人员不擅长沟通,造成的结果就会让自己特别的痛苦,也让合作人员恨的牙根痒痒。为了结束战火蔓延,同时为了提升开发人员的满意度,Swa...

[Spring cloud 一步步实现广告系统] 21. 系统错误汇总

2019-08-19
阅读 8 分钟
2.6k
因为Eureka在集群启动过程中,会连接集群中其他的机器进行数据同步,在这个过程中,如果别的服务还没有启动完成,就会出现Connection refused: connecterror,当其他节点启动完成之后,报错就会消失。

[Spring cloud 一步步实现广告系统] 20. 系统运行测试

2019-08-18
阅读 8 分钟
2.2k
经过长时间的编码实现,我们的主体模块已经大致完成,因为之前我们都是零散的对各个微服务自行测试,接下来,我们需要将所有的服务模块进行联调测试,Let's do it.

[Spring cloud 一步步实现广告系统] 19. 监控Hystrix Dashboard

2019-08-15
阅读 6 分钟
3k
在之前的18次文章中,我们实现了广告系统的广告投放,广告检索业务功能,中间使用到了 服务发现Eureka,服务调用Feign,网关路由Zuul以及错误熔断Hystrix等Spring Cloud组件。简单调用关系:

[Spring cloud 一步步实现广告系统] 18. 查询返回广告创意

2019-08-13
阅读 10 分钟
2.3k
在上一节中我们实现了根据流量信息过滤的代码,但是我们的条件有可能是多条件一起传给我们的检索服务的,本节我们继续实现根据推广单元的三个维度条件的过滤。

[Spring cloud 一步步实现广告系统] 17. 根据流量类型查询广告

2019-08-12
阅读 7 分钟
2.5k
从上图我们可以看出,在媒体方向我们的广告检索系统发起请求的时候,请求中会有很多的请求参数信息,他们分为了三个部分,我们来编码封装这几个参数对象信息以及我们请求本身的信息。Let's code.

[Spring cloud 一步步实现广告系统] 16. 增量索引实现以及投送数据到MQ(kafka)

2019-08-10
阅读 10 分钟
2.7k
上一节中,我们为实现增量索引的加载做了充足的准备,使用到mysql-binlog-connector-java 开源组件来实现MySQL 的binlog监听,关于binlog的相关知识,大家可以自行网络查阅。或者可以mailto:magicianisaac@gmail.com

[Spring cloud 一步步实现广告系统] 15. 使用开源组件监听Binlog 实现增量索引准备

2019-08-09
阅读 23 分钟
2.4k
最主要有3个用途: 数据复制(主从同步) Mysql 的Master-Slave协议,让Slave可以通过监听binlog实现数据复制,达到数据一致性目的

[Spring cloud 一步步实现广告系统] 14. 全量索引代码实现

2019-08-08
阅读 7 分钟
2.4k
上一节我们实现了索引基本操作的类以及索引缓存工具类,本小节我们开始实现加载全量索引数据,在加载全量索引数据之前,我们需要先将数据库中的表数据导出到一份文件中。Let's code.

[Spring cloud 一步步实现广告系统] 13. 索引服务编码实现

2019-08-07
阅读 6 分钟
2.1k
上一节我们分析了广告索引的维护有2种,全量索引加载和增量索引维护。因为广告检索是广告系统中最为重要的环节,大家一定要认真理解我们索引设计的思路,接下来我们来编码实现索引维护功能。

[Spring cloud 一步步实现广告系统] 11. 使用Feign实现微服务调用

2019-08-04
阅读 5 分钟
2.9k
上一节我们使用了Ribbon(基于Http/Tcp)进行微服务的调用,Ribbon的调用比较简单,通过Ribbon组件对请求的服务进行拦截,通过Eureka Server 获取到服务实例的IP:Port,然后再去调用API。本节课我们使用更简单的方式来实现,使用声明式的Web服务客户端Feign,我们只需要使用Feign来声明接口,利用注解来进行配置就可以使用...

[Spring cloud 一步步实现广告系统] 9. 主类和配置文件

2019-07-30
阅读 2 分钟
2.2k
搜索系统启动主类 {代码...} 配置文件 {代码...}

[Spring cloud 一步步实现广告系统] 8. 检索系统配置&依赖

2019-07-30
阅读 5 分钟
2.2k
工作流程 项目依赖 {代码...}

[Spring cloud 一步步实现广告系统] 7. 中期总结回顾

2019-07-29
阅读 3 分钟
2.1k
在前面的过程中,我们创建了4个project: 服务发现 我们使用Eureka 作为服务发现组件,学习了Eureka Server,Eureka Client的使用。 Eureka Server 加依赖 {代码...} 加注解 {代码...} 改配置 {代码...} 使用Sprint Boot 项目三部曲,我们可以快速添加一个新组件,并正常使用 Nacos Server 这个我没有在项目中实现,但是...

[Spring cloud 一步步实现广告系统] 6. Service实现&Zuul配置&Test

2019-07-29
阅读 8 分钟
2.2k
JPARepository 的默认实现方法,如果我们只是继承了JpaRepository而没有实现具体的操作方法,我们也是可以通过使用它的默认方法来做CRUD操作的,如下:

[Spring cloud 一步步实现广告系统] 5. 投放系统配置+启动+实体类

2019-07-28
阅读 3 分钟
2.1k
其他的数据库对应实体类(AdUnit,AdPlan,AdCreative,AdUnitDistrict,AdUnitHobby,AdUnitKeyword,RelationshipCreativeUnit),大家可以参考上面的例子自己实现,也可以去github上下载源码。

[Spring cloud 一步步实现广告系统] 4. 通用代码模块设计

2019-07-27
阅读 8 分钟
2.5k
一个大的系统,在代码的复用肯定是必不可少的,它能解决: 统一的响应处理(可以对外提供统一的响应对象包装) 统一的异常处理(可以将业务异常统一收集处理) 通用代码定义、配置定义(通用的配置信息放在统一的代码管理中,便于维护和更新) 创建项目 mscx-ad-common POM文件 {代码...} 项目结构 vo (统一响应对象pack...

[Spring cloud 一步步实现广告系统] 3. 网关路由

2019-07-27
阅读 3 分钟
2.4k
Zuul(Router and Filter) WIKI: 传送门 作用 认证,鉴权(Authentication/Security) 预判(Insights) 压力测试(Stress Testing) 灰度/金丝雀测试(Canary Testing) 动态路由(Dynamic Routing) 服务迁移(Service Migration) 降低负载(Load Shedding) 静态响应处理(Static Response handling) 主动/主动交...

[Spring cloud 一步步实现广告系统] 2. 配置项目结构 & 实现Eureka服务

2019-07-25
阅读 7 分钟
2.5k
父项目管理 首先,我们在创建投放系统之前,先看一下我们的工程结构: mscx-ad-sponsor就是我们的广告投放系统。如上结构,我们需要首先创建一个Parent Project mscx-ad 来编写父项目的pom,来管理我们的统一依赖信息。 {代码...} 服务发现 Eureka Eureka Server (提供服务的注册和发现) Eureka Client Service provider...

[Spring-Cloud-Alibaba] Sentinel 规则持久化

2019-07-22
阅读 10 分钟
4.5k
在之前的练习中,只要应用重启,就需要重新配置,这样在我们实际的项目是非常不实用的,那么有没有办法把我们配置的规则保存下来呢?答案是YES,那么接下来,给大家来介绍如何将Sentinel规则持久化。

[Spring-Cloud-Alibaba] Sentinel 整合RestTemplate & Feign

2019-07-19
阅读 5 分钟
5.5k
Sentinel API Github : WIKI Sphu (指明要保护的资源名称) Tracer (指明调用来源,异常统计接口) ContextUtil(标示进入调用链入口) 流控规则(针对来源属性) {代码...} 降级规则 {代码...} Sentinel Annotation 源码:com.alibaba.csp.sentinel.annotation.aspectj.SentinelResourceAspect & com.alibaba.csp.se...