最新消息:XAMPP默认安装之后是很不安全的,我们只需要点击左方菜单的 "安全"选项,按照向导操作即可完成安全设置。

一文了解 java项目开发流程_JAVA企业级项目开发

XAMPP相关 admin 75浏览 0评论
 AA00047  
阅读正文   需要 15分钟
虽说工作就是简单的事情重复做,但不是所有简单的事你都能有机会做的。
我们平日工作里,大部分时候都是在做修修补补的工作,而这也是非常重要的。做好修补工作,做好优化工作,足够让你升职加薪!
但是如果有机会,去尝试些自己平日里少做的事,我觉得是一件值得庆幸的事。
前段时间,接了个新项目。只有一些idea在业务需求方脑海里,然后就开始需求讨论,然后就开始做事了。项目不复杂,但是由于是用JAVA语言实现(这相对来说是我的薄弱点),对我个人显得比较有意义。
总结下来,其实也就是一个项目清单。个人觉得还是有点意义吧,给没有一定全面实践的同学参考吧

1. 项目规划

1.1 首先,你得彻底明白到底要做什么?

这个过程,可能是你要读需求一遍、两遍、三遍…….. 然后假设,你已经在使用这个产品了。

1.2 其次,明白需求后,就要进行整体框架的构思!

比如用什么呈现给用户,用什么来存储数据,需要些什么样的系统等。
在这个层次上,一般都会遵循公司的规定,然后再根据项目本身需求,做些相应的调整。
我们在这个项目里的整体框架为:前端使用 APP(ios&android)、H5进行用户界面呈现 ===>> 接入网关进行数据加解密,流控转发等 ===>> 第一层API服务,接受客户端请求,做简单业务检验组装 ===>> 第二层核心业务SERVICE服务,进行核心业务处理,如写库、调用第三方接口等 ===>> 最下层基础服务,提供单一的功能服务,如消息服务,订单服务。前期只提供APP,因此不存在单独H5调用API服务的情况,但是H5的应用场景仍然存在,此时的H5地址,由服务接口提供地址返回到APP进行webview加载。

1.3 人员规划

项目整体框架出来后,得要有人去实施才行。这里一般需要遵循一个最小原则,即划分出的人员,尽量做到能够独立完成自有的模块,而不是一定要依赖于另一方的实现才能进一步。比如 android,ios各一人,API与SERVICE可以多个人,但是都要让其有全部权限,因为API与SERVICE有强依赖,脱离一方,将无法独立完成。基础服务各自安排相关人员实现。最后进行联调即可。

1.4 时间规划

有了人员之后,也不能无限时间的去做事。肯定是要规划的,否则没有压力也没有动力。项目不知何时才能结束。订时间计划一定要去询问当事人,要多少时间,尽量站在专业的角度给出合理的建议和评估。促进项目的完成。
2. 框架规划及搭建

2.1 有了整体框架的构思后,就要细节到每个层次的实践了

因为都是应用的分层,所以,不可能有统一的描述,只能是针对每个应用层。做自己该做的事。如android/ios 有自己的开发框架;
h5有自己的开发框架(因为很多应用场景可能涉及到h5与app原生的交互,所以即使功能简单,也尽量利用一些已有的框架进行开发)。而服务端,虽分为多层应用,但是应尽量使用同一门语言,利用同一套开发框架,自己公司有研发框架自然最好,没有也尽量利用统一的开源框架。这样做的好处是,当有人员变动时,可以立即熟悉其代码及应用场景,从而增加适应性和管理性。
针对服务端的框架,我觉得有必要多说点。因为整个应用运行的流畅性,可靠性,准确性,都是由服务端来决定的。虽然用户看到的是APP或者H5,但是可以说,服务端才是应用的核心。所以,服务端要做的事情自然很多了。

2.2 怎样搭建好一些服务端的框架呢?

首先,框架类的东西,自然是要提前学习的。但是,就目前市场行情来说,要想利用框架应该都是比较简单的,尤其是公司内部提供的框架,一定要有demo。这样,照着demo,一步步调试,直到整个应用接通;删除不需要的模块,添加特别需要的模块,保证在具体开发过程中,能够想利用啥就有啥可利用;充分了解框架需要的一些配置参数,知道事务从哪里来,到哪里去?这里,应有一个配置中心与之对应,但是自己得清楚。

