姬望 + 关注
阿里巴巴中间件高级技术专家

IT人员修炼之路

发布时间:2016-11-09 09:55:01 浏览:2121 评论 :0

写了10年代码,混了10年,总要记录一点什么,来阿里之前趁着有空,简单总结了一下,希望有缘的年轻人看到能对你有所帮助,也希望大家都来喷一下我这个混子。 感悟: 任何行业想走到顶端都要付出超出常人的努力,it尤为明显。进来了就要趁早好好想一想,这是不是你要走的路。 我

编程语言 架构 程序员 阿里技术协会 http 人生 修炼

架构师速成-架构目标之伸缩性\安全性

发布时间:2015-09-16 09:00:00 浏览:1108 评论 :0

为满足伸缩性,所需的架构模式包含: 分布式,这个前面有单独的章节进行了讲解,分布式是互联网时代的主旋律。 负载均衡,前面已经有讲解。 服务拆分,按照业务进行系统服务的拆分并单独部署。 为满足伸缩性,需要的支撑系统: 运维系统: 自动扩容,缩容 监控系统 监控流量,确定何时伸缩 为满足安全性,所需的架构模式包含: 数据加密,密码的加密存储

分布式 安全 架构 监控 加密 防火墙 互联网 负载均衡 存储

架构师速成-架构目标之可用性

发布时间:2015-09-13 21:34:00 浏览:1144 评论 :0

服务器等,从而共同完成工作任务。各种负载均衡的软硬件有很多,我们可以单独讲解一下。 配置中心,原来单一节点的配置,被类似zookeeper的多节点配置中心取代。 流量控制,流量控制是保证大流量下系统可用性的重要手段,当系统流量不足以支撑所有流量时,只保留合理的流量处理。其他流量直接丢弃,否则系统会被压垮,造成雪崩。 功能降级,另外大流量情况下,有些无关紧要的功能可以暂时降级,后期通过数据

分布式 架构 监控 配置 负载均衡 解决方案 分布式系统 zookeeper 异地

架构师速成-架构目标之正确性

发布时间:2015-09-08 19:37:00 浏览:1246 评论 :0

本系统架构模式: 统一异常 统一异常处理是保证程序正确性的第一步,这是第一个架构模式。具体如何实现,详见前面的文章。 日志 日志也是保证程序正确的一大手段,虽然是在错误出现后,日志才会记录。但是日志是快速确认问题,并分析出隐藏问题的重要手段。 关键点 日志文件按照级别进行区分,将错误和普通调试日志分开 日志文件滚动方式,可以按天及按大小滚动,定时清理 日志级别可以实时调

架构 监控 性能 日志 模块 单元测试

架构师速成-架构的目标

发布时间:2015-09-07 11:39:00 浏览:1039 评论 :0

架构的目标为了实现以下特性: 正确性 系统首先需要正确,运行稳定 可用性 软件系统对于用户的商业经营和管理来说极为重要,因此软件系统必须非常可靠,一般99.99%是一个比较基本的要求。 快速开发 互联网目前是一个快鱼吃慢鱼的时代,已经不是大鱼吃小鱼了。因为小鱼在一夜之间就长大了,把大鱼吃掉了。诺基亚就是明证,facebook就是明证。 良好体验 良好的体验对用户的吸引

安全 架构 性能 用户体验 高性能

架构师速成-架构体系

发布时间:2015-09-05 20:24:00 浏览:1366 评论 :0

经过这段时间的反思和整理,终于对架构有了一个较为明确的理解。架构是产品从无到有以及慢慢壮大过程中所需要的全部技术体系总称,架构过程: 配置、编码、测试、运维、监控分析、安全、运营等一系列技术体系的选型、取舍 技术选型基础上进行规划、设计、实现、迭代、制定相关规范 相关技术及规范运用到产品开发的整个过程中,并在产品迭代过程中对架构进行迭代优化 架构不止包含技术的框架,比如有人用

安全 架构 监控 消息队列 模块 配置 测试 运营 数据同步 容灾 权限管理 自动化测试 单元测试 自动化运维 开发框架

程序员都很闷骚

发布时间:2015-08-14 08:25:00 浏览:853 评论 :0

假定: 程序员都是闷骚的 程序员有独特的搞笑方式 程序员80%都不满于现状,需要发泄 程序员都有一点色 所以: 子龙左手青釭剑,右手亮银枪,跨下白龙马,一身白盔白甲,帅到爆炸!如今我们左手xmind,右手eclipse,uml在脚下,也是无比潇(ku)洒(bi) 他们是喜欢的 亚美蝶,揍我不行,揍我小舅子可以。 他们是喜欢的 老板说:哎呀,我们方向错了,我们重新搞一个

