蓝桥软件学院告诉你Java开发的几个注意点

2017-05-09

蓝桥软件学院告诉你Java开发的几个注意点


1.将一些需要变动的配置写在属性文件中


有时候,我们在编程的时候往往会忘记配置属性,所以,在文件并发执行的时候使用的线程数可以将其设置成可以在属性文件中进行配置,这样在无论程序是在开发的环境中,还是是在测试的环境的里,程序的编译和运行都是没有阻碍的;但是如果是部署在prod上,系统有时就会抛出各种异常,也许就是因为环境更没有配置好导致的。这种方法也同样适用于我们在配置路径、服务器和端口号等待情况。



2.测试中尽可能模拟线上环境



测试是在开发过程中一个很重要的一个环节,Java程序员如果能够把测试做好,对他的影响也还是很大的。在产品的生产过程中通常一个典型的场景就只是使用到1到3个账户来进行性能的测试,而这个数量本就是应该是1000到2000个,所以做好测试还是很重要的。在我们做性能测试的时候,使用的测试数据必须是真实而且是未经过裁剪的;测试过程中,不贴近于真实环境的性能测试,可能会给我们带来不可预料的性能、多线程的问题。



3.对于所有外部调用以及内部服务都要做容错处理



在进行调用的时候,不管是对于RPC的调用还是对第三方服务的调用,我们都应该仔细核实,不能想当然的认为可用性是完全百分之百的,我们应当避免这种服务器出现调用超时和重试的情况,这样将会对应用程序的稳定性和性能造成不利的影响。



timg.jpg



4.安全设计上一个系统要遵循最小权限原则



系统的安全涉及到用户自身的安全问题,所以在网络服务安全的时候,在设计系统时,我们需要遵循“最小权限”的原则,最好采用白名单等方式,来拒绝黑客轻易的利用它来进行服务攻击。



5.需要提供以下文档


编写好单元测试的文档并使其拥有良好的代码覆盖率。 

高层次的设计图:描述了所有的组件,交互和结构。 

详细的设计图:具体到代码层面的设计,以及一些关键逻辑的流程。 

系统组成文档:说明系统的所有组成文件、配置文件等。 

数据库层面的dml以及ddl文档,尤其是sql查询语句需要经过dba或者核心开发人员的review才能够上线。 

不仅仅对于传统的开发流程,即使对于敏捷开发,这些文档也是必不可少的,否则在后续的维护、交接上会带来很大的不便。


6.做好系统关键功能的监控、错误恢复、备份等


对于系统一些至关重要的功能模块要做好对其的监控,防止其影响系统的运行,造成不可估算的损失。另外,如果可以,监控到故障后去去试图恢复,恢复失败再发送告警。对于一些很重要的数据文件,还要做到冗余备份,防止发生一些突然故障造成数据丢失。


7.数据库设计时设计一些便于追踪历史、整理的列


比如create_time、update_time可以说明记录的创建和更新时间。create_by、update_by可以说明记录是由谁创建和更新的。


此外,删除记录有时候并非真正删除,这时需要设计表示此记录状态的列,如可以取‘Active’或‘Inactive’的 ‘status’列。


8.制定好项目回滚计划


每当新的功能上线时,一旦遇到发生故障,这时候如果没有一份回滚计划,那么可能会手忙脚乱而造成线上服务一段时间用户不可用。若拥有一个良好的回滚计划,可以让你能够有条不紊的执行相关操作,在可控时间内将系统恢复到一个可运行的状态。


9.项目上线前要做好量化分析


对于项目中用到的内存、数据库、文件、缓存等,一定要做好量化的分析。需要预估出来未来的一段时间的空间占用多少,给运维分配机器时一个参考。以此来防止,由于数据量的增长过快,导致存储空间不够。这一点是非常重要的,不然很容易造成线上服务不可用。


10.制定好系统的部署计划。


系统部署的平台是一个至关重要的部分。对于部署平台的描述,不能仅限于一台服务器、两个数据库这个层面,至少需要包括


操作系统的特定版本,JVM等。 

有多少内存(包括物理内存,JVM堆内存,JVM栈内存和JVM永久代的空间)。 

CPU(内核数)。 

负载均衡器,需要的节点数、节点类型,比如是Active-Standby型还是Active-Active型。 

文件系统要求,例如,你的应用程序可能会收集生成的日志并将其保存很长的周期,之后才进行归档。这样的话,你就需要有足够的硬盘空间。


上一篇:Cookie与Session的区别-总结很好的文章

下一篇:Java程序员编程面试取胜的8个技巧,蓝桥软件学院告诉你啦