使用一个顺手的IDE工具,不是说你技术不够牛逼,而是一个好的工具,能够让你事半功倍。(其实能够多背点套路,也不一定非要体现在正式项目上)

写出第一个可供使用的接口服务,可以说,第一个永远是比较重要的。因为,第一个的思路,就是你后续所有功能的方向,因此,写好第一个”hello, world.”;

3. 开发环境的搭建(服务端)
其实这项工作是及其重要的,之所以把它放在第三点,是因为,没有代码作铺垫,开发环境搭了也没用。

开发环境的搭建,主要也是服从于整体框架的构思。

主要包括,需要多少个服务,需要多少台服务器,需要多少个基础应用,需要多少个基础配置等等。当然,开发环境本身就是一个很大的难题,一般还是交给专业运维几十年的老司机来完成了。自己就当作了解得了。目前的项目开发,除一些小规模公司还在利用一套服务端代码,干完所有的事外,大部分应该都是多个应用的配合完成。而测试环境,不太可能利用多个服务器提供服务。因此,使用docker进行测试环境搭建尤佳。建立多个docker进行多个服务器模拟,也算是和线上环境保持一致了。

目前的主流技术得用上(当然关键还得看你的框架规划),zookeeper, dubbo, redis, mongo, mq, …

只有开发环境搭建好了,才能让后面的流程无忧。搭建的过程一定是,又搭建,又改代码,又排错…

4. 进度的同步

4.1 及时向领导同步项目进度

对于一个新项目,有些地方行动缓慢是很正常的。而部分开发同学(比如我自己),就喜欢沉浸在自己的小世界里纠结,走不出来,从而忘却向领导汇报工作。而作为一个有点同理心的领导来说,他又不愿意实时都来盯着你做事,因为也怕你遇到困难,想多给你点时间解决。
但是,这种情况,开发同学自己其实是要吃亏的,因为,给外人的感觉就是,你啥都没做。所以,解决问题的同时,也不忘向领导汇报。

4.2 有处理不了的问题,及时向大牛们或者领导请教

独立解决问题是好事,但是千万别过了头,实在解决不了,就要及时请教。否则,浪费的是时间。进步最快的方式,莫过于向比自己牛逼的人请教。知之为知之,不知为不知!

4.3 尽量将问题分摊下去

问题肯定是有的,而且会很多。千万不要把所有的事情都压在自己这儿,那样自己会累死的,而且项目进度也会因此变得缓慢。要多利用小组成员的各自优点,适当多让其搞点事情。工作永远都不是单一的一件事,肯定还会有其他的事情插入进来,观察事情的重要性解决。如果能够让其他同学解决的,尽量让其他同学处理,这点也得与领导同步。否则分心过于利害,受阻的只有项目进度,延期可不是自己一人的事情了。需求也不可能一下就是完善的,在做的过程中,才可能发现一些潜在的问题,这时及时与需求方沟通,保持高效的状态。当然,后期的跟进,也是尽量做到不要一人大包大揽,而是相应的人就去负责相应事情的跟进。其他人只要知道结果就行。

5. 功能模块的完成
说到具体的业务实现,个人觉得,已经不那么难了。不过就是,先尽力提出的一个初稿,然后发现问题解决问题,发现问题,解决问题的过程。
各自系统能做的事情完成后,就是联调各系统间的调用关系,保持高效的沟通,让问题在短时间内解决,尤为重要。在这种时候,我觉得,一个小黑屋也许也是个不错的选择。
联调的过程,其实就是一个自测的过程,应把尽可能多情况给考虑到位。
代码检查,自己开发的代码,基本上很难发现其中的问题,即时找到相应人帮忙检查代码,是比较好的解决代码问题的方案。其实,在给别人检查的时候,也是自己检查的时候,相当于自己再一次的开发,也能及时发现问题。
6. 多轮的测试验证
测试同学,其实在开发快结束的时候,已经把测试用例给到大家。这也是另一个角度的开发,因此,参考测试用例进行相应开发修改也是很有必要的。
  1. 第一轮测试,可能主要是大功能的验证,小功能的检查,挡板环境即可,无需真实环境。
  2. 第二轮测试,则是要把之前的测试及各种配置,全部清空,以一个全新的项目来对待,重新进行相应环境搭建,代码部署,然后再进行测试,确保问题解决后,做好了相应的处理方案备份。这时,就需要用到真实的应用环境了。对之前一些暂未解决的问题进行重新测试。确保无问题。
  3. 第三轮测试,应该是一个灰度发布的环境,也可以认为是预上线。将所有环境当作是线上来处理,如果运行ok,即可准备发布上线了。
