前言:

已经工作4年,真是时间飞逝。

其实当你在一间公司工作一两年之后,公司用到的开发框架的基本使用你应该都会了。

你会根据一个现有项目A复制一下搭建出另外一个类似框架的项目B,然后在项目B上进行业务逻辑开发。

如果你更努力一点,你可能有去摸索一些配置的作用,一些问题的排查会更有经验和自己的想法。

如果你好奇心更强一点,可能会去了解一些框架的原理,各个框架之间是怎么相互协助工作的。自己能否从无到有将这些框架串联起来。

想写一系列这样的文章:将Java项目开发过程中的一些框架,如何一步步串联起来,并且结合源码探索其核心部分原理。以及项目从小项目演变到大项目的过程中,需要开发框架以及结构变化。以及特定业务场景设计。具体概请见下文。

大概使用的开发框架及工具:

基本工具:Eclipse、Maven、Tomcat

前端:Jquery、Vue.js、 Element

后台核心框架:Spring、SpringMVC、MyBatis

后台辅助框架:日志框架Logback、安全框架Shiro、任务调度框架Quartz

分布式框架:Dubbo、RabbitMQ、Redis…………..

除了这些框架还有一些特定业务场景,以及高扩展高可用的架构演变过程等等。 
主要分为下面三个阶段博客提纲。

阶段一:集中式基本架构

一、基本工具:Eclipse、Maven、Tomcat(此篇不写博客,关于Maven猿友可自行网上安装教程及博客)

二、Spring介绍及探索:主要就是依赖注入以及AOP原理,Spring使用大多以配置为主,因此从配置入手,结合源码探索其原理。

三、SpringMVC:以实例入手,结合源码探索其主要原理。

四、Mybatis:以实例入手,结合源码以及分页插件拓展探索其用法及原理。

五、日志框架Logback:结合实例、配置、源码了解其原理,并对Logback封装,使得更加符合实际业务需求。

六、前端框架Vue.js+Element使用,Jquery默认猿友已经会用了。

七、安全框架Shiro:主要登录及权限认证实例入手,探索其用法。

八、任务调度框架Quartz:实例+配置+源码探索用法及基本原理。

九、异步线程池使用及业务场景。

十、数据库事务实例及应用场景

十一、ehcache本地缓存实例及应用场景。

之所以阶段一叫集中式基本架构,是因为这种结构适合前端代码,后台代码在一个工程,部署到一台服务器上里面。带来的问题有:性能问题、工程十分臃肿、风险很大、不好迭代。

当然性能问题可以通过集群方式,就是部署到多台机器上,然后根据用户访问的ip进行分流到不同机器响应。目前web项目大多采用这种做法。

但是一旦业务及功能模块多了起来,需要快速迭代,必然要模块拆分。因此必须采用分布式架构。 
分布式架构一般根据功能进行划分模块,以电商为例:对外web端一个模块、管理web端、商品后台一个模块、订单支付后台等一个模块、用户信息后台一个模块。各个模块之间通过接口服务实时通信,异步通过MQ方式通信、缓存也需要使用分布式缓存框架。

接下来我们看下阶段二的博客提纲。

阶段二:高扩展、高性能、高可用、快速迭代分布式架构

一、分布式服务框架Dubbo:主要实例以及原理探索。

二、日志流水透传:让同一个请求经过的多个模块的日志流水保持一致。

三、分布式消息框架RabbitMQ:实例+配置+源码理解其原理。

四、任务调度框架Quartz改造:将所有模块的JOB任务集中管理,以服务调用形式触发。

五、分布式缓存框架Redis:了解其原理并规范使用,各个模块定义系统码,共享缓存内存资源,但是已系统码隔离。

六、前后端分离:对性能以及用户体验较高的web模块进行前后端分离,前端模块全部为静态资源,部署待静态资源服务器,与controller拆分开。

七、session共享:之前也提到根据功能划分模块,多个web模块对外提供请求相应,那么就会涉及session共享,一次登录即可。主要采用tomcat-redis技术实现session共享。

八、OAuth2.0认证和授权:这是扩展外部合作渠道的毕竟之路,如授权给外部商户获取你的用户信息。如微信公众号就是这种做法,很多可以使用微信登录以及QQ登录也是这种做法。

九、封装常用的业务工具类:如批量导入导出,ftp上传及下载文件、json处理等等。

十、将框架集成部分抽出形成一个基础框架:这个非常有意义,可以简化配置,对框架升级等等。

阶段三:适配大数据、高并发以及自动化要求(可能更偏向运维)

一、日志监控,自动告警:将ERROR日志通过邮件或短信方式发给对应的开发人员,可以起到很好的提醒作用。

二、自动化部署以及持续集成:模块多了,上线部署变得更加频繁的时候,就需要简化部署流程。

三、代理与负载均衡&集群:根据阶段二,一般web项目通过ip进行负载分流,后台可以使用Dubbo的负载均衡。

四、资源服务器搭建

五、数据读写分离

六、分库分表

七、秒杀设计

八、非关系型数据库使用

九、大数据工具的使用

我有一个微信公众号,经常会分享一些Java技术相关的干货;如果你喜欢我的分享,可以用微信搜索“Java团长”或者“javatuanzhang”关注。

