[dubbo 源码之 ]1. 服务提供方如何发布服务

2020-02-28
阅读 12 分钟
2.2k
服务发布 启动流程 1.ServiceConfig#export 服务提供方在启动部署时,dubbo会调用ServiceConfig#export来激活服务发布流程,如下所示: Java API: // 1. 创建ServiceConfig实例 {代码...} XML {代码...} 查看export源码可知,总共有三种服务导出选项: {代码...} 2.ServiceConfig#doExport 此方法主要是根据设置的属性进...

SEATA 分布式事务入门DEMO

2020-01-15
阅读 11 分钟
2.8k
Simple Extensible Autonomous Transacation Architecture,seata是简单的、可扩展、自主性高的分布式架构

从零开始安装Redis 集群(Linux CenOS7)

2020-01-06
阅读 6 分钟
2.3k
使用ISO安装CentOS7虚拟机 配置静态IP(参考Mac VMware Fusion CentOS7配置静态IP) 安装vim {代码...} 安装jdk 使用FileZilla上传jdk到Linux系统的/home/software {代码...} 配置java环境变量 {代码...} 安装Redis https://redis.io/download 下载稳定版本 使用FileZilla上传redis到Linux系统的/home/software 解压压缩...

[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] 6. 商品分类和轮播广告展示

2019-11-19
阅读 15 分钟
4.6k
从上图我们可以看出,商品的分类其实是有层级关系的,而且这种关系一般都是无限层级。在我们的实现中,为了效果的展示,我们仅仅是展示3级分类,在大多数的中小型电商系统中,三级分类完全足够应对SKU的分类。

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

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

[springboot 开发单体web shop] 3. 用户注册实现

2019-11-07
阅读 9 分钟
2.2k
作为一个现代化电商平台,什么最重要呢?of course 是用户,广大用户群体是支持我们可持续发展的基石,顾客是上帝, 虽然在当今上帝已经不被重视了,特别是很多的平台对于老用户就是恨不得赶紧Out...但是用户量是一切的基础,那我们就开始创建我们的上帝吧!

[springboot 开发单体web shop] 2. Mybatis Generator 生成common mapper

2019-11-06
阅读 9 分钟
2.4k
在我们开启一个新项目的研发后,通常要编写很多的entity/pojo/dto/mapper/dao..., 大多研发兄弟们都会抱怨,为什么我要重复写CRUD? 我们为了避免编写一些不必要的重复代码,这节给大家介绍介绍使用一个开源工具,来帮助我们从这种简单枯燥的编码中解救出来。隆重有请: MyBatis通用Mapper4

[springboot 开发单体web shop] 1. 前言介绍和环境搭建

2019-11-04
阅读 5 分钟
2.2k
springboot 本身是为了做服务化用的,我们为什么要反其道使用它来开发一份单体web应用呢?在我们现实的开发工作中,还有大量的业务系统使用的是单体应用,特别是对于中小型团队来说,在项目开发之初选择服务化开发是得不偿失的,因为对于此类团队,势必所有的工作都是需要我们开发人员来做的,例如:

[插件化开发] 1. 初识OSGI

2019-10-15
阅读 5 分钟
4.3k
当前product是以solution的方式进行售卖,但是随着公司业务规模的快速夸张,随之而来的是新客户的产品开发,老客户的产品维护,升级以及修改bug,团队的效能明显下降,为了解决此类问题,必须站在公司战略的统一高度来重构系统。

[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 一步步实现广告系统] 12. 广告索引介绍

2019-08-06
阅读 1 分钟
2.4k
在我们广告系统中,为了我们能更快的拿到我们想要的广告数据,我们需要对广告数据添加类似于数据库index一样的索引结构,分两大类:正向索引和倒排索引。

[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 一步步实现广告系统] 10. 使用Ribbon 实现微服务调用

2019-07-31
阅读 2 分钟
2.2k
在使用Ribbon调用广告投放系统API之前,我们需要先创建2个VO对象,AdPlanVO,AdPlanGetRequestVO. {代码...} 在AdSearchApplication启动类中,添加RestTemplate客户端。 {代码...} 创建一个controller,来测试调用广告提供系统的API {代码...}

[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.3k
JPARepository 的默认实现方法,如果我们只是继承了JpaRepository而没有实现具体的操作方法,我们也是可以通过使用它的默认方法来做CRUD操作的,如下:

[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 一步步实现广告系统] 1. 业务架构分析

2019-07-26
阅读 1 分钟
4.2k
什么是广告系统? 主要包含: 广告主投放广告的《广告投放系统》 媒体方(广告展示媒介-<地铁广告屏幕>)检索广告用的《广告检索系统》 广告计费系统(按次,曝光量等等) 报表系统 Etc. 使用技能栈 JDK1.8 MySQL 8+ Maven 3+ Spring cloud Greenwich.SR2 Eureka Zuul / gateway Feign ... Spring boot 2.1.5 Kafk...

[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...