在测试过程中,因测试人员只是人工的处理,有时不一定能捕获所有的问题,开发在这时,也应站在测试的角度,发现问题,即时监控,即时处理。
  1. 自动化测试,这个其实应该是靠后的处理,但是如果能做到这些的话,也能够快速的重现问题。
  2. 压力测试,应对线上环境,需有一定的能力评估,不然,只瞎猜,恐怕也不是好事。随时准备横向扩展,也只是出现问题后的解决方案。做好压测,发现代码中存在的问题,即时处理掉。

7. 外围处理(上线前)

7.1 上线前,肯定是有很多事务要处理的。

  1. 测试环境中的各种基础数据,随时导出备份,到线上时,直接插入使用;
  2. 服务器,在架构评审过程中进行数量评估;
  3. 域名,对外网提供服务一定是要域名的;
  4. 权限,比如上线后,出现了问题,谁有权限来处理问题,一定提前给到;
  5. 验收,这是关键的一点,功能完成后,及时验收,如果上线有些小问题,尽量协商,不要在线上频繁改动。
如此,整个项目就完工了。其实发现,一个项目真正的功能实现,并没有占多大的比例,而是一些前期的准备及后续的处理,反而占了更多的时间。第一个版本上线后,可能接着就是迅速迭代了。(如果运营还可以的话!)

以上,就是一整个项目的流程清单,以一步一个脚印的经历总结,不涉及具体语言代码,但是思路都是相通的,希望对你有帮助!
java项目开发相关文章内容推荐:
Java是用来做项目的!Java的主要应用领域就是企业级的项目开发!要想从事企业级的项目开发,你必须掌握如下要点:

1、掌握项目开发的基本步骤2、具备极强的面向对象的分析与设计技巧3、掌握用例驱动、以架构为核心的主流开发方法

 

没有人愿意自己一辈子就满足于掌握了一些代码实现的技巧,别人告诉你要实现什么,你就用代码堆砌来实现别人的要求!你必须学会从整个项目的角度去思考!你必须学会假如你是项目经理,你该如何思考!你必须学会假如你是架构师,你该如何思考!你必须掌握针对某个特定问题领域的分析方法!

关于基础tb知识:你可以看看这些名词或知识点,看是否能说出个一二三四来。

JavaSE

—-基本语法、数据类型、操作符等:int、long、Integer、Long、if、else、for、while

—-面向对象:class(类)、Object(对象)、instance(实例)、state(状态)、behavior(行为)、field、method、new、可见性(访问控制)、attribute、property、package、import、static variable、class variable、instance variable、heap、method area、stack、GC(垃圾回收)、override、overload、对象转型(casting)、多态、this、super

—-异常处理:理解编译期错误和运行期错误的区别、Exception、RuntimeException、checked exception、unchecked exception、try、catch、finally、throw new XXXException、throws XXXException、异常处理的基本原则

—-数组与集合:数组的定义和使用方法、Collection、List、Set、Map、ArrayList、HashSet、HashMap、Iterator、equals、hashCode、Comparable、Comparator

—-常用类:String、intern、常量池、StringBuffer、java.util.Date、SimpleDateFormat、Regex(正则表达式)

—-反射机制:Class、Method、Field、invoke、newInstance、BeanUtils(apache-commons)、PropertyUtils(apache-commons)

—-输入输出流:InputStream、OutputStream、Reader、Writer、Adapter设计模式与原始流类、Decorator设计模式与包装流类、对象序列化和反序列化

—-多线程:Thread、Runnable、sleep、wait、notify、synchronized、lock

Servlet和JSP