Java项目框架搭建系列(Java学习路线)的更多相关文章

  1. 记录-项目java项目框架搭建的一些问题(maven+spring+springmvc+mybatis)

    伴随着项目框架的落成后,本以为启动就能成功的,but.... 项目启动开始报错误1:java.lang.ClassNotFoundException: org.springframework.web. ...

  2. 深入理解Java并发框架AQS系列(二):AQS框架简介及锁概念

    深入理解Java并发框架AQS系列(一):线程 深入理解Java并发框架AQS系列(二):AQS框架简介及锁概念 一.AQS框架简介 AQS诞生于Jdk1.5,在当时低效且功能单一的synchroni ...

  3. mac OS X下Java项目环境搭建+IntelliJ IDEA Jrebel插件安装与破解+Office 2016破解版安装

    一.mac OS X下Java项目环境搭建 因为某些原因新入手了台最新版的MacBook Pro,意味着今天要花一天时间安装各种软件以及项目环境搭建╮(╯▽╰)╭ 项目环境搭建步骤: 1.安装jdk ...

  4. 深入理解Java并发框架AQS系列(一):线程

    深入理解Java并发框架AQS系列(一):线程 深入理解Java并发框架AQS系列(二):AQS框架简介及锁概念 一.概述 1.1.前言 重剑无锋,大巧不工 读j.u.c包下的源码,永远无法绕开的经典 ...

  5. 深入理解Java并发框架AQS系列(四):共享锁(Shared Lock)

    深入理解Java并发框架AQS系列(一):线程 深入理解Java并发框架AQS系列(二):AQS框架简介及锁概念 深入理解Java并发框架AQS系列(三):独占锁(Exclusive Lock) 深入 ...

  6. 权限管理系统之项目框架搭建并集成日志、mybatis和分页

    前一篇博客中使用LayUI实现了列表页面和编辑页面的显示交互,但列表页面table渲染的数据是固定数据,本篇博客主要是将固定数据变成数据库数据. 一.项目框架 首先要解决的是项目框架问题,搭建什么样的 ...

  7. .Net Core3.0 WebApi 项目框架搭建 四:JWT权限验证

    .Net Core3.0 WebApi 项目框架搭建:目录 什么是JWT 根据维基百科定义,JWT(读作 [/dʒɒt/]),即JSON Web Tokens,是一种基于JSON的.用于在网络上声明某 ...

  8. ssm项目框架搭建(增删改查案例实现)——(SpringMVC+Spring+mybatis项目整合)

    Spring 常用注解 内容 一.基本概念 1. Spring 2. SpringMVC 3. MyBatis 二.开发环境搭建 1. 创建 maven 项目 2. SSM整合 2.1 项目结构图 2 ...

  9. Angular企业级开发(5)-项目框架搭建

    1.AngularJS Seed项目目录结构 AngularJS官方网站提供了一个angular-phonecat项目,另外一个就是Angular-Seed项目.所以大多数团队会基于Angular-S ...

随机推荐

  1. O037、Rebuild Instance 操作详解

    参考https://www.cnblogs.com/CloudMan6/p/5516852.html   上一节我们学习了 snapshot ,snapshot 一个重要的作用就是对 Instance ...

  2. win10上使用php与python实现与arduino串口通信

    注意: php 需要php7,安装及开启php_dio.dll com口按照实际的进行设置,如果不知道可以打开arduino编辑器进行查看 可以与用户实现命令行交互,但是效率过慢,不清楚如何优化,使用 ...

  3. WebStorm 使用技巧

    常用快捷键 代码编辑 ctrl + d:复制行 ctrl + y:删除行 ctrl + x:剪切行 ctrl + shift + ↑: 行移动 ctrl + shift + enter: 换行 ctr ...

  4. vue入门:(class与style绑定)

    对象语法 数组语法 一.对象语法 1.1对象语法绑定HTML Class 语法:v-bind:class="{'className1':boolean1,'className2':boole ...

  5. 解决IDEA报错Could not autowire. There is more than one bean of 'xxx' type

    更新项目之后IDEA突然出现了这样的报错信息.显示Could not autowire. There is more than one bean of 'xxx' type.这个错误的意思是xxx类型 ...

  6. tp5.1 nginx配置

    解决方案 修改fastcgi的配置文件    目录:/www/server/nginx/conf/fastcgi.conf fastcgi_param PHP_ADMIN_VALUE "op ...

  7. nagios-调用脚本

    在自已编写监控插件之前我们首先需要对nagios监控原理有一定的了解 Nagios的功能是监控服务和主机,但是他自身并不包括这部分功能,所有的监控.检测功能都是通过各种插件来完成的. 启动Nagios ...

  8. Java 工具类 IpUtil - 获取本机所有 IP 地址,LocalHost 对应地址 IP

    Java 工具类 IpUtil - 获取本机所有 IP 地址,LocalHost 对应地址 IP IP 工具类 源代码: /** * <p> * * @author XiaoPengwei ...

  9. .NET平台的发展

    .NET平台的发展.NET从1.0到.NET Core3.0:C#从1.0到8.0: ASP.NET从1.0到Core3.0: ASP.NET MVC1.0到ASP.NET MVC6.0,

  10. CSS基础学习-5.CSS属性_字体文本文本装饰