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

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

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

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

SEATA 分布式事务入门DEMO

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

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

2020-01-06
阅读 6 分钟
2.4k
使用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 分钟
3k
上节 我们实现了根据搜索关键词查询商品列表和根据商品分类查询,并且使用到了mybatis-pagehelper插件,讲解了如何使用插件来帮助我们快速实现分页数据查询。本文我们将继续开发商品详情页面和商品留言功能的开发。

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

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

[springboot 开发单体web shop] 6. 商品分类和轮播广告展示

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

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

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

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

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

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

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

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

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

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

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

被辞退员工的一天

2019-08-22
阅读 2 分钟
2.9k
其实,公司在发展的过程中,总会遇到各种各样的问题,无论是管理方面,还是运营方面,如果一旦某一环节出现了问题,当然受伤的肯定是弱小的员工,特别是我们技术小伙伴是最容易被拿来开刀垫背。当遇到这样问题的时候,往往小伙伴会怪罪于公司 ,为什么选择的是我,为什么不是别人?当然我们这次也有。

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

2019-08-20
阅读 2 分钟
2.4k
mscx-ad-db 这个模块主要有2个作用,本身只应该作为数据库脚本管理package来使用,但是我们在生成索引文件的过程中,为了方便,我就直接将导出全量索引的json文件生成也写在了该项目中。 主要目的还是通过flyway进行数据库脚本的管理。

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

[Spring cloud 一步步实现广告系统] 12. 广告索引介绍

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

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

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

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

2019-07-31
阅读 2 分钟
2.3k
在使用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.3k
工作流程 项目依赖 {代码...}

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

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