记一次搭建发布web应用的经历

原先都是做数据开发的,换了公司之后,做回了Java后台开发。从svn到git,终究会有一个趟坑的经历。
git具体的命令技能就不说了,会开新的帖子。下面就说下这次小白经历吧。

项目背景:从调用oracle 提供的webService 转到调用 接口服务(接口直接调用oracle的函数、存储过程等)。由此可见,项目可简单,现阶段就提供一个接口就可以。代码很简单,趟坑很重要!

1.mybatis 调用存储过程

平常用mybatis,就是搞搞select,delete,update,insert等。没有调用过存储过程。

那么mybatis的mapper里怎么调用存储过程等呢?

//这个带返回的
 <select id="idname" statementType="CALLABLE" parameterType="model名字" resultType="java.lang.String">
{#{result,mode=OUT,jdbcType=VARCHAR} = call 存储过程名称(
    #{param, jdbcType=VARCHAR}……入参列表
)}
</select>


//也可以,out在后面

{call queryTeacher(#{fid,mode=IN,jdbcType=INTEGER},#{type,mode=IN,jdbcType=VARCHAR},#{name,mode=OUT,jdbcType=VARCHAR})}

然后在对应的Service,调用相应的方法,执行存储过程后,可以获取到相应的结果。思路是一致的

从select可以看出,主要声明 statementType="CALLABLE",在代码体中 call 某某名称

参考:http://blog.csdn.net/walkcode/article/details/9318039

2.json转换

原本已经是返回的json格式的东东,而为了符合接口规范,需要参数重新组织,返回code,message,data.

针对数据库返回的格式,建立对应的result实体进行解析,填充到接口定义的返回字段中。

主要用的(fastjson):

  • JSON.parseObject():解析成对象
  • 根据需要转换成相应的状态码
  • 分字段,填充到新的返回中

3.上传git

之前知道项目是上传到git,然后自动部署的。没想到自己还是躺了。

运维搞得自动部署会去读取一级目录下的pom.xml,而我的pom.xml在二级目录下。(部署打印日志,找不到pom.xml)

坑,又重新把项目搭建了。

4.各种报错

DruidDataSource配置

错误描述:

(1)部署后,在配置文件中DruidDataSource下配置的变量不能读取。(未解决,怀疑是运维的坑)

直接把配置换成了死代码。
(2)catalina.sh 自动部署的坑:


catalina.png

启动参数的问题

JAVA_OPTS="$JAVA_OPTS -Duser.language=en -Duser.country=US"

(3)

    Cannot resolve reference to bean 'sqlSessionFactory' while setting bean property 'sqlSessionFactory'; 
nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [spring/applicationContext-dao.xml]:
 Cannot resolve reference to bean 'dataSource' while setting bean property 'dataSource'; nested exception is org.springframework.beans.factory.BeanCreationException:
 Error creating bean with name 'dataSource' defined in class path resource [spring/applicationContext-datasource.xml]: Invocation of init method failed; nested exception is java.sql.SQLException:
The Network Adapter could not establish the connection 

主要看最后这句话The Network Adapter could not establish the connection,因为datasourse配置的db ip 是一个域名,so 没有被解析。

因此找到/etc/hosts文件加上映射即可。

Hosts是一个没有扩展名的系统文件,可以用记事本等工具打开,其作用就是将一些常用的网址域名与其对应的IP地址建立一个关联“数据库”,当用户在浏览器中输入一个需要登录的网址时,系统会首先自动从Hosts文件中寻找对应的IP地址,一旦找到,系统会立即打开对应网页,如果没有找到,则系统会再将网址提交DNS域名解析服务器进行IP地址的解析。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,080评论 19 139
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,987评论 6 342
  • 1. 简介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的...
    笨鸟慢飞阅读 5,725评论 0 4
  • 麻将是中国的国粹,打麻将可以让人的大脑更加的灵活,还能预防老年痴呆。每年过年我都会一旁看着我爸和爷爷在牌桌上玩的风...
    我是胖少阅读 263评论 0 0
  • 每个人的衣橱里都少不了条纹裙,因为它们是流行里不出局的宠儿。不管潮流怎么变换,总有它的一席之地。条纹元素也是一直都...
    小天小哥阅读 2,694评论 0 200