—-HttpServlet、doGet、doPost、HttpServletRequest、HttpServletResponse、request.getParameter、request.setAttribute、request.getAttribute、request.getSession、ServletContext、Filter、web.xml、tomcat、forward与redirect、http协议的无状态性、cookie、JSP Scope Object、、

HTML与JavaScript

—-你需要能够理解常见的网页标签、理解在网页中引入JavaScript的方法、以及JavaScript的基本语法与使用方法

以上,就是你进一步学习Java所必备的基本知识。特别是一些个专业术语和名词,看到这些名词,如果你像看到亲爹一样亲切,那么说明你对Java的基础知识就很熟悉了。

接下来是SSH:

对于初学者来说,这三大框架被赋予了太多神秘的色彩,似乎它们是重中之重的知识!但是对于拥有多年Java开发经验的专业技术人员来说,对于那些Java牛人来说,却对这三大框架不太感冒!难道它们不重要吗?

现在很多企业都在用这三大框架,所以很多企业也把掌握这三大框架作为招聘的必备条件。不可否认的是,也有很多大型企业没有用这三大框架,这些企业经过多年发展,自身已经有一定的技术积累,也形成了自己独特的技术框架体系。这三大框架既可以说很重要,也可以说不重要。

重要的原因在于:

这三大框架对JavaEE开发中所存在的普遍的问题,提供了优美的解决方案,它们蕴含了这个行业中最NB的开发人员的努力和想法,所以,学习这三大框架,你就可以窥探到这些处于技术巅峰的牛人们究竟对一个问题是怎么想的,通过一种什么样的设计思路去解决问题的。

 

所以,对于你来说,你没有太多项目开发的经验,经验是什么?经验就是你知道可能会遇到哪些问题,针对哪个问题可以有哪些解决方法,在某个情景下,哪种解决方法是较好的,哪种方法不太好等等!如果你没做过什么项目,你根本就不会去意识到你可能会遇到哪些问题,而这些问题往往又是非常关键的!解决得不好,会影响到你的程序的稳定性、可扩展性等等!三大框架就给初学者提供了了解你以后可能会遇到哪些问题,以及针对这些问题的解决方案!

当你了解了这三大框架为什么是重要的,那么你也就能理解,为什么这三大框架也可以说是不重要的。如果你曾经开发过很多项目,你碰到了各种各样的问题,凭着你的技术功底,逐个击破了这些问题,在这些人眼里,三大框架(是不是还有N个框架?呵呵)都是浮云!

你属于哪一种人呢?如果你没有太多项目开发经验,那么三大框架对于你来说就是非常重要的!而且,由此你也知道了该怎么去学这三大框架。

 

对于三大框架的学习而言,着力点在于给你展示问题,并触发你自己主动的思考,我们鼓励你提出自己的想法,也许你的想法很白痴,但那毕竟是你自己的想法,如果你不知道牛人的想法,那你怎么知道自己的想法是很白痴的呢?在这种思想的碰撞过程中,你就会逐渐提高自己!

 

所以,三大框架学完之后,你不应该只是看到一大堆配置文件,你不应该只是看到了一些Action,一些Service,一些映射文件,你不应该只知道session.save/update/delete,你不应该只是知道struts2中有一堆interceptor,你不应该只是看到一堆jar包……

如果你只是知道拷贝一堆jar包,定义一系列配置文件之后,SSH三大框架就能够运行起来了,也可以给你干活了,那么,很悲哀的是,你仍然没有掌握三大框架的精粹!请你回答以下问题:

Struts2:

为什么每次请求都要创建一个Action对象?

ModelDriven拦截器的配置中refreshModelBeforeResult解决了什么问题?

为什么在web.xml中配置的StrutsPrepareAndExecuteFilter要过滤所有的请求?

请你给我谈谈ValueStack?

Struts2是如何实现MVC设计模式的?

Spring:

你为什么要用Spring?

请你聊一聊IOC/DI?

什么是声明式的事务管理?为什么要使用声明式的事务管理?Spring如何实现声明式的事务管理?

把spring和hibernate集成,定义事务管理特性的时候,为何要将除了添加、删除、更新操作之外的方法,即主要执行查询任务的方法定义为read-only?

Hibernate:

