刷新
UML建模、设计原则

博主头像 # UML统一建模语言 定义: 用于软件系统设计与分析的语言工具 目的: 帮助开发人员更好的梳理逻辑、思路 官网: https://www.omg.org/spec/UML 画图工具可以用在线网址:https://app.diagrams.net/ 或者是 https://www.processon ...

醒醒!你不是真的需要微服务

博主头像 2020 年,很多技术人可能都已经迷醉在了微服务的成功故事中,但现实很骨感,微服务也不是“灵丹妙药”。本文想给现阶段“狂热”的微服务泼泼冷水、降降温,也许你就会发现,你并不是真的需要微服务。 2020 年,如果再讲什么是微服务,已经落伍了,毕竟微服务的成功故事已经开始在业界广为流传了。但是你真的需要... ...

初识设计模式 - 备忘录模式

博主头像 简介 备忘录设计模式(Memento Design Pattern)也叫作快照(Snapshot)模式,主要用于实现防丢失、撤销、恢复等功能。 其定义是,在不违背封装原则的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态,以便之后恢复对象先前的状态。 典型实现 首先,定义一个备忘录 Mem ...

第1章 软件架构与需求分析方法

博主头像 学习目标 能够掌握系统、子系统、模块、组件、服务、框架、架构等概念的含义 能够知道单体架构、分布式架构、微服务架构的适用场景、优势和劣势 能够知道微服务架构常见技术框架 能够了解组件化、服务化产生的原因、优势和问题,初步具备中台概念 了解常见的需求问题 掌握一个需求包含的要素 掌握如何做需求分析 1 ...

Python基础之面向对象:3、三大特征-继承与派生

博主头像 面向对象 一、三大特征之继承 python三大特征: 封装、继承、多态 三者中继承最为核心,实际应用多,感受较为直观 封装和多态略微抽象 1、继承的概念 继承的含义: ​ 在现实生活中,继承表示人与人之间资源的从属关系 ​ 例如:儿子继承父亲 ​ 在编程的世界中,继承表示类与类之间的资源从属关系 ​ ...

01 设计模式入门

一 什么是设计模式 设计模式是一套反复使用的代码设计总结。使用设计模式是为了可重用代码、保证代码可靠性、程序的重用性。熟悉设计模式能更容易看懂框架源码,更好的设计自己的系统。 二 设计模式分类 设计模式分为创建型、结构型和行为型三种模式。 三 设计模式的六大原则 开放封闭原则:尽量通过扩展软件实体来 ...

做一个不崩溃的核酸系统有多难?

博主头像 热度已经过了,但还是觉得有必要从架构设计的角度来讨论一下此事。并用以往我的经验来设计一套负载能力更好一些的系统。 先说一下基本的架构思路: 最大限度的避免计算,静态化 不用数据库,更新类操作使用APPEND模式的文本文件 流程最短,最好是客户端访问的第一台服务器就能完成全部工作 善用CDN 客户端负 ...

Python基础之面向对象:1、面向对象与编程思想

博主头像 一、人狗大战 1、需求 用代码模拟人、狗打架的小游戏 人和狗种类不同,因此双方的属性各不相同 推导一: 人和狗各有不同属性 使用字典方式储存属性较为方便,并可储存多种属性 # 1、在字典内储存‘人’属性 person = { 'name': '阿拉蕾', 'age': 18, 'gender': ' ...

apijson 初探

博主头像 apijson 初探 本文试着用 5W1H 方式切入,试图快速建立自己对 apijson 的整体认知,所以这不是一趟快速入门的 demo 之旅,而是显得比较务虚的探索式知识体系整合过程。 持续更新中... 1、Why 前后端开发过程中各种痛点: 开发流程繁琐、周期长 前端/客户端与后端各种扯皮 文档 ...

设计模式之禅01单一职责原则

单一职责原则 1.1 我是“牛”类,我可以担任多职吗 单一职责原则,英文名称是Single Responsibility Principle,简称是SRP,定义是应该有且仅有一个原因引起类的变更。 什么是类的职责,以及怎么划分类的职责? 举例:rbac模型 这个接口设计的存在问题:用户属性和用户行为 ...

JQueue一个实现Outbox模式的库

博主头像 为了提高系统吞吐率,也就是提高生产效率,核心观点如下,系统设计也是如此 在微服务或任何其他基于事件的架构(event-driven-architecture)中,在一些用例中,一个服务可能需要我们对他们自己的本地数据库进行修改,同时发布一个事件。然后,该事件会被其他服务所消费。为了拥有一个一致的软件 ...

京东云开发者|探寻软件架构的本质,到底什么是架构?

博主头像 不论是开发人员还是架构师,我们都一直在跟软件系统打交道,架构是在工作中出现最频繁的术语之一。那么,到底什么是架构?你可能有自己的答案,也有可能没有答案。对“架构”的理解需要我们不断在实践中思考、归纳、演绎,形成自己的认知。 1 到底什么是软件架构 ? 定义 ”架构是什么“ 是件非常困难的事情,不同的 ...

hyperf/go/springboot通过jsonrpc通信

一、背景 随着用户的增长和业务的增多,单节点服务已经满足不了需求,用hyperf对主业务进行了重构。 hyperf是一个后现代的php框架,基于php+swoole,支持协程,解决了php让人诟病的性能问题和多线程支持不够的问题。官方也提供了各种组件,比如 配置中心、定时任务、消息队列和微服务,对于 ...

聊一聊分布式锁的设计模型

博主头像 什么是分布式锁?对于这个问题,相信很多同学是既熟悉又陌生。随着分布式系统的快速发展与广泛应用,针对共享资源的互斥访问也成为了很多业务必须要面对的需求,这个场景下人们通常会引入分布式锁来解决问题。我们通常会使用怎么样的分布锁服务呢?有开源的 MySQL,Redis,ZooKeeper,Etcd 等三方... ...

Struts2架构图解

#Struts2架构图解 ##前言 公司的一些老项目里偶尔还能碰到基于struts框架编写的工程,但是在Spring流行的现在,新的项目开发已经不会去使用struts框架了(很多老的框架技术就已经不再被企业使用啦)。 本文只是浅显地对struts做一个图解说明,仅代表个人对于该框架的理解。 ##简单 ...

一种基于柔性事务的分布式事务解决方案设计探究

博主头像 1 背景 市面上常见的有,2pc/3pc、tcc、saga等常见的分布式事务解决方案,但是实际实施起来框架比较重,设计开发比较繁琐,不易于快速开发上手。本文提供一种基于柔性事务设计的简单易上手的分布式事务设计方案,用于解决常见的分布式事务常见场景。 2 常见分布式事务场景 2.1 同步场景 常见的场 ...

说说 Redis pipeline

博主头像 更多技术文章,请关注我的个人博客 www.immaxfang.com 和小公众号 Max的学习札记。 Redis 客户端和服务端之间是采用 TCP 协议进行通信的,是基于 Request/Response 这种一问一答的模式,即请求一次响应一次。 普通模式 我们先来看下普通模式下,一条 Redis ...

<1···4950