程序员 eclipse 测试 UML

架构师速成-有关架构的思考

发布时间:2015-08-11 08:55:00 浏览:863 评论 :0

架构是什么?架构的目标是什么?如果解决这2个问题,可能我能更好的梳理杂乱的架构理论。经过2天的思考,总算有了一点眉目。我们从一个产品的本质来说,追本朔源,自上而下: 大概就是这样的,当然架构不止需要解决这些问题,本产品只是其中一个部分,要支撑一个web产品还需要依赖很多的外部公共系统,对这些系统整合也算作架构的范畴。 架构,又名软件架构,是有关软件整体结构与组件的抽

架构 算法 软件架构 同步 开发环境 数据结构

架构师速成8.3-可用性之分库分表

发布时间:2015-08-10 08:00:00 浏览:1094 评论 :0

有状态分布式,涉及的知识就比较多了,不过我们可以拿几个现实的例子由浅入深的来理解。 数据库的分库分表 假设你是一个开发负责人,开始使用单机的数据库,突然一天数据库硬盘挂掉了。你没有做备份,然后就没有然后了。 进入第2个公司,你意识到备份的重要性,每天定时备份到另一台机器,突然有一天,数据库硬盘挂掉了。你心想幸好我有备份,然后巴拉巴拉的恢复起来,用了2个小时。老板说不错,但是—

分布式 架构 NOSQL 高可用 数据库 数据迁移 同步 数据节点

架构师速成-如何高效编程

发布时间:2015-08-08 18:07:00 浏览:1113 评论 :0

今天看见有个csdn的征文大赛,谈谈如何高效编程,正好之前有些感触,先沉淀下来。 引子 赵云大喝一声,挺枪骤马杀入重围,左冲右突,如入无人之境。那枪浑身上下,若舞梨花;遍体纷纷,如飘瑞雪。 赵云是所有历史人物中我最喜欢的一个,如果放到现代,他走了it的道路,一定可以成为一个编程高手。为什么? 其实古时打仗也是一门技术活,需要有勇有谋,跟it没有什么太大的区别。打

架构 面向对象 测试 编程 单元测试

架构师速成8.3-可用性之分布式

发布时间:2015-08-08 09:45:00 浏览:897 评论 :0

分布式算是软件界发展的一个里程碑,它开辟一个新的软件时代,其他的溢美之词我就不再乱说了。 分布式按照我的观点,应该分为有状态和无状态2种: 有状态 分布式数据库 分布式存储 无状态 分布式计算 分布式web系统 当然分布式尽量做成无状态的分布式,但是存储最终因为最终存储的是有状态的数据,所以不得不变的有状态。当然web系统也可以是有状态的,但是最好做成无

分布式 架构 web 集群 Cache 可扩展性 负载均衡 解决方案 分布式计算 分布式系统 分布式数据库 分布式存储 存储 cookie 数据存储

架构师速成8.3-可用性

发布时间:2015-08-07 09:18:00 浏览:874 评论 :0

作为一个软件系统可用性是第一位的,如果一个系统不可用,你其他的地方做的再怎么好,然并卵。 一般什么情况下软件会不可用: 我方发生故障,导致系统不可用,当然会出现单机的不可用及n多机器群的全部不可用。 程序故障 功能错误、程序退出 系统故障 CPU超负荷、内存超负荷、网络超负荷 物理故障  机器死机 断电 断网 不可恢复故障 地震、海啸等等 客户方也会发生相同故障,

分布式 架构 监控 负载均衡 解决方案 单点故障 数据同步 CPU 单元测试 异地

架构师速成8.3-架构师必须要了解的规则

发布时间:2015-08-07 09:17:00 浏览:1045 评论 :0

作为一个架构师,有些规则是必须要掌握的,这就想软件的公理,如果你学物理不知道牛顿定律,那就不要学了。在软件行业也有类似的东西,我称之为软件定律。例如: ACID,CAP,BASE ACID 传统数据库系统中,事务具有ACID 4个属性 (1)原子性(Atomicity):事务是一个原子操作单元,其对数据的修改,要么全都执行,要么全都不执行。 (2)一致性

分布式 架构 高可用 数据库 cap Availability 分布式系统

