美文网首页java技术栈进阶Java服务器端编程
记一次搭建发布web应用的经历

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

作者: 进击的小鹿 | 来源:发表于2017-08-01 15:19 被阅读25次

    原先都是做数据开发的,换了公司之后,做回了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地址的解析。

    相关文章

      网友评论

        本文标题:记一次搭建发布web应用的经历

        本文链接:https://www.haomeiwen.com/subject/idxokxtx.html