java程序员的业务场景基础知识,JBPM,ANT,FreeMarker

用来描述发布的接口(服务)

soap(simple object access protocol)

是xml和http的结合,是webservice数据通信的协议

uddi 用来管理,查询webService的服务

(没必要主动说)

webservice的具体三种实现方式(框架)或者三种实现框架的区别

1. Axis2:可以用多种语言开发,

是一个重量级框架,功能非常强大,

但是它的性能比较低。

2. Xfire:它相比Axis2来说是一个轻量级框架,

它的性能要比Axis2高。

3. cxf:是Xfire的升级版,就好比是,

struts2是webwork的升级,

然后cxf和spring集成起来非常方便,简易,

性能方面也要比Xfire高。

【注】jdk6 自带的webservice jws

(主动说)

业务场景

我在以前做项目的时候,其中遇到一个功能,

需要进行两个项目之间的数据的传输,

项目经理让我去完成这个任务,我根据以往的项目经验,

想到两种解决方案,第一种

就是开放另外一个项目的数据库的权限给我,

然后我直接通过访问另外一个项目的数据

库,来得到需要的信息,但后来我分析了下,觉的这种方式不安全,

而且因为当时

这个项目是另外一家公司负责在做,所以数据库里面的表结构,

以及以后牵涉

到的责任问题都很多,所以我就采用了第二种方案,

即通过webservices的方式,进行

异构系统之间数据信息的传递,webservices的具体实现,

有xfire,cxf,axis2,

我根据以往的项目经验,了解到cxf是xfire的升级版本,适用于java语言,

xfire/cxf 性能比axis2要高,并且和spring整合起来也比较方便,

而axis2支持更多的语言,

性能相对于cxf要低,通过上面分析,

结合我们目前的两个项目都是基于java

语言的,所以我采用cxf这种方式实现了两个项目之间数据的传递,

我们为了保证

webservice的安全性我们采用了基于

WS-Security标准的安全验证(使用CXF回调函数)。

(没必要主动说)

webservice服务端配置流程

首先在web.xml中引入cxfServlet核心类,

指定对以/cxf开头的url路径提供webservice服务,

之后我们在要发布成webservice接口上添加@Webservice 注解,

而且还要在实现类上添加同样的webservice注解并且要说明实现了哪个接口,

之后在spring-webservice.xml中发布webservice服务,

通过jaxws:endpoint这个标签,

并且在标签配置implementor和address来表明实现服务的类,

以及发布的地址,

最后在浏览器中输入相关的webservice地址?wsdl来验证服务是否发布成功。

(没必要主动说)

webservice客户端的配置

首先通过wsdl2java根据发布的webservice服务端地址的wsdl

生成客户端调用的中间桥梁java类,

将生成的java类拷贝到客户端项目中,

配置spring-client.xml文件,

通过jaxws:client定义一个bean,

并通过address属性指明要访问的webservice的服务地址,

通过serviceClass指明充当中间桥梁的服务类,之后获取该bean,

就可以通过它来访问发布的webservice接口中的方法。

十八、oracle索引概述

索引呢 是与表相关的一个可选结构,可以提高sql语句的检索效率,相当于我们的字典目录 ,可以快速进行定位 ,所以可以减少磁盘I/O, 但是因为索引在物理与逻辑上都是独立于表的数据 它会占用一定的物理空间(额外磁盘空间) 所以并不是索引越多越好,而我们应该根据业务需求去创建索引,而且进行增删改操作时 oracle又要自动维护索引 所以在一定程度上也降低了维护速度,而且我们在创建索引和维护索引要耗费时间,这种时间随着数据量的增加而增加,我们一般创建索引呢 是这样创建的 create index 索引名 on 表名(字段),索引又分为普通索引 唯一索引(unique) 单个索引 复合索引(又叫组合索引,在索引建立语句中同时可包含多个字段名),顺序索引,散列索引,位图索引。

十九、oracle存储过程

存储过程就是封装一些sql的集合,也就是一条条的sql语句,过程的优点就是简化了sql命令加上它是预编译的,所以它的执行效率和性能较高,再者,如果不调用过程的话就要和数据库发生多次交互,调用过程只需传一个命令所有的那些执行逻辑都在数据库端执行,所以说它降低了网络的通信量,其次,存储过程大大提高了安全性,这就是优点

