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

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

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

1.mybatis 调用存储过程

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

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

//这个带返回的
 


//也可以,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 自动部署的坑:


记一次搭建发布web应用的经历_第1张图片
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地址的解析。

你可能感兴趣的:(记一次搭建发布web应用的经历)