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

比如,没有把一些需要并发执行时使用的线程数设置成可在属性文件中配置。那么你的程序无论在DEV环境中,还是TEST环境中,都可以顺畅无阻地运行,但是一旦部署在PROD上,把它作为多线程程序处理更大的数据集时,就会抛出IOException,原因也许是线上环境并发造成也许是其他。如果线程数目可以在属性文件中配置,那么使它成为一个单线程应用程序就变得十分容易了。我们不再需要为了解决问题而反复地部署和测试应用了。这种方法也同样适用于配置 URL、服务器和端口号等。

这里推荐使用属性文件外化这些配置,文件格式使用properties、yaml、hocon、json都可以。下面的类实现了对这些格式的文件的spring注入支持,包括占位符支持。

https://github.com/superhj1987/awesome-libs/blob/master/src/main/java/me/rowkey/libs/spring/config/AwesomePropertyPlaceholderConfigurer.java

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

生产过程中一个典型的场景就是只使用1到3个帐户进行测试,而这个数量本应是1000到2000个的。在做性能测试时,使用的数据必须是真实并且未经裁剪的。不贴近真实环境的性能测试,可能会带来不可预料的性能、拓展和多线程问题。这里也可以采取预发布环境的方式来解决部分问题。

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

不管是RPC调用还是对于第三方服务的调用,都不能想当然的认为可用性是100%的。不允许出现服务调用超时和重试,将会对应用程序的稳定性和性能造成不利的影响。

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

网络服务随处可见,从而使得黑客可以轻易地利用它进行拒绝服务攻击。所以,设计系统时,需要遵循“最小权限”原则,采用白名单等方式。

5. 需要提供以下文档

  1. 编写单元测试文档并使其拥有良好的代码覆盖率。
  2. 高层次的设计图:描述了所有的组件,交互和结构。
  3. 详细的设计图:具体到代码层面的设计,以及一些关键逻辑的流程。
  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型。
  • 文件系统要求,例如,你的应用程序可能会收集生成的日志并将其保存很长的周期,之后才进行归档。这样的话,你就需要有足够的硬盘空间。

11. 选择最合适的工具/技术

很多情况下,开发者会在生产系统中使用一门想要学习的语言或某种工具。通常这不是最好的选择。比如,为已经实际上是关系型的数据使用NoSQL数据库。不管是语言还是工具,都有其适用的场景。不能求新,也不能以“自我”为标准。

12. 在一些关键技术领域具有充足的知识储备。

  • 设计模式
  • JVM调优
  • 多线程“并发问题”
  • 事务问题,包括分布式事务
  • 性能问题,包括GC、计算等
  • 缓存

Ps:此文部分内容来自网上资料。

原文出处: 后端技术杂谈

from: http://www.importnew.com/21453.html

Java开发的几个注意点相关推荐

  1. Java开发工具简介

    Java语言是一种解释性的语言,即读一句程序执行一句,这样就需要一 个解释器完成源程序到机器语言的翻译过程.同时Java是跨平台的语 言,跨平台是指Java程序可以在安装任何操作系统的计算机上运行,起 ...

  2. linux java 构建工具有哪些,Linux ant --强大的Java开发构建工具

    用途说明 ant严格说来,ant其实并非原生的Linux命令,但它是一个使用广泛.功能强大的跨平台构建工具程序,尤其是进行Java开发时,许多开源的Java项目都使用ant作为构建工具.ant命令一般 ...

  3. android 设置setmultichoiceitems设置初始化勾选_阿里巴巴Java开发手册建议创建HashMap时设置初始化容量,但是多少合适呢?...

    集合是Java开发日常开发中经常会使用到的,而作为一种典型的K-V结构的数据结构,HashMap对于Java开发者一定不陌生. 关于HashMap,很多人都对他有一些基本的了解,比如他和hashtab ...

  4. java string 占位符_驳《阿里「Java开发手册」中的1个bug》?

    前两天写了一篇关于<阿里Java开发手册中的 1 个bug>的文章,评论区有点炸锅了,基本分为两派,支持老王的和质疑老王的. 首先来说,无论是那一方,我都真诚的感谢你们.特别是「二师兄」, ...

  5. Java开发环境的搭建以及使用eclipse从头一步步创建java项目

    原文:出自本人的Linux博客http://blog.csdn.net/unix21/article/details/18813173 一.Java 开发环境的搭建 这里主要说windows环境下怎么 ...

  6. Java开发环境的搭建以及使用eclipse创建项目

    一.Java 开发环境的搭建 这里主要说windows环境下怎么配置Java环境.如果是Linux环境参考本博客另一篇文章即可: Linux环境安装卸载JDK 1.首先安装JDK java的SDK简称 ...

  7. 《Java 开发从入门到精通》—— 2.2 编写第一段Java程序

    本节书摘来异步社区<Java 开发从入门到精通>一书中的第2章,第2.2节,作者: 扶松柏 , 陈小玉,更多章节内容可以访问云栖社区"异步社区"公众号查看. 2.2 编 ...

  8. 初级java开发学习路线_成为初级全栈Web开发人员的10分钟路线图

    初级java开发学习路线 So you have started your journey into the world of web development. But what do you lea ...

  9. java培训分享:学习java开发的优势是什么

    想要进入到互联网行业的小伙伴,经常比较纠结学那个学科比较好,目前java.web前端.Python等都是非常热门的行业,前景也是比较好的,选择java学科的人比较多,那么学习java开发的优势是什么呢 ...

  10. java开发培训好学习吗?难度大不大?

    ​ 互联网快速的发展,不断的在进行变革和更新,越来越多的人都对这个行业充满向往,很多人都想要学习java技术,那么java开发培训好学习吗?难度大不大?来看看下面的详细介绍. java开发培训好学习吗 ...

最新文章

  1. 机器学习入门(16)— CNN 池化层概念和特征
  2. 人人都能学会的python编程教程11:定义函数
  3. 重置一个画面大小的方法
  4. jsp中给div加背景_web前端入门到实战:详解css3如何给背景图片加颜色遮罩
  5. 2012年总结2013展望 向岁月致敬 对未来憧憬
  6. 关于tagLyst工具授权验证的分析报告
  7. BZOJ3787 gty的文艺妹子序列 【树状数组】【分块】
  8. MarkDown 编辑器字体改颜色大小等常用操作
  9. 项目3-商城-1-注册登录首页
  10. linux系统外接硬盘_Linux添加硬盘和挂载
  11. 实际成本法 与 计划成本法 用的到科目
  12. Word中只修改某一页的页眉页脚,其它页的保持不变
  13. 关于blocked by CORS policy的跨域问题
  14. weblogic漏洞总结复现
  15. bootbox.js实践总结(一)
  16. SpringBoot 封装返回类报错:No converter found for return value of type
  17. 【Servlet】什么是Servlet;常见状态码;Servlet API;Cookie和Session
  18. Stay hungry, Stay young
  19. 福州大学计算机考研要准备多久,福州大学(专业学位)计算机技术考研难吗
  20. 简单的excel考勤表

热门文章

  1. Python数据结构与算法(第五天)
  2. 【反欺诈】互金欺诈与反欺诈
  3. 数据分析:2020年3月汽车工业经济运行情况
  4. R统计笔记(四):中括号与双中括号的差异
  5. 从员工出走仅剩 5 人,到一支打胜仗的铁军
  6. MySQL - Explain深度剖析
  7. Spring JDBC-数据连接泄露解读
  8. python re正则匹配_python re正则表达式模块
  9. blp模型 上读下写_Java高并发编程(三):Java内存模型
  10. 阿里巴巴开源分布式框架Seata TCC模式深入分析