由于课程是边制作边发放,因此大纲也是逐步更新,跟已经推出的视频同步
第01节课:整体课程内容概览
-----------------------以下为Maven补充和Git部分------------------------------------------------------------------
第02节课:Maven补充:分模块、分工程管理
第03节课:Maven补充:多模块,多Web应用,合并成一个War包
第04节课:Git快速上手:Git简介、基本原理、安装、Git服务器配置、插件Egit
第05节课:Git快速上手:TortoiseGit的本地使用
第06节课:Git快速上手:Egit的本地使用
第07节课:Git快速上手:TortoiseGit和Egit的远程使用,以及冲突解决,包括:内容冲突、树冲突、逻辑冲突
-----------------------以下为基本业务功能块构建部分------------------------------------------------------------------
第08节课:要完成的基本业务功能介绍、基本的数据字典
第09节课:搭建基础的开发环境:Eclipse+Maven+Git
第10节课:使用Spring+Mybatis来实现Customer的DAO部分
第11节课:Mybatis的分页实现,DAO的简单测试
第12节课:Service部分的实现,以及基本的基础模块开发
第13节课:基于Spring MVC实现Web层开发
第14节课:基本的新增和列表页面,还有分页的tag开发和测试
第15节课:带查询条件的分页、修改和删除页面的开发和测试
第16节课:查询页面、Mybatis动态查询的实现,Json的自动拼装
第17节课:提炼公共的Webmodel,开始X-gen生成的模板制作,做DAO部分的模板
第18节课:制作X-gen生成需要的service、web层需要的模板
第19节课:制作X-gen生成需要的数据,以及相应的Visitor
第20节课:制作X-gen生成需要的Action,还有部分的Visitor
第21节课:通过X-gen生成商品模块,并调整整个生成的模板和程序
第22节课:通过X-gen生成购物车模块,并调整整个生成的模板和程序
第23节课:通过X-gen来生成订单主模块、明细模块,还有库存管理模块
第24节课:给客户管理模块加入ehcache,然后把现有的工程加入到Git中
第25节课:实现前端的业务登录、首页等功能
第26节课:测试并调整登录的业务功能,使用Cookie来保存用户信息
第27节课:实现index功能的开发
第28节课:Index和商品详细描述页面实现,购物车的实现
第29节课:完成下订单和修改库存的功能
第30节课:把基础的业务应用配置并部署到Linux服务器上去
-----------------------以下为Nginx部分------------------------------------------------------------------
第31节课:Nginx简介、安装和基本运行
第32节课:Nginx的进程结构、基本配置等
第33节课:Nginx常用核心模块指令的功能和配置使用
第34节课:Nginx的Http模块部分的功能和配置使用
第35节课:Nginx的Location区段的功能和配置使用
第36节课:Nginx的反向代理模块的功能和配置使用
第37节课:Nginx结合实际应用,来实现反向代理和动静分离的功能
第38节课:Nginx的负载均衡模块,以及结合实际应用的配置
第39节课:Nginx的Rewrite模块的配置和使用
第40节课:Nginx更多模块的基本功能和配置,常见功能的配置示例
第41节课:Nginx的配置优化以及使用建议
第42节课:应用上Nginx过后的体系结构,以及在更大访问量下,体系结构如何变化
-----------------------以下为Varnish部分------------------------------------------------------------------
第43节课:Varnish简介、安装和基本使用
第44节课:VCL简介、基本语法和基本配置使用,包括负载均衡的配置使用
第45节课:VCL来配置实现健康检查、ACL访问控制等功能
第46节课:Grace模式和Saint模式的理解和应用
第47节课:VCL常用的函数和常用的Http头
第48节课:VCL的子程序,Ation和理解Request流程
第49节课:VCL的变量,常见的VCL应用片断
第50节课:使用CLI来管理Varnish,掌握如何清除缓存,varnishadm命令
第51节课:Varnishd命令和运行期参数,理解参数和选项的功能
第52节课:Varnish的日志操作和Varnish的共享内存:Varnishlog、Varnishtop、Varnishhist、Varnishsizes、Varnishnsca、Varnishreplay
第53节课:规划Varnish的缓存大小;Varnishstat统计信息;提高Varnish的命中率
第54节课:Varnish的性能调优和基本的配置使用建议
第55节课:把Varnish和基本应用,还有Nginx组合起来使用
第56节课:基本的性能测试;Varnish的监控和初步优化
第57节课:应用上Varnish后的体系结构,以及体系结构的演变
-----------------------以下为Memcached部分------------------------------------------------------------------
第58节课:Memcached简介、缓存的含义、安装、基本配置、启动和基本使用
第59节课:Memcached基本的工作原理、两阶段哈希;Memcached的操作命令:set、add、replace、append、prepend、cas、get 、 gets、delete、incr/decr等
第60节课:stats命令、stats sizes命令、flush_all命令、version命令、stats settings、stats items、stats slabs区块统计等
第61节课:理解Memcached的数据存储方式,理解Slab Allocator的方式、理解新建Item分配内存过程
第62节课:内存分配的Chunk、Slab分配演示、Memcached的数据存储方式的缺点;理解Memcached的数据过期方式:延迟/惰性 过期,LRU,懒惰删除机制
第63节课:Memcached的Java客户端开发、Memcached和Spring集成开发
第64节课:理解Memcached的分布式方式、分布式中根据余数计算分散的方式、一致性Hash算法、虚拟节点
第65节课:Memcached内存调优建议,调优目标、调优方法,常见问题的解决,使用Memcached-tool来辅助调优
第66节课:Memcached的限制和使用建议,Memcached的典型适用场景,不适合使用Memcached的场景;Memcached的批量导入导出
第67节课:分析到底把哪些内容放到Memcached里面进行缓存,Memcached结合业务功能进行开发
第68节课:继续Memcached结合业务功能进行开发和测试
第69节课:Nginx+Varnish+基本业务功能+Memcached结合开发使用,进行基本的性能测试,Memcached的监控和初步优化
第70节课:现有的系统,应用上Memcached后的体系结构,思考体系结构如何演变
-----------------------以下为ActiveMQ部分------------------------------------------------------------------
第71节课:ActiveMQ简介、功能和特点;消息中间件;ActiveMQ安装和基本使用;消息收发HelloWorld
第72节课:JMS基本概念,PTP和Pub/Sub域、JMS的消息结构:消息头,属性和消息体
第73节课:JMS的可靠性机制、消息的接收确认、持久化、过期、优先级、临时目的地、持久订阅本地事务等;PTP模型;Pub/Sub模型
第74节课:JMS的API结构,一个JMS应用开发的基本步骤;代码示例非持久的Topic消息收发;代码示例持久的Topic消息收发
第75节课:Broker的启动方式,内嵌到Java中启动Broker,利用Spring集成启动Broker
第76节课:ActiveMQ结合Spring开发:环境设置、Spring配置、Queue消息收发;Topic消息收发;ActiveMQ结合Spring开发最佳实践和建议
第77节课:连接到ActiveMQ,ActiveMQ支持的传输协议和配置:TCP、NIO、UDP、VM、SSL、HTTP/Https等协议
第78节课:ActiveMQ的消息存储持久化;KahaDB的方式、AMQ的方式、JDMC的方式、Memory的方式
第79节课:在一台服务器上启动多个Broker;ActiveMQ的静态网络链接;Static networkConnector的基本原理;networkConnector配置的可用属性
第80节课:演示在static桥接下,多线程的consumer访问集群,消费消息的不均衡性;
第81节课:理解丢失的消息这种场景,配置和演示static集群下的消息回流功能
第82节课:容错的链接,Failover协议,可用的配置参数;ActiveMQ的动态网络链接:多播协议multicast,Discovery协议,Peer协议,Fanout协议
第83节课:ActiveMQ的集群:Queue的消费者集群、Broker集群、Master Slave(基于共享储存的、JDBC实现的、复制LevelDB的方式)
第84节课:Destination高级特性:通配符、组合队列、Configure Startup Destinations、删除不活动的Destinations、Destination Options
第85节课:Destination高级特性:虚拟Destinations、虚拟主题、镜像队列、Per Destination Policies
第86节课:Message Dispatch高级特性:消息游标(Store-based、VM、File-based)、异步发送
第87节课:Message Dispatch高级特性:Dispatch Policies(严格顺序分发策略、轮询分发策略)
第88节课:Message Dispatch高级特性:Optimized Acknowledgement、生产者流量控制
第89节课:Message高级特性:Message Properties、Advisory Message、延迟和定时消息投递
第90节课:Message高级特性:Blob Messages、Message Transformation
第91节课:Consumer高级特性:独有消费者、消费者异步分发、优先级、管理持久订阅者、消息组
第92节课:Consumer高级特性:消息选择器、重投递策略、慢消费者处理
第93节课:监控和管理Broker、集成ActiveMQ和Tomcat
第94节课:什么时候使用ActiveMQ、ActiveMQ优化和使用建议
第95节课:应用ActiveMQ:分析到底把哪些功能用ActiveMQ来辅助实现,ActiveMQ结合业务功能的开发第一部分
第96节课:ActiveMQ结合业务功能的开发第二部分,并测试相应的功能
第97节课:ActiveMQ结合业务功能的开发第三部分,并测试相应的功能,然后上传到服务器上
第98节课:Nginx+Varnish+基本业务功能+Memcached+ActiveMQ组合运行测试
第99节课:基本的性能测试分成两种,一种是Nginx+Varnish+基本业务功能+Memcached,另外一种是Nginx+Varnish+基本业务功能+Memcached+ActiveMQ
第100节课:应用上ActiveMQ后的体系结构,以及今后系统架构的演变
-----------------------以下为MongoDB部分------------------------------------------------------------------
第101节课:本部分课程总体概览,MongoDB简介:是什么、NoSQL的优缺点、CAP定理和BASE原则、MongoDB的特点
第102节课:MongoDB安装和基本使用,MongoDB启动参数说明
第103节课:MongoDB基本概念:数据库、集合、文档、_id、基本数据类型等
第104节课:MongoDB增删改操作第一部分
第105节课:MongoDB增删改操作第二部分
第106节课:MongoDB查询操作第一部分:指定需要返回的键、按条件查询,包括多种操作符、正则表达式
第107节课:MongoDB查询操作第二部分:查询数组、查询内嵌文档、分页、排序、游标、存储过程等
第108节课:聚合框架第一部分:概念、管道操作符($match、$project、$group、$sort、$limit)
第109节课:聚合框架第二部分:$group、$unwind、$sort等的操作使用,MapReduce的开发使用
第110节课:聚合框架第三部分:更多MapReduce可选的键、聚合命令group的使用
第111节课:理解MongoDB的文档存储机制
第112节课:MongoDB的索引第一部分:创建、修改、删除索引,以及分析使用索引对查询的影响
第113节课:MongoDB的索引第二部分:hint、强制全表扫描、唯一索引、复合索引、索引的集合等
第114节课:Capped集合:功能、基本原理、创建和使用的语法;用GridFS存储文件:功能介绍、基本操作、基本原理
第115节课:MongoDB的副本集第一部分:副本集简介、创建副本集、副本集的使用、rs函数、rs.status的说明
第116节课:MongoDB的副本集第二部分:修改副本集配置、副本集中主节点的确定、成员配置选项——选举仲裁者、优先级、隐藏成员、延迟备份节点、创建索引
第117节课:MongoDB副本集的基本原理:操作日志oplog、初始化同步的步骤、处理陈旧数据、心跳、成员状态、回滚等
第118节课:MongoDB副本集的管理和MongoDB主从复制:以单机模式启动成员、副本集的配置、创建比较大的副本集、强制重新配置、把主节点变为备份节点等等;MongoDB主从复制
第119节课:MongoDB的分片第一部分:分片功能介绍、分片和复制、Mongos、配置服务器、启动mongos进程、将副本集转换成为分片
第120节课:MongoDB的分片第二部分:数据分片、指定分片的集合、分片的详尽示例
第121节课:MongoDB的分片第三部分:块、拆分块、均衡器、限制分片大小、集群对数据的影响、理解MongoDB分片数据的分配方式 —— 一分片多区间等
第122节课:MongoDB分片的片键选择:片键选择的重要性、片键规则、片键的几种类型:小基数片键、升序片键、随机分发的片键、基于某个业务的片键,以及好片键的建议
第123节课:MongoDB分片的管理:列出所有的Shard、查看分片信息、查看集群信息摘要、检查配置信息、删除分片等
第124节课:监控应用状态:查看正在进行的操作、系统分析器system.profile;用户身份验证;
第125节课:备份和恢复,以及 数据导入导出
第126节课:Java操作MongoDB:获取驱动、连接MongoDB服务、连接池的配置、操作MongoDB
第127节课:MongoDB和Spring集成开发:集成、使用MongoTemplate来进行数据的CRUD
第128节课:MongoDB应用建议及最佳实践
第129节课:分析应用MongoDB的功能,MongoDB结合到应用的开发实现一
第130节课:MongoDB结合到应用的开发实现二,并上传服务器测试
第131节课:应用上MongoDB后的体系结构变化、今后架构的继续变化
-----------------------以下为MogileFS部分------------------------------------------------------------------
第132节课:MogileFS简介、是什么、有什么、能干什么,以及特点和适用性;
第133节课:通过源码安装MogileFS、基本的配置等
第134节课:理解MogileFS的基本概念、使用方式和各种命令
第135节课:理解MogileFS,包括:高层流程、存储节点、表说明
第136节课:MogileFS的Java客户端开发,包括:基本的Java客户端开发,和Spring集成开发
第137节课:基于MogileFS的小应用示例第一部分:构建好整个工程的开发环境和准备
第138节课:基于MogileFS的小应用示例第二部分:使用x-gen来生成新的模块,并调试通过CRUD的功能
第139节课:基于MogileFS的小应用示例第三部分:使用Spring web MVC来实现文件的上传下载
第140节课:基于MogileFS的小应用示例第四部分:把上传的文件保存到MogileFS里面,并能从里面获取到文件
第141节课:MogileFS和Nginx的集成,MogileFS和Memcached的集成
第142节课:应用上MogileFS之后,系统体系结构的变化,以及文件更多,访问更频繁的情况下,体系结构的变化
-----------------------以下为阶段一最后的小结和整体部署部分------------------------------------------------------------------
第143节课:阶段一小结,阶段一构建的基本架构,部署的环境介绍和部署计划
第144节课:整理阶段一的代码和配置,把整个工程打成一个可以部署的war,并发布到服务器上
第145节课:配置服务器端的nginx和varnish,配置MogileFS,并测试通过
第146节课:配置Memcached和MongoDB,并测试运行通过
第147节课:配置ActiveMQ,并通过web应用调用,测试运行通过
第148节课:阶段一之后的发展方向,以及在更高的并发,更大的数据量的情况下,整个系统架构的演变思路
.......Over,主体课程按时制作并发放完毕!
本课程为架构技术类实战课程,建议你做到如下几点:
1:掌握基于框架的Java Web应用开发,比如:Spring MVC、Spring、Mybatis/Hibernate等的开发
2:最好不要跳跃学习,尽量按照课程安排的顺序循序渐进。
如果想要先学习某单个知识的朋友,也尽量从这单个知识的开头开始学习
3:积极跟着视频去分析和思考,尤其要理解思路和方法,这样才能举一反三
4:一定要动手去开发,实实在在的把代码写出来,而不是满足于看懂、或是听懂
5:自己开发的过程中,一定不要对着视频去抄代码,要按照课程讲述的思路和实现方式,尽量自己去实现
6:克服急躁情绪,没有一蹴而就的好事,踏踏实实去理解、去练习
7:学会的判断标准:自己能够独立的把代码写出来,把功能实现出来,这才算真的学会了。
2014年私塾在线推出重磅课程
——独家顶级软件架构师实战培训课程
关于费用说明
有一些朋友说课程价格有点高,真的是高吗?请计算一下:76个小时多,全价也才2200,不到30一个小时,何况有活动,有VIP折扣,真正购买的价格,每个小时顶多20多块钱,现在一个像样的盒饭也要20了吧!
再请计算,假如你的月工资是1万(这个不高吧,真正做开发的2-3年绝对可以达到),每月工作22天,差不多一天是400多元的收入,每天8个小时,平均每个小时的收入是50以上吧!
另外再计算一下,如果通过课程学有所获,加个薪或者跳个槽,恐怕一个月的收入都不止上浮2000块吧。
那么,这个价格高吗?这笔投资值吗?相信你有自己的答案。当然,更便宜是每个人都愿意的,可是也要体谅一下老师的劳动,大家都要吃饭不是,已经盒饭价了呢,总得赏老师个盒饭吃吧!:)
在北京IT圈子里,真正达到软件架构师能力和水平的,一般的年薪在30-50万,资深的或者高级的架构师,年薪在50-80万,水平更高的,薪水也就更多了,可以称得上是金领了。
因此,一直以来,有很多朋友都在朝软件架构师这个方向努力发展。但由于没有人领路,一些朋友走了很多弯路,还有一些朋友始终在门外徘徊,迟迟无法进入软件架构师的行列。
为此,私塾在线特别推出这套《独家顶级软件架构师实战培训课程》,希望能帮助更多的朋友,少走弯路,并早日达到软件架构师的水平要求,走上幸福的康庄大道!
课程目标
专注于构建:高可扩展性、高性能、大数据量、高并发、分布式的系统架构
课程特色
国内唯一:国内第一套,也是唯一的一套
全面系统:从零开始、全面系统、成体系的软件架构课程,循序渐进的讲述构建课程目标所描述的系统架构所需要的各种技术知识和技能
注重实战:真正把软件架构的技术和理念具体化、实战化,不空洞的讲述理论,而是实实在在的,手把手的教你搭建出这样的系统架构
项目驱动:整个课程从一个基本的应用开始,不断的重构和优化,把各种所需知识和技能融合到每一步对系统的改造中,最终构建出课程目标所描述的系统架构
课程内容
整个课程经过精心设计和安排,从零开始,循序渐进、浑然一体。
整体内容分成两个大的阶段:
第一阶段:
基本目标:
把需要用到的各项技术学会,并组合起来构建出分布式的、高可扩展的系统架构,为高性能、大数据量、高并发的处理和性能优化做好准备
课程内容:
1:构建基本的业务功能块(基于Maven+Git+Spring mvc+spring+mybatis+ehcache+mysql+X-gen代码生成),前端页面JQuery+css+Html
基本业务:用户管理、商品管理、购物车、订单管理、库存管理
2:高扩展性的分布式体系架构(基于Nginx+Varnish+Memcache+ActiveMQ)
3:NoSQL的合理使用和架构优化(基于MongoDB)
4:分布式文件存储和架构优化(基于MogileFS)
内容说明:
1:阶段一课程中用到的技术,如果私塾在线有相应课程的,就是直接开发和使用,比如:Maven(在本课程里面会再补充一些知识)、SpringMVC、Spring、X-gen(在本课程中只是使用,当个jar包用就可以,没学过设计模式综合实战的课程也是可以的。设计模式综合实战的课程是讲述如何一步一步开发出X-gen,并综合应用上23个Gof设计模式的)等等
2:有些课程,虽然私塾在线没有相应的课程,但是使用特别普遍,基本大家都会用的,也是直接开发和使用,比如:mybatis(这个对于有Hibernate基础的朋友,很容易上手)、ehcache(使用配置都很简单)、mysql(阶段一的课程仅仅做最基本的使用)
3:其他的内容,在本课程里面,都会根据需要来讲述相应的知识,让大家快速上手、理解和掌握该技术,然后结合着项目进行应用,比如:Git、Nginx、Varnish、Memcache、ActiveMQ、MongoDB、MogileFS等,因此大家不用担心基础问题。
第二阶段(基于第一个阶段):
基本目标:
高性能、高并发、大数据量的分布式体系架构和性能优化,涉及内容很多,具体内容还在规划中,尽请期待。
预计第二个阶段的课程将在第一个阶段结束后2-3个月内开始推出,具体的时间请留意网站的信息。
主讲老师
陈臣(cc) 老师:私塾在线和Java私塾创始人,13年的Java开发和使用经验,《研磨设计模式》的作者,参与和领导了多个大中型项目的设计和开发,在系统架构、系统设计、应用级框架和中间件开发等方面具有很多经验和领悟。
适应人群
阶段一的课程适合如下人群:
1:有一定工作经验,还未从事架构工作,但想要向架构方面发展的朋友
2:已经开始从事架构工作,但想要系统学习提升的朋友
3:了解一些架构的知识,但是一直停留在理论上,不会实际操作,也无法让这些理论知识落地的朋友
4:有一定开发经验,想要系统学习架构方面的知识,扩展知识面和提升开发能力的朋友
温馨提示:阶段一的课程内容面向初中级架构人员,水平很高的朋友,不建议购买,免得您老白花钱。
特别说明
1:本课程是关注于架构设计,不关注业务设计,所以想要学习业务建模、软件的概要或详细设计的朋友,不适合选择本课程,对于软件设计方面的内容,我们会开设专门的软件设计类课程进行讲述,比如:框架设计、API设计、系统建模、设计模式综合应用、软件系统重构等等。
毕竟软件架构和软件设计关注的是不同层面的东西,当然,在国内目前的情况是,很多公司的软件架构和软件设计是同一批人员。不过由于内容实在太多,因此我们把软件架构和软件设计分开成不同的课程体系。
2:阶段一的课程是整体设计的,相互之间有关联,不单独拆开销售,请见谅。
3:由于是边制作边发放的方式,因此详细的课程大纲,也是跟着具体的视频课程,逐步公布和完善。
课程购买
阶段一的课程正式定价为2200元。
课程正式发放阶段:
从课程正式发放日算起,每一个月的销售价格上涨200元,直到正常的销售价格
详情咨询
对于有不清楚、有疑惑的朋友,请加私塾在线qq:2371651507 ,详细咨询和了解,如果不在线,请把问题留言即可,上线后会一一回复。
cc:
二十年Java/JavaEE开发经验,高级系统架构师,拥有Sun的多项Java和J2EE方面的技能认证,拥有丰富的开发经验和深厚的技术沉淀,精通Java/JavaEE相关技术和多种开源框架,尤其擅长系统分析和架构设计,曾从事专业的中间件研发。
多年的首席架构师和CTO,拥有多年项目经理、技术部经理的管理经验。参与和领导了多个大中型项目的设计和开发,在系统架构、系统设计、应用级框架和中间件开发等方面具有很多经验和领悟。
原创著作《研磨设计模式》和《研磨Struts2》广受好评,尤其是《研磨设计模式》,一直稳居原创设计模式类图书第一的位置,并输出版权到台湾。