缺点呢,就是不同的数据库对过程支持的关键字支持的关键字都是不一样的,所以它的移植性是非常差的,再者,它的维护性难度也比较大,因为它没有专业的调试和维护工具,所以说它维护起来比较麻烦,这就是存储过程的基本概述.

二十、Junit 业务场景

在我们开发项目的时候为了提高代码的性能和保证逻辑正确性,在我们编写代码后往往都要进行单元测试,来验证代码,当时我们公司开发人员全部使用的main方法来进行验证,但是使用mian的最大缺点就是不能将多个类同时进行验证,验证的结果不直观,测试复杂(每个类都要写main方法,单个运行),一定程度上浪费时间,所有我和项目经理提议使用专业测试工具Junit来进行测试,因为Junit是一个Java语言的单元测试框架 ,测试简单,不仅可以提供工作效率和代码的质量,也提高团队的合作能力,我提议后我们进行了Junit的培训使用Junit4加注解的方式来测试。

二十一、Apache+Tomcat 实现负载均衡及seesion复制

当我们tomcat访问量大,线程连接数不够时,我们考虑到了tomcat的负载均衡来分担过多的访问.性能方面负载均衡也能利用多台tomcat来增大内存量,

流程,准备工作apache,Jk_mod,tomcat,在apache的conf/httpd.conf文件中 使用include 标签引入我们自定义的一个mood_jl.conf,在modules中引入下载的k_mod-apache-X.X.XX.so文件,在其中引入我们的.so,及work.properties文件,及指定负载分配控制器controller,在work.properties文件中worker.list=controller,tomcat1,tomcat2指定service,worker.tomcat1.port Ajp端口号,type 是ajp,host为指定ip,lbfactor 指定分配权重值越大分担请求越多,worker.controller.type=lbworker.controller.balanced_workers=tomcat1,tomcat2 指定分担请求的tomcat Session的复制在tomcat中service.xml中Engine标签加入 jvmRoute 值为work,properties中指定的tomcat名称,然后打开

我们在做这个项目时,我们考虑到服务器性能的问题,我们最开始想到使用纵向扩展,来增加硬件的配置提高其性能,但这样做比较耗费资金,而且服务器内存空间也是有限的;所以后来就想到使用横向扩展来达到这一目的

当时我们的apache是通过jk借助于ajp协议与tomcat进行通信的,在我们不进行负载均衡之前,那所有的请求都由一台tomcat进行处理,这样会使我们的tomcat所承受的压力增大,而我们进行负载均衡之后,同样数量的请求经过apache和jk将其分发到多台tomcat进行处理,从而降低每台tomcat所承受的压力,而且当其中一台机器宕机时,其他机器还可以继续提供服务,保证服务不间断。

在这个过程中,我们遇到了session问题,然后我此昂到用session复制来解决这个问题;

在apache的配置文件中增加session粘带特性:

worker.lb.sticky_session=1

worker.lb.sticky_session_force=0

Tomcat的配置

修改server.xml文件:

增加jvmRoute=”tomcat2” *. jvmRoute赋的值为worker.properties中配置的相应的server名一致

将此配置的注释去掉

修改应用的web.xml文件

在应用中的web.xml文件中增加

如果这样做,当第一次访问的时候,会把所以数据全部缓存到第一台服务器上,通过web配置文件,会把第一台缓存的数据全部复制到第二胎服务器上,这样做就加大网路通信量,导致阻塞,所以我们就想到了可以通过memcached分布式缓存来存取session从而解决上述问题。

二十二、Ant业务场景

Ant是基于java语言编写的,因此具有跨平台的特性,此外还具有简洁方便,灵活

配置的特性,因此我就在XX项目中使用ant进行项目的编译,打包,部署操作。使用ant

之后,如果我们在客户那里修改代码后,就可以直接使用ant进行编译,打包,部署,而不需要为了编译,打包,部署专门在客户那里安装eclipse.此外使用ant也可以直接和svn进行交互,下载源码的同时进行编译,打包,部署。

二十三、maven业务场景

maven业务场景