架构师速成6.15-开发框架-单点登录

发布时间:2015-08-06 07:10:00 浏览:976 评论 :0

单点登录应该归为架构的部分了,但是一般网站在开始的时候最好有单点登录的思想,防止后期再做大量的修改。而且单点登录对于开发人员来说并没有增加太多额外的工作量,所以提前讲一下对大家都是好的。 先说一下单点登录的机制(摘自百度百科,给我广告费): 当用户第一次访问应用系统1的时候,因为还没有登录,会被引导到认证系统中进行登录;根据用户提供的登录信息,认证系统进行身份校验,如果通过

架构 开发框架

架构师速成6.14-开发框架-异常处理

发布时间:2015-08-05 08:52:00 浏览:806 评论 :0

异常为什么需要单独一节来讲解呢?因为异常是软件设计里一项需要架构者自己构思处理的一个特殊部分。一般的框架没有提供统一的处理方式,而且会被很多同学忘记处理,或者是比较粗糙处理掉。想一想有很多网站出错时,用户会看到一大段的英文异常,甚至执行的sql都包含在里面,你会不会觉得很不专业呢? 首先异常应该分类,确定异常分类至关重要,这是后期进行不同处理的基础: 业务异常,是用户在执行业

架构 日志 软件设计 ajax handler 开发框架

架构师速成6.13-开发框架-前后结合

发布时间:2015-08-04 08:14:00 浏览:880 评论 :0

前面说完了前端和后端的封装,本节再单独讲解一下哪些地方需要前后结合。 AJAX的前后端结合: 定义统一的返回消息体,{isError:true/false,message:’需要返回的消息’,data:{返回的数据},postAction:{后续的动作}} 根据消息体的返回,进行不同类别的展示,例如:错误提示,加载页面片段,数据刷新,页面跳转,或者自定义后续处理 服务端能自动

架构 程序员 ajax page 开发框架

架构师速成6.11-开发框架-后端封装思路

发布时间:2015-07-31 07:46:00 浏览:1330 评论 :0

要做一个好的开发框架并不是直接找一个现成的Spring就ok了,这个对于一般新手来说学习难度还是有点高。另外Spring还是一个通用性的框架,我们需要针对业务的定制化封装。我以java为例讲解一下后端需要做什么: 确定层数结构 parent common test dao service-common service web-common web parent统一引入的

架构 java 数据库 spring 测试 单元测试 开发框架 service

架构师速成6.9-如何写好代码

发布时间:2015-07-30 18:38:00 浏览:907 评论 :0

读过很多代码,有些人写了5年以上的代码,但是代码烂到直接让人无从读起。有人写的代码让人读的赏心悦目,为什么人与人之间的差距这么大呢? 看来如何写好代码还是一件很值得一说的事情。 关键思想: 人写代码是用来给别人读的,而不是给机器执行的。写代码就应该像写小说一样,让人读的轻松愉快。 软件的生命周期中,维护周期占1半以上,所以不看避免要有人来改动你的代码 你如果更换工作

架构 编码规范

架构师速成6.8-设计开发思路-领域驱动

发布时间:2015-07-30 18:28:00 浏览:1022 评论 :0

领域驱动设计简称DDD,很好的名字,先来普及一下相关的名词缩写: 测试驱动设计 TDD,行为驱动设计 BDD,面向对象设计 OOD,面向过程设计 OPD。 设计思路和方法是一项专门的技能,区别于设计模式,编程语言。UML是设计的工具,设计方法是设计的灵魂,而且设计方法并没有好坏之分。关键是你需要掌握各种设计方法,在做项目时信手拈来,才是真正的高手。为什么要讲领域驱动设计,因

架构 面向对象 软件设计 淘宝 领域模型

架构师速成6.7-设计开发思路-uml

发布时间:2015-07-29 18:25:00 浏览:1016 评论 :0

uml是什么东西?统一建模语言,一门语言,是用来进行软件设计的一门语言。 其实一门语言的诞生并不伟大,让大多数人都使用才足够伟大。uml就是一门伟大的语言,因为目前软件设计的唯一语言就是它。 UML其实还是比较简单的,就那么几个图形,那么几种模式,但是因为他是唯一的语言,所以有设计能力的人都能很容易看懂你说的什么,这就是他的伟大之处。 我说一下在软件设计中最常用的几个

架构 面向对象 软件设计 序列 UML 存储

3

lamper 2017-06-01 评论了:

架构师速成4-幼儿园