请你谈谈你对OR映射的理解?

很多人说Hibernate不适合大项目,性能有问题,你是如何理解的?

Hibernate为什么一定要定义一个数据库标识?

为什么Hibernate建议你的实体类实现hashCode和equals方法?

谈谈你对Hibernate实体类中的数据库标识与数据库主键之间关系的认识?

谈谈你对Hibernate关联映射与数据库外键之间关系的认识?

调用session.save方法,hibernate一定会发出insert语句吗?谈谈你的理解

调用session.update方法,hibernate一定会发出update语句吗?谈谈你的理解

请你聊一下以下名词、概念或用法:lazy、lazy=”extra”、inverse、fetch、fetch=”join”、fetch=”subselect”、batch-size

配置了lazy=”true”一定会实现懒加载吗?

请你谈谈Hibernate中的“N+1”问题

请你谈谈Hibernate有哪些最佳实践?

以上并非SSH中全部重点的问题,但它们能考察你能否灵活运用SSH框架!如果你能深刻理解这些问题,再配以合适的实战项目训练,你也会逐渐成为牛人!

最后是项目开发能力:

不管你是学Java还是别的技术,你的根本目的在于给客户创造价值!否则,你下大力气学习的东西,随着技术的进步和更新,很快就会过时!所以,技术的核心在于用技术创造有价值的成果!也就是说,客户需要什么,你就要用技术把客户需要的东西给他造出来!

 

一个公司之所以要用各种福利条件极力挽留你,是因为你能够给公司带来极高的利益!那么,你有什么可以给公司利用的呢?公司最看重你的哪方面的能力呢?

做项目需要的能力很多,其中最核心最基础的就是建模能力。

 

什么是建模能力呢?

给大家一个面试题:

一个保险公司的保险卡管理模块:销售人员领取保险卡信息(保险卡数量、卡号、领取日期),然后直接销售给客户,销售完毕后,将保险卡信息录入保险公司系统内部(销售人员信息、购买人信息、购买的保险卡数量、卡号等),客户登录保险公司网站激活保险卡,需要填写(保险卡卡号、激活密码、被保险人信息、受益人信息)

要求就是:如果这个模块交给你来做,你要怎么做?你要解决哪些问题?你可否画个图,给我描述一下你的想法是什么吗?

这只是一个面试题而已,因为只有简单几句话,所以我把它放到这里,让大家感受一下所谓建模要解决什么问题。业务领域的问题实在是太多了!也许一个几十上百页的需求文档才能把某个业务领域的问题描述清楚,而你的职责就是要把它们实现出来!

某个公司要开发一个考勤管理系统,要求与现有的人力资源系统对接,你是主要的技术负责人,那么,你要做哪些工作呢?

某ERP项目要实现一个排班管理模块,交给你去完成,你如何去完成呢?

不要抱怨项目经理给你的信息太少,不要抱怨客户没有描述清楚他们的需求……你的价值就在于理顺所有的问题 tb ,用各种手段获得你想要的信息,按照一定的思路汇总,并在特定的时间里逐个解决它!

你应该意识到学Java不是一个坦克大战、一个网络飞车、一个CMS那么简单,你不要沉迷于那些技术细节(虽然也是有必要的,但不要转牛角尖),不要满足于实现了CRUD式的项目需求(虽然这是基础中的基础),在你的前方,永远有一个目标在那里,需要你去努力追赶!

今后你将面对更加繁杂的需求,你学习项目的唯一目的,就是:

 

学习如何将需求转化为实现,如何对需求进行分析,如何建立概念模型,如何理顺各种概念之间的关系,如何进行设计,如何选择合适的技术来实现你的设计方案,如何对你的实现进行测试,如何解决你所遇到的形形色色的问题(性能、需求变更等)。

 

利用Java找工作,需要的就是项目经验。

项目经验就是理解项目开发的基本过程,理解项目的分析方法,理解项目的设计思路,理解项目的实现技巧,理解项目的测试方法,理解项目中各种问题的解决方案!!!

看完以上内容,相信身为Java程序员的你,已经清楚自己的目标了!

转载请注明:XAMPP中文组官网 » 一文了解 java项目开发流程_JAVA企业级项目开发