🌟 JavaSE
- 基本语法:包括Java的基本数据类型、运算符、流程控制、函数、异常处理等。
- 面向对象编程:封装、继承、多态、抽象类、接口、内部类等。
- 集合框架:包括List、Set、Map等集合类型以及泛型。
- IO流:包括字节流和字符流,文件读写等。
- 多线程:包括线程创建、同步、死锁、线程池等。
- 反射:包括Class、Method、Constructor等反射API的使用。
- 异常处理:包括Exception和RuntimeException等异常类型的捕获和处理。
- JDBC:包括连接数据库、执行SQL语句、批处理等。
- 注解:包括元注解、自定义注解、注解处理器等。
- Lambda表达式和Stream API:Java 8新特性,简化了集合的操作和代码的书写。
- JVM:包括类加载机制、双亲委派机制、内存模型、垃圾回收等。
🌟 JavaWeb
- Servlet:理解Servlet的生命周期、请求和响应的过程、Servlet API等;
- JSP:学习JSP的基本语法、JSP指令、EL表达式、JSTL标签库等;
- MVC架构:掌握MVC架构的实现方式、优势和劣势;MVC设计模式,即Model、View、Controller之间的关系和作用。
- 数据库技术:了解数据库的基本概念、SQL语句、数据库连接池等;
- Web基础知识:了解HTTP协议、Servlet、JSP、JavaScript、HTML、CSS、Tomcat等Web开发相关技术。
- Ajax:掌握Ajax的工作原理及其实现方式;
- XML和JSON:理解XML和JSON的基本结构和用途,掌握XML解析和JSON解析的方法。
- RESTful API:理解RESTful API的概念和设计原则,掌握RESTful API的开发方法。
- 版本控制工具:掌握Git等版本控制工具的使用。
- Maven工具:了解Maven工具的使用和管理项目依赖的方法。
🌟 多线程
- 进程和线程的概念:理解进程和线程的概念,以及它们之间的关系和区别。
- 线程的创建和销毁:了解如何创建和销毁线程,能够创建多个线程,并正确地释放线程资源。
- 线程同步和互斥:掌握线程同步和互斥的实现方法,如锁、信号量、条件变量等,能够正确地使用这些方法来保证多个线程之间的数据共享的正确性。
- 线程通信:了解线程之间的通信方式,如管道、消息队列、共享内存等,能够正确地使用这些方法来实现线程之间的数据传输和同步。
- 线程调度和优先级:了解线程的调度算法和优先级,并正确地设置线程的优先级,以保证线程的运行效率和响应性。
- 异常处理和错误处理:能够正确地处理线程中出现的异常和错误,并能够正确地回收线程资源,避免程序出现崩溃等问题。
- 并发编程模型:了解并发编程的常用模型,如生产者-消费者模型、读者-写者模型、线程池模型等,能够根据实际需求选择合适的并发编程模型。
🌟 主流框架
- Spring框架:掌握Spring框架的基本原理、IOC容器、AOP编程、事务管理等。
- Spring Boot框架:掌握Spring Boot框架的使用、自动化配置、启动器、命令行界面等。
- MyBatis框架:掌握MyBatis框架的使用、Mapper接口、动态SQL语句、插件等。
- Spring MVC:学习Spring MVC的基本概念、Spring的依赖注入、控制反转等;
- 微服务技术:包括Spring Cloud组件、Dubbo、Zookeeper等微服务框架。
- 单元测试:掌握JUnit和Mockito等单元测试框架的使用和原理。
🌟 Redis缓存
- 数据结构:redis支持多种数据结构,例如字符串、列表、哈希、集合、有序集合等,在使用redis时需要了解这些数据结构,以及它们的特点和使用场景。
- 安装和配置:了解如何在自己的系统上安装redis,并且了解redis的配置文件和参数含义。
- 命令:redis的使用主要通过命令行进行,需要了解redis提供的各种命令及其参数含义。
- 持久化:redis支持两种持久化方式,即快照和AOF,需要了解它们之间的区别以及如何进行配置。
- 高可用性:redis提供了各种高可用性方案,例如主从复制、哨兵和集群等,需要了解它们之间的区别以及如何进行配置。
- 性能优化:了解如何对redis进行性能优化,例如使用合适的数据结构、调整缓存大小、优化命令使用等。
- 分布式锁:了解如何使用redis实现分布式锁,以避免多个客户端同时对同一资源进行修改。
🌟 消息中间件
- 消息队列的基础概念:需要了解消息队列的一些基本概念,如消息生产者、消息消费者、消息队列等。
- 消息中间件的分类:需要了解消息中间件的分类,如点对点模型、发布订阅模型等,并了解它们的应用场景和特点。
- 消息中间件的实现原理:需要了解消息中间件的实现原理,包括消息的存储方式、消息的传递方式、消息的过滤方式等。
- 消息中间件的常见应用场景:需要了解消息中间件的常见应用场景,如分布式事务、数据同步、异步处理等。
- 常见的消息中间件:需要了解常见的消息中间件,如ActiveMQ、RabbitMQ、RocketMQ、Kafka等,熟悉它们的使用、配置和优化。
🌟 全文搜索
- Elasticsearch基础知识:了解Elasticsearch的基础概念、索引、分片、节点、集群等基本概念。
- 全文搜索的基本原理:理解全文搜索的基本原理以及如何搭建一个可靠的全文搜索引擎。
- Lucene基础知识:Lucene是Elasticsearch底层的搜索引擎库,因此需要了解Lucene的基础知识,包括索引和查询的基本原理,以及查询语法等。
- 数据建模和索引设计:为了提高搜索的效率和准确性,需要对数据进行建模和索引设计,包括确定字段类型、分析器、词库等等。
- 查询语句的编写和优化:学会如何编写和优化查询语句,包括基本查询、复合查询、聚合查询、模糊查询、范围查询等。
- 集群和分布式搜索:了解分布式搜索的基本原理和配置,扩展集群的节点数以及实现高可用性。
- 与其他系统的集成:学会如何与其他系统(如Kibana、Logstash、Beats等)进行集成,以实现更复杂的数据分析和可视化功能。
🌟 MySQL
- 数据库基础知识:了解关系型数据库的概念、数据库的体系结构、数据类型、SQL语言等基本知识。
- 数据库设计:学习如何设计合理的数据库结构,涉及到数据表、数据字段、数据类型、主键、外键、索引等概念。
- 数据库操作语言(SQL):了解SQL语言的语法规则、基本语句以及高级语句,如SELECT、INSERT、UPDATE、DELETE等。
- 数据库管理系统(DMS):包括MySQL的基本配置、安装和管理、备份和恢复、安全等知识。
- 数据库优化:学习如何优化数据库查询性能,包括索引优化、查询语句优化等。
- 数据库应用开发:如何在Web应用中使用MySQL,以及如何使用各种编程语言进行对MySQL的操作。
- 数据库安全:涉及到数据库用户身份、权限管理、数据加密等相关内容。
总之,MySQL关系型数据库学习需要全面了解各种基础知识以及实际应用,掌握以上知识点可以使得初学者更好地入门 MySQL 数据库的学习。
🌟 Mongodb
- NoSQL数据库概念和优点:NoSQL是指非关系型数据库,MongoDB就是一种NoSQL数据库,需要了解其与传统关系型数据库的区别和优点。
- MongoDB的安装和配置:需要了解如何安装和配置MongoDB,包括如何启动和停止MongoDB服务。
- MongoDB的基本概念和架构:需要了解MongoDB的文档、集合、数据库和副本集、分片等概念,以及其整体架构。
- MongoDB的数据存储和查询:需要了解MongoDB的数据存储方式和数据查询语言,掌握如何使用MongoDB进行数据存储和查询。
- MongoDB的高级功能:需要了解MongoDB的高级功能,包括索引、数据备份和恢复、性能优化等。
- MongoDB的应用场景和实践经验:需要了解MongoDB在实际应用中的应用场景和实践经验,例如如何在Python、Java等编程语言中使用MongoDB进行开发。
🌟 开发工具
- Eclipse:一款开源的Java IDE,被广泛使用。
- IntelliJ IDEA:一款功能强大的Java IDE,具有高度的智能化和自动化功能。
🌟 模板引擎
- 模板语言:FreeMarker和Thymeleaf均有自己的模板语言,需要学习其基础语法及常用指令、表达式等。
- 数据模型:模板引擎可以接收一个数据模型,并将其渲染到模板中。因此,需要了解如何准备数据模型及如何在模板中使用数据模型中的数据。
- 模板标记:模板标记是指模板引擎中用来标识特定功能或指令的标记。需要了解如何使用模板标记以及如何自定义模板标记。
- 模板文件:需要了解如何创建和管理模板文件,包括如何使用模板继承、布局、包含等功能。
- 集成框架:了解如何将FreeMarker和Thymeleaf集成到常用的Java Web框架中,如Spring MVC等。
- 性能优化:模板引擎的性能对于Web应用程序非常重要。需要了解如何进行性能优化和缓存机制的实现。
- 其他:还需要了解如何处理异常、调试技巧、安全性等方面的内容。
🌟 部署
- 打包成war文件,部署到Web容器中:将Java项目打包成war文件,然后将war文件部署到Tomcat、Jetty、WebSphere等Web容器中,通过Web容器来管理和运行Java项目。
- 打包成jar文件,直接运行:将Java项目打包成可执行的jar文件,然后在命令行或者脚本中直接运行,不需要Web容器的支持,适用于一些简单的命令行应用。
- 使用Docker容器部署:将Java项目打包成Docker镜像,然后在Docker容器中运行,可以轻松制作和部署Java项目。
- 通过Jenkins进行自动化部署:使用Jenkins等自动化工具,将Java项目打包、发布和部署进行自动化化管理,可以提高效率和减少出错率。
- 使用云服务进行部署:将Java项目部署到云平台上,如AWS、Azure、Google Cloud等,可以快速部署和弹性扩展Java应用。
- Linux操作系统和Shell脚本:了解Linux操作系统的基本概念、常用命令和Shell编程等。
🌟 负载均衡
- 网络基础知识:如路由、子网划分、IP地址等;
- 协议和服务:如HTTP、TCP、UDP、DNS等;
- 负载均衡算法:如轮询、最少连接、IP哈希、加权轮询等;
- 负载均衡器的分类和功能:如硬件负载均衡器和软件负载均衡器;
- 负载均衡架构的设计和部署:如负载均衡器的选型、高可用性和容错性等;
- 监控和调优:如性能监测、请求分析、错误排除等。
🌟 监控
- JConsole:Java自带的监控工具,可以实时监控JVM的运行情况。
- JMeter:Apache开源的性能测试工具,可以模拟多种负载类型,对Java应用进行性能测试和压力测试。
- JProfiler:商业的Java性能分析工具,可以分析JVM的各种性能指标,并提供详细的性能分析报告。
- 掌握SkyWalking的架构、原理和使用方法,了解支持的语言、支持的部署方式、支持的监控数据等。
- 掌握Prometheus的基本概念和架构,例如指标、目标、作业、规则等;Prometheus的查询语言PromQL;Grafana的基本概念和架构,例如数据源、面板、图表等;Grafana的模板变量和面板过滤器等高级功能;Prometheus和Grafana的安全设置,例如认证、授权、TLS等;
🌟 Apache ShardingSphere
- 数据库分片和分库分表的概念
- 分片规则和分片键的设计
- 数据库读写分离的概念和实现方式
- Proxy和JDBC的区别和联系
- ShardingSphere架构和原理
- ShardingSphere的配置和使用方法
- ShardingSphere的优势和局限性
- ShardingSphere在实际应用中的使用场景和案例
- ShardingSphere的性能调优和故障处理方法
- 对分布式数据库的理解和实践经验。
🌟 设计模式
学习设计模式需要掌握以下知识点:
- 面向对象编程思想:设计模式是基于面向对象编程思想而产生的,因此学习设计模式需要熟悉面向对象的基本概念、原则、特点等。
- UML建模:在学习设计模式时需要使用UML类图或时序图等图形化工具来描述模式结构、流程,因此需要掌握UML建模的基本知识。
- 设计原则:设计模式通常都基于一些设计原则(如单一职责原则、开闭原则等),因此需要熟悉这些设计原则。
- 模式分类及应用场景:了解不同类型的设计模式,以及它们的应用场景。
- 代码实现:了解设计模式的基本思想后,需要通过编写代码实现模式,加深理解。
- 重构:学习设计模式后,需要将其应用于实际项目中,进行重构,提高代码的可维护性、可扩展性等。因此需要掌握重构的基本思想及常用技巧。
🌟 领域驱动DDD
- 领域模型:了解什么是领域模型和如何正确设计一个领域模型。
- 领域驱动设计的基础概念:包括聚合、实体、值对象、领域服务、领域事件等概念的理解。
- 业务分析和建模:学会如何进行业务分析,理解业务模型和业务过程。了解如何将业务分析转化为领域模型的设计。
- 软件开发技术:掌握至少一门编程语言,理解基本的面向对象设计和编程技术。
- 设计模式:熟悉常用的设计模式,并知道如何将其应用到领域模型的设计中去。
- 持久化技术:掌握常用的数据库技术和ORM框架,了解如何将领域模型持久化到数据库中。
- 分布式系统设计:对于涉及到分布式系统的问题,需要具备相应的设计和开发经验。
- 团队协作和沟通能力:领域驱动设计需要团队协作,需要良好的沟通能力和合作精神。
🌟 Kubernetes
- 容器技术:需要熟悉常见容器技术,例如Docker。
- 容器编排:需要熟悉常见容器编排工具,例如Docker Compose、Kubernetes等。
- Linux操作系统:需要熟悉Linux操作系统的基本命令和操作。
- 网络基础:需要熟悉网络基础知识,例如IP地址、子网掩码、端口、协议等。
- 负载均衡:需要了解负载均衡的概念、原理和常见工具。
- 存储:需要了解存储的概念和种类,例如本地存储、网络存储等。
- 安全:需要了解容器和Kubernetes的安全机制和实践。
🌟 Activiti工作流(非必要)
- Java编程语言:Activiti是一个基于Java的框架,所以熟练掌握Java编程语言是必须的。
- BPMN标准:Activiti采用BPMN2.0标准,掌握BPMN的基本原理和相关概念是学习Activiti的基础。
- Activiti框架:了解Activiti的基本框架结构、核心类和模块,包括流程引擎、表单引擎、任务引擎、历史引擎、流程仓库等。
- Activiti的基本API:掌握Activiti的基本API,如流程定义API、运行时服务API、历史记录服务API等,可以实现流程的定义、部署、执行和监控。
- Spring框架:Activiti通常与Spring集成使用,因此需要了解Spring框架的基本原理和使用方法。
- 数据库:Activiti的流程和任务信息需要进行持久化存储,因此需要掌握数据库相关知识,包括SQL语言、数据库设计和操作等。
- Web开发技术:Activiti的表单和任务界面通常采用Web技术实现,因此需要掌握相关的Web开发技术,如HTML、CSS、JavaScript等。
- 工作流设计和开发经验:具有一定的工作流设计和开发经验,可以更好地理解Activiti的使用和应用场景。
🌟 FastDFS文件存储(非必要)
- 分布式系统:了解分布式系统的基本概念和架构,包括分布式存储、负载均衡、集群等。
- Linux系统:熟悉Linux系统的基本操作、目录结构、命令行等。
- 文件存储:了解文件在计算机系统中的存储方式和存储管理方法,包括文件系统、文件格式、文件读写操作等。
- 编程语言:熟悉至少一种编程语言,如C、Java等。
- 网络协议:了解TCP/IP协议等网络协议的基本概念和原理。
- FastDFS:熟悉FastDFS的特点、架构、安装部署、配置以及使用方法等。
- 文件上传下载:了解文件上传下载的基本原理和方法,包括HTTP协议、FTP协议等。
- 数据库:了解MySQL等数据库的基本操作和使用方法,以及与FastDFS的配合使用。
- 高可用性:了解如何保证FastDFS的高可用性,包括负载均衡、故障转移等。
- 安全性:了解如何保护FastDFS的安全性,包括用户权限管理、数据加密等。