前段时间在研究maven,知道maven是一个项目管理工具,其核心特点就是通过

maven可以进行包的依赖管理,保证jar包版本的一致性,以及可以使多个项目共享

jar包,从而能够在开发大型j2ee应用的时候,减小项目的大小,并且和ant

比起来,maven根据“约定优于配置”的特性,可以对其项目的编译打包部署进行了

更为抽象的封装,使得自己不需要像ant那样进行详细配置文件的编写,直接使用

系统预定好的mvn clean,compile,test,package等命令进行项目的操作。于是我就

在XX项目中采用了maven,为了保证团队中的成员能够节省下载jar包所需要的时间,

于是我就采用nexus搭建了在局域网内的maven私服,然后通过配置settings.xml中

建立mirror镜像,将所有下载jar包的请求都转发到maven私服上,之后通过在pom.xml

即(project object model)中配置项目所依赖的jar包,从而达到在构建项目的时候,

先从本地仓库中查找,如果不存在从内部私服查找,如果不存在最后再从外网central

服务器查找的机制,达到了节省下载带宽,提高开发效率,以及jar包重用的目的。

ant业务场景

ant是基于java语言编写的,因此具有跨平台的特性,此外还具有简洁方便,灵活

配置的特性,因此我就在XX项目中使用ant进行项目的编译,打包,部署操作。使用ant

之后,如果我们在客户那里修改代码后,就可以直接使用ant进行编译,打包,部署,

而不需要为了编译,打包,部署专门在客户那里安装eclipse.此外使用ant也可以

直接和svn进行交互,下载源码的同时进行编译,打包,部署。

maven的常用命令

mvn eclipse:clean eclipse:eclipse -Dwtpversion=2.0

mvn clean package

maven的生命周期是独立的,但是生命周期下的阶段是相互关联并且延续的。

maven的生命周期

clean(清理):clean;default(默认):compile,test,packageinstall;site(站点)

二十四、Servlet的概述:

Servlet是一个web容器,我们通常用的servlet是httpservlet,而httpservlet又是继承于genericservlet,而genericservlet又实现了servlet接口

servlet的生命周期是 :先进行实例化,然后是初始化,然后是提高服务,然后销毁,最后不可用,在这五个生命周期,其中,初始化是调用的init方法,这个方法只有一个,而提高服务的时候调用的是service方法,而我们具体在我们所写的这个方法中,因为我们继承了httpservlet,其实就是对应了doGet(),doPost(),这种方法,然后据我了解,servlet是单例的。非线程安全的,我们通常有一下几种方案来解决:

第一种,继承SingleThreadModel但是这样每次都会创建一个新的servlet实例,但这样消耗服务器的内存,降低了性能,并且这个接口现在已经过时了,不推荐使用。

第二种:我们尽量避免使用全局变量,就我个人而言,我比较喜欢使用这种方法。

第三种,我们可以通过使用ThreadLocal, 内部结构是一个Map结构,用当前线程作为key,他会创建多个副本。get,set方法

第四种,我们当然还可以来加锁,进行解决线程问题。

而且我还知道,向我们这种常用的MVC框架,struts1,spring这些MVC框架,都是基于servlet发展而来的,就比如struts1 的核心总控制器是ActionServlet,而springMVC的前端总控制器是dispatchServlet,在项目我们曾经用serlet来生成 图片验证码的,防止用户进行暴力破解

servlet的配置文件 web.xml

ImageCodeServlet

org.leopard.code.ImageCodeServlet

ImageCodeServlet

/d

描述:

我在web.xml中,我首先需要写一个servlet标签,servlet标签中有两个子标签,一个叫servlet-name,这个name可以随便起,但是要保证唯一性,除此之外,在这个servlet-name下有一个servlet-class,这个servlet-class对应的就是我后台提高服务的servlet,除此之外还有一个servlet-mapping,这个里边首先有一个servl-name。,这个servl-name首先要保证和上边的servlet-name保持一致,除此之外还有一个url-pattern,这是一个虚拟路径,是用来发送请求的url地址

java程序员的业务场景基础知识,JBPM,ANT,FreeMarker

业务场景篇未完待续,敬请关注期待


分享到:


相關文章: