背景介紹 (Background Introduction)

  1. 目前有一些报表客户抱怨打不开
  2. 报表执行过程过长,5、8、10秒甚至更多
  3. 不能及时发现和掌握服务器web站点情况

用戶需求(User Requirements)

  1. 监控web站点执行情况
  2. 使用跟用户相同的谷歌浏览器进行模拟后台解析
  3. 获得web站点初始化时间单位秒
  4. 提供接口给运维人员做监控实时掌握web站点情况

詳細設計(Design details)

1. simple设计

(1)   TipDetail 数据消息

字段(Field

字段说明(Description

备注所有:

Success

是否成功(调用是否成功)

WebstatusInEntity

Message

调用消息(错误或提醒)

T Data

泛型对象(描述相关功能信息)

(2)   WebstatusInEntity站点输入参数实体

字段(Field

字段说明(Description

备注所有:

Url

加载的Url

FilterIps

过滤Ips,多个逗号隔开

FilterPorts

多个逗号隔开

MaxLoadScends

最大加载时间

MinRequstLen

最小请求数

(3)   WebstatusOutEntity  Web解析结果输出对象

字段(Field

字段说明(Description

备注所有:

Id

Id(服务端执行的唯一id

IsFinish

是否结束

IsSuccess

是否成功(是否执行成功)

LoadScends

加载秒数(在MaxLoadScends时间内)

2. 功能接口

description

方法

描述

参数(替换模板内数据)

返回结果

逻辑说明

http://127.0.0.1:8734/NetAnalyzerService?wsdl

Post

WCF接口地址

 

RunWebstatusJson

运行状态分析

WebstatusInEntity webstatusInEntity = new WebstatusInEntity();
webstatusInEntity.setUrl("http://10.134.226.153:81/Reports/powerbi/OEE_BU?rs:embed=true&rs:token=1");   //要执行的web
webstatusInEntity.setFilterIps("10.134.226.153");   //通过谷歌可以监控到Url需要访问的原始Ip,如果有多个可以逗号隔开
webstatusInEntity.setMaxLoadScends(20);             //服务端监控一直执行所等待时间,
webstatusInEntity.setMinRequstLen(100);

 

数据结果集

GetWebstatusJson

获取Webstatus分析详情

Id

1. 相关类:

(1)   package simple;

import com.google.gson.Gson;
import com.google.gson.reflect.TypeToken;
import org.apache.cxf.endpoint.Client;
import org.apache.cxf.jaxws.endpoint.dynamic.JaxWsDynamicClientFactory;

import java.util.ArrayList;
import java.util.List;

/**
 * created by xun-yu.she on 2019/8/15
 */
public class WebstatusTest {

/*
      
程序主入口
    */
   
public static void main(String[]
args) throws Exception {

try {
            String resultJson = RunWebstatusJsonJob(100);
            System.out.println("*******"
+ resultJson);
        } catch (Exception ex)
{

System.out.println("*******"
+ ex.getMessage());
        }

}

/*

  Java调用动态调用Wcf接口
     
执行web查看状态,由于第一二次执行涉及到初始化等,所以难免获取的时间会长一些,
      所以平均的打开速度竟可能以第
3~4次的分析,所以这里我设置的是一个执行的Job,根据情况执行
    */
   
public static String
RunWebstatusJsonJob(int runCount) throws Exception {
        try {
            //初始服务
           
JaxWsDynamicClientFactory
dcflient = JaxWsDynamicClientFactory.newInstance();
            //创建服务
           
Client client =
dcflient.createClient("http://10.60.136.172:8734/NetAnalyzerService?wsdl");
            //初始化序列化对象
           
Gson gson = new Gson();
            Object[] objects;
            //结果集
           
List<WebstatusOutEntity>
webstatusOutEntitys = new ArrayList<WebstatusOutEntity>();
            //参数对象
           
WebstatusInEntity
webstatusInEntity = new WebstatusInEntity();
            webstatusInEntity.setUrl("http://127.0.0.1:81/Reports/powerbi/OEE_BU?rs:embed=true&rs:token=1");   //要执行的web
           
webstatusInEntity.setFilterIps("10.134.226.153");   //通过谷歌可以监控到Url需要访问的原始Ip,如果有多个可以逗号隔开
           
webstatusInEntity.setMaxLoadScends(20);             //服务端监控一直执行所等待时间,
           
webstatusInEntity.setMinRequstLen(100);             //执行一次Url执行大概最小请求数,可以通过谷歌浏览器的network监控到,如果服务端执行的请求数大于最小请求数,就会默认web执行成功
           
//循环多次执行
           
for (int i = 0; i <
runCount; i++) {
                try {
                    objects =
client.invoke("RunWebstatusJson", webstatusInEntity.getUrl(),
webstatusInEntity.getFilterIps(), null,
webstatusInEntity.getMaxLoadScends(), webstatusInEntity.getMinRequstLen());
                    //泛型序列化
                   
TipDetail<WebstatusOutEntity>
resultDetail = gson.fromJson(objects[0].toString(), new TypeToken<TipDetail<WebstatusOutEntity>>()
{
                    }.getType());
                    //线程等待,这等待的时间是服务器端需要根据用户设定的MaxLoadScends的值去监控等待一段时间,所以调用端一般需要在此基础上多增加15+秒,在调用查询接口了解执行情况,服务端同一时间只处理一次请求,不能被多个客户端同时调用
                   
Thread.currentThread().sleep(webstatusInEntity.getMaxLoadScends()
* 1000 + 10000);//毫秒
                   
if (resultDetail.getSuccess()
&& resultDetail.getData() != null) {
                        objects =
client.invoke("GetWebstatusJson",
resultDetail.getData().getId());
                        //泛型序列化
                       
resultDetail =
gson.fromJson(objects[0].toString(), new TypeToken<TipDetail<WebstatusOutEntity>>()
{
                        }.getType());
                       
webstatusOutEntitys.add(resultDetail.Data);
                    }
                } catch (Exception ex)
{

}
            }

String strWebstatusOutEntitys
= gson.toJson(webstatusOutEntitys);
            return strWebstatusOutEntitys;
        } catch (Exception ex)
{
            // statusCode=500 //Wcf挂了
           
System.out.println("*******"
+ ex.getMessage());
            throw ex;
        }

}

}

(2)  
package simple;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.util.List;

/**
 * created by xun-yu.she on 2019/8/14
 *
数据消息对象
 
*/
@Data
@AllArgsConstructor
@NoArgsConstructor
public class TipDetail<T> {

/// <summary>
    ///
是否成功(调用是否成功)
   
///
</summary>
   
public Boolean Success;

/// <summary>
    ///
调用消息(错误或提醒)
    
/// </summary>
   
public String Message;

/// <summary>
    ///
泛型对象(描述相关功能信息)
   
///
</summary>
   
public T Data;
    //public List<T> Datas ;

}

(3)  
package simple;
import lombok.Data;

/**
 * created by xun-yu.she on 2019/8/15
 *
站点输入参数实体
 
*/
@Data
public class WebstatusInEntity {

/// <summary>
    ///
加载的Url
    /// </summary>
   
public String Url;

/// <summary>
    ///
过滤Ips,多个逗号隔开
   
///
</summary>
   
public String FilterIps;

/// <summary>
    ///
过滤Ports,多个逗号隔开
   
/// </summary>
   
public String FilterPorts;

/// <summary>
    ///
最大加载时间
   
///
</summary>
   
public int MaxLoadScends;

/// <summary>
    ///
最小请求数
   
///
</summary>
   
public int MinRequstLen;

}

(4)  
package simple;
import lombok.Data;

/**
 * created by xun-yu.she on 2019/8/15
 * Web
解析结果输出对象
 
*/
@Data
public class WebstatusOutEntity {

/// <summary>
    /// Id
(服务端执行的唯一id
   
///
</summary>
   
public String Id ;

/// <summary>
    ///
是否结束
   
///
</summary>
   
public boolean IsFinish ;

/// <summary>
    ///
是否成功(是否执行成功)
   
///
</summary>
   
public boolean IsSuccess ;

/// <summary>
    ///
加载秒数
   
///
</summary>
   
public int LoadScends ;

}

前提條件(Design Constants)

1.  导入需要的包

<dependencies>
    <dependency>
        <groupId>org.apache.httpcomponents</groupId>
        <artifactId>httpclient</artifactId>
        <version>4.5.4</version>
    </dependency>
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>fastjson</artifactId>
        <version>1.1.41</version>
    </dependency>
    <dependency>
        <groupId>org.apache.cxf</groupId>
        <artifactId>cxf-spring-boot-starter-jaxws</artifactId>
        <version>3.1.11</version>
    </dependency>
    <dependency>
        <groupId>org.scala-lang</groupId>
        <artifactId>scala-library</artifactId>
        <version>2.11.0</version>
    </dependency>
    <dependency>
        <groupId>com.google.code.gson</groupId>
        <artifactId>gson</artifactId>
        <version>2.8.5</version>
    </dependency>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <version>1.16.22</version>
    </dependency>
</dependencies>

最終用戶特征(User characteristics)

总结:此为java调用.net wcf调用实例

Web循环监控Java调用 / Java调用.net wcf接口的更多相关文章

  1. 修改rabbitmq Web UI 监控页面的端口

    在前几天工作中遇到一个问题,部署服务器,需要用rabbitmq自带的一个web UI监控组件,但是15672的端口没有对外映射.尝试了几种办法.开始修改rabbitmq.config,rabbitmq ...

  2. .Net调用Java端带有WS-Security支持的Web Service各方案实战【转】

    原文:http://www.xuebuyuan.com/641669.html 到现在为止,我们AEP平台已经发布很长一段时间了,也有很多ISV接入并上线了,就语言而言,目前主要有三类:Java..N ...

  3. Java与WCF交互(二):WCF客户端调用Java web service【转】

    原文:http://www.cnblogs.com/downmoon/archive/2010/08/25/1807982.html 在上篇< Java与WCF交互(一):Java客户端调用WC ...

  4. 转载——Java与WCF交互(二):WCF客户端调用Java Web Service

    在上篇< Java与WCF交互(一):Java客户端调用WCF服务>中,我介绍了自己如何使用axis2生成java客户端的悲惨经历.有同学问起使用什么协议,经初步验证,发现只有wsHttp ...

  5. 使用Java编写一个简单的Web的监控系统cpu利用率,cpu温度,总内存大小

    原文:http://www.jb51.net/article/75002.htm 这篇文章主要介绍了使用Java编写一个简单的Web的监控系统的例子,并且将重要信息转为XML通过网页前端显示,非常之实 ...

  6. JsBridge实现Javascript和Java的互相调用

    前端网页Javascript和Native互相调用在手机应用中越来越常见,JsBridge是最常用的解决方案. 在Android开发中,能实现Javascript与Native代码通信的,有4种途径: ...

  7. php调用java

    PHP调用JAVA方式 1.     背景 在开发招商银行信用卡分期付款功能过程中,在支付成功之后需要对银行的返回数据进行签名验证,因签名加密方式招商银行是不提供的,只提供了相应的JAVA验证类测试例 ...

  8. Java 常用远程调用协议比较

    一.综述本文比较了RMI,Hessian,Burlap,Httpinvoker,web service等5种通讯协议的在不同的数据结构和不同数据量时的传输性能.RMI是java语言本身提供的远程通讯协 ...

  9. 在网页程序或Java程序中调用接口实现短信猫收发短信的解决方案

    方案特点: 在网页程序或Java程序中调用接口实现短信猫收发短信的解决方案,简化软件开发流程,减少各应用系统相同模块的重复开发工作,提高系统稳定性和可靠性. 基于HTTP协议的开发接口 使用特点在网页 ...

随机推荐

  1. [Vue] : Vue实例的声明周期

    vue实例的生命周期 什么是生命周期:从Vue实例创建.运行.到销毁期间,总是伴随着各种各样的事件,这些事件,统称为生命周期! 生命周期钩子:就是生命周期事件的别名而已: 生命周期钩子 = 生命周期函 ...

  2. 初学c++动态联编

    先看一下什么是C++联编? 我觉得通俗的讲,用对象来访问类的成员函数就是静态联编. 那什么是动态联编: 一般是通过虚函数实现动态联编. 看一个动态联编的例子: 我比较懒,所以直接粘贴了MOOC视频的图 ...

  3. typedef void (*funcptr)(void)的含义

    fun a;//等价于void (*a)(); 这样声明起来就方便多了 void (*a)();表示a是个指针,指向一个不带参数.返回值为空的函数 定义一个函数指针类型. 比如你有三个函数: void ...

  4. MIME协议(二)

    MIME协议 RFC822文档定义了邮件内容的主体结构和各种邮件头字段的详细细节,但是,它没有定义邮件体的格式,RFC822文档定义的邮件体部分通常都只能用于表述一段普通的文本,而无法表达出图片.声音 ...

  5. JavaWeb_(Hibernate框架)Hibernate论坛项目中多对多案例

    基于SSH论坛小型项目 传送门 用户和发帖进行举例 多对多关系:多个用户可以回复多个帖子 因此引入了一张回复表,用来保存用户id和帖子id CREATE TABLE `hforum`.`answer` ...

  6. java线程基础方法详解

    一.线程状态转换 1.新建状态(New):新创建了一个线程对象. 2.就绪状态(Runnable):线程对象创建后,其他线程调用了该对象的start()方法.该状态的线程位于可运行线程池中,变得可运行 ...

  7. golang——reverse反转字符串

    reverse反转,是个比较基础算法.要实现这个方法,从常理考虑可以申请一个新空间,然后将字符串的从尾到头依次填充该空间,最后新空间的内容就是反转后的结果了,这个方式的算法复杂度是O(n),并且还需要 ...

  8. CISCO实验记录二:路由器基本操作

    一.路由器基本操作要求 1.设置路由器本地时间 2.启用光标跟随 3.设置路由器标语信息和描述信息 4.为接口配置描述信息 5.快速恢复接口到出厂设置 二.路由器基本操作命令 1.设置路由器本地时间 ...

  9. Flume-几种拓扑结构

    一.串联 Flume Agent 连接 这种模式是将多个 flume 顺序连接起来了,从最初的 source 开始到最终 sink 传送的目的存储系统.此模式不建议桥接过多的 flume 数量,flu ...

  10. VIM | vim操作大全

    1. 关于Vim vim是Linux下第二强大的编辑器. 虽然emacs是公认的世界第一,我认为使用emacs并没有使用vi进行编辑来得高效. 如果是初学vi,运行一下vimtutor是个聪明的决定. ...