最近在写一个监控,主要目前是监控服务是否挂了,原理很简单,用脚本定时的去访问一下服务的接口,看服务是关挂了,监控dubbo的时候我需要一个工具类,指定ip端口服务名直接访问dubbo服务,找资料的过程中我发现cmd也可以直接调用dubbo服务
cmd调用dubbo方法
- telnet 127.0.0.1 8089
这时候输入ls 就可以直接查出服务列表
查服务中可以调用的方法
- ls com.phpsong.DemoService
服务端写个接口,返回success,就表示成功
- invoke com.phpsong.service.HeartBeatService.heartbeat()
调用当时如果是一个对象的方式
- invoke com.phpsong.service.GoodsService.getGoods({"class":"com.phpsong.dto.GoodsDTO","goodsCode":"XXXXXX"})
根据这个方式找到一个工具类
- package com.phpsong.monitor.utils;
-
- import java.io.InputStream;
- import java.io.PrintWriter;
- import java.net.Socket;
- import java.util.Map;
- import java.util.Scanner;
-
- public class DubboUtil {
-
- /**
- * 为了监控服务是否能正常访问,没有参数
- * @param ip
- * @param methodName 包路径.类名.方法名
- * @return
- */
- public static String noParamInvokeDubbo(String ip,int port,String methodName){
- String request = methodName + "()";
-
- //String ip = dubboUrl.split(":")[0];
-
- //int port = Integer.parseInt(dubboUrl.split(":")[1]);
-
- return telnetDubbo(ip, port, request);
- }
-
-
- public static String invokeDubbo(String dubboUrl, Map<String, String> map) {
-
- String className = map.get("className");
- String methodName = map.get("methodName");
- String params = map.get("params");
-
- String request = className + "." + methodName + "(" + params + ")";
-
- String ip = dubboUrl.split(":")[0];
-
- int port = Integer.parseInt(dubboUrl.split(":")[1]);
-
- return telnetDubbo(ip, port, request);
- }
-
- public static String telnetDubbo2(String ip, int port, String request) {
-
- Socket socket;
- String result = "";
- try {
- socket = new Socket(ip, port);
- PrintWriter pw = new PrintWriter(socket.getOutputStream());
-
- String msg = "\r\n";
- pw.write(msg);
- pw.flush();
-
- InputStream ins = socket.getInputStream();
- byte[] tt = new byte[1024];
- ins.read(tt, 0, tt.length);
-
- pw.write("invoke " + request + "\r\n");
- pw.flush();
- ins.read(tt, 0, tt.length);
- result = new String(tt, "gbk");
-
- } catch (Exception e) {
- result=e.toString();
- }
-
- return result;
- }
-
-
- public static String telnetDubbo(String ip, int port, String request) {
-
- Socket socket;
- String result = "";
- try {
- socket = new Socket(ip, port);
- PrintWriter pw = new PrintWriter(socket.getOutputStream());
-
- String msg = "\r\n";
- pw.write(msg);
- pw.flush();
-
- InputStream ins = socket.getInputStream();
- Scanner sc = new Scanner(System.in);
-
- byte[] tt = new byte[1024];
- int len = 0;
-
- len = ins.read(tt, 0, tt.length);
-
- pw.write("invoke " + request + "\r\n");
- pw.flush();
- len = ins.read(tt, 0, tt.length);
- result = new String(tt, 0, len, "gbk");
- result = result.split("\r\n")[0];
- } catch (Exception e) {
- //e.printStackTrace();
- result=e.toString();
- }
-
- return result;
- }
- }
我的监控的时候是没有参数于是有重新写了一个没有参数的访问 noParamInvokeDubbo这样方便使用
springboot返回的对象都是json的,如果直接返回字符串,在字符串外层会加上双引号,这个要注意
如果是控制器中可以输出,来解决字符串加引号的问题
- response.getWriter().write("success");
- dubbo service层目前没有好的解决方式,有好的方式请留言
使用的是dubbo服务,主要找了一下是否有工具类直接访问dubbo服务,
最近优化了一下系统里的excel大文件的导入和导出,
导出修改的比较多,因为poi版本的问题,无法使用easyexcel来处理,在老版本poi只上修改的
pom.xml
- <!-- poi -->
- <dependency>
- <groupId>org.apache.poi</groupId>
- <artifactId>poi</artifactId>
- <version>3.9</version>
- </dependency>
- <!-- https://mvnrepository.com/artifact/org.apache.poi/poi-ooxml -->
- <dependency>
- <groupId>org.apache.poi</groupId>
- <artifactId>poi-ooxml</artifactId>
- <version>3.9</version>
- </dependency>
- <!-- https://mvnrepository.com/artifact/org.apache.poi/poi-ooxml-schemas -->
- <dependency>
- <groupId>org.apache.poi</groupId>
- <artifactId>poi-ooxml-schemas</artifactId>
- <version>3.9</version>
- </dependency>
-
- <!-- https://mvnrepository.com/artifact/org.apache.commons/commons-collections4 -->
- <dependency>
- <groupId>org.apache.commons</groupId>
- <artifactId>commons-collections4</artifactId>
- <version>4.1</version>
- </dependency>
添加工具类
- import java.io.InputStream;
- import java.util.List;
- import java.util.Objects;
-
- import org.apache.log4j.Logger;
- import org.apache.poi.openxml4j.opc.OPCPackage;
- import org.apache.poi.xssf.eventusermodel.XSSFReader;
- import org.apache.poi.xssf.model.SharedStringsTable;
- import org.xml.sax.InputSource;
- import org.xml.sax.XMLReader;
- import org.xml.sax.helpers.XMLReaderFactory;
-
- public class LargeExcelFileReadUtil {
- /** logger日志. */
- public static final Logger LOGGER = Logger.getLogger(LargeExcelFileReadUtil.class);
-
- // 处理一个sheet
- public static List<String> getRowFromSheetOne(String filename, Integer rowNum) throws Exception {
- InputStream inputStream = null;
- OPCPackage pkg = null;
- SingleRowHandler singleRowHandler = null;
- try {
- pkg = OPCPackage.open(filename);
- XSSFReader r = new XSSFReader(pkg);
- SharedStringsTable sst = r.getSharedStringsTable();
- singleRowHandler = new SingleRowHandler(sst, rowNum);
- XMLReader parser = XMLReaderFactory.createXMLReader("com.sun.org.apache.xerces.internal.parsers.SAXParser");
- parser.setContentHandler(singleRowHandler);
- inputStream = r.getSheet("rId1");
- InputSource sheetSource = new InputSource(inputStream);
- parser.parse(sheetSource);
- return singleRowHandler.getRow();
- } catch (Exception e) {
- String message = e.getMessage();
- if (Objects.nonNull(rowNum) && Objects.nonNull(singleRowHandler)
- && SingleRowHandler.FINISH_ROW_MESSAGE.equalsIgnoreCase(message)) {
- // 获取某一行数据完成 ,暂时不知道怎么能终止excel解析,直接抛出了异常,实际是成功的
- return singleRowHandler.getRow();
- }
- throw e;
- } finally {
- if (Objects.nonNull(pkg)) {
- pkg.close();
- }
- if (Objects.nonNull(inputStream)) {
- inputStream.close();
- }
- }
- }
-
- // 处理一个sheet
- public static List<List<String>> getRowsFromSheetOne(String filename) throws Exception {
- InputStream inputStream = null;
- OPCPackage pkg = null;
- MultiRowHandler multiRowHandler = null;
- try {
- pkg = OPCPackage.open(filename);
- XSSFReader r = new XSSFReader(pkg);
- SharedStringsTable sst = r.getSharedStringsTable();
- multiRowHandler = new MultiRowHandler(sst);
- XMLReader parser = XMLReaderFactory.createXMLReader("com.sun.org.apache.xerces.internal.parsers.SAXParser");
- parser.setContentHandler(multiRowHandler);
- inputStream = r.getSheet("rId1");
- InputSource sheetSource = new InputSource(inputStream);
- parser.parse(sheetSource);
- return multiRowHandler.getRows();
- } catch (Exception e) {
- throw e;
- } finally {
- if (Objects.nonNull(pkg)) {
- pkg.close();
- }
- if (Objects.nonNull(inputStream)) {
- inputStream.close();
- }
- }
- }
-
- public static List<List<String>> getRowsFromSheetOne(InputStream inputStream) throws Exception {
-
- OPCPackage pkg = null;
- MultiRowHandler multiRowHandler = null;
- try {
- pkg = OPCPackage.open(inputStream);
- XSSFReader r = new XSSFReader(pkg);
- SharedStringsTable sst = r.getSharedStringsTable();
- multiRowHandler = new MultiRowHandler(sst);
- XMLReader parser = XMLReaderFactory.createXMLReader("com.sun.org.apache.xerces.internal.parsers.SAXParser");
- parser.setContentHandler(multiRowHandler);
- inputStream = r.getSheet("rId1");
- InputSource sheetSource = new InputSource(inputStream);
- parser.parse(sheetSource);
- return multiRowHandler.getRows();
- } catch (Exception e) {
- throw e;
- } finally {
- if (Objects.nonNull(pkg)) {
- pkg.close();
- }
- if (Objects.nonNull(inputStream)) {
- inputStream.close();
- }
- }
- }
-
- public static void main(String[] args) throws Exception {
- List<List<String>> rowsFromSheetOne = LargeExcelFileReadUtil.getRowsFromSheetOne("E:/20200511/22.xlsx");
- System.out.println(rowsFromSheetOne);
-
- }
-
- }
- import java.util.ArrayList;
- import java.util.List;
- import java.util.Objects;
- import java.util.regex.Pattern;
-
- import org.apache.commons.lang3.StringUtils;
- import org.apache.poi.xssf.model.SharedStringsTable;
- import org.apache.poi.xssf.usermodel.XSSFRichTextString;
- import org.xml.sax.Attributes;
- import org.xml.sax.SAXException;
- import org.xml.sax.helpers.DefaultHandler;
-
- /**
- * 获取完整excel数据的handler<br/>
- *
- * @author Administrator
- *
- */
- public class MultiRowHandler extends DefaultHandler {
- private int curRowNum = 0;// 行号,从1开始
- private int curColIndex = -1;// 列索引,从0开始
- private int colCnt = 0;// 列数,取第一行列数做为列总数
- private String cellType = "";
- private SharedStringsTable sst;
- private String lastContents;
- private boolean nextIsString;
- private String cellPosition;
- private List<String> head = null;
- private List<String> curRowData = null;
- private boolean curRowIsBlank = true;// 当前是个空行
- private List<List<String>> rows = new ArrayList<>();
-
- public List<List<String>> getRows() {
- return rows;
- }
-
- public MultiRowHandler(SharedStringsTable sst) {
- this.sst = sst;
- }
-
- @Override
- public void startElement(String uri, String localName, String name, Attributes attributes) throws SAXException {
- if (name.equals("c")) {
- cellPosition = attributes.getValue("r");
- curColIndex = getColIndex(cellPosition);
- // 这是一个新行
- if (isNewRow(cellPosition)) {
- curRowNum = getRowNum(cellPosition);
- if (2 == curRowNum && Objects.nonNull(curRowData)) {
- head = curRowData;
- colCnt = head.size();
- }
- curRowData = getBlankRow(colCnt);
- }
- cellType = "";
- cellType = attributes.getValue("t");
- if ("s".equals(cellType)) {
- nextIsString = true;
- } else {
- nextIsString = false;
- }
- }
- // 清楚缓存内容
- lastContents = "";
- }
-
- private boolean isNewRow(String cellPosition) {
- // 坐标以A开头,后面跟数字 或者坐标行和当前行不一致的
- boolean newRow = Pattern.compile("^A[0-9]+$").matcher(cellPosition).find();
- if (!newRow) {
- int cellRowNum = getRowNum(cellPosition);
- newRow = (cellRowNum != curRowNum);
- }
- return newRow;
- }
-
- /**
- * 根据列坐标获取行号,从1开始,返回0时标示出错
- *
- * @param cellPosition
- * 列坐标,为A1,B23等
- * @return 行号,从1开始,返回0是为失败
- */
- private static int getRowNum(String cellPosition) {
- String strVal = Pattern.compile("[^0-9]").matcher(cellPosition).replaceAll("").trim();// 获取坐标中的数字
- if (StringUtils.isNotBlank(strVal)) {
- return Integer.valueOf(strVal);
- }
- return 0;
- }
-
- /**
- * 根据列坐标返回当前列索引,从0开始,返回-1时标示出错<br/>
- * A1->0; B1->1...AA1->26
- *
- * @param cellPosition
- * 列坐标,为A1,B23等
- * @return 列索引,从0开始,返回-1是为失败,A1->0; B1->1...AA1->26
- */
- private static int getColIndex(String cellPosition) {
- int index = -1;
- int num = 65;// A的Unicode码
- int length = cellPosition.length();
- for (int i = 0; i < length; i++) {
- char c = cellPosition.charAt(i);
- if (Character.isDigit(c)) {
- break;// 确定指定的char值是否为数字
- }
- index = (index + 1) * 26 + (int) c - num;
- }
- return index;
- }
-
- /**
- * 返回一个全部为空字符串的空行
- *
- * @param cnt
- * @return
- */
- private List<String> getBlankRow(int cnt) {
- List<String> result = new ArrayList<>(cnt);
- for (int i = 0; i < cnt; i++) {
- result.add(i, "");
- }
- curRowIsBlank = true;
- return result;
- }
-
- @Override
- public void endElement(String uri, String localName, String name) throws SAXException {
- if (nextIsString) {
- int idx = Integer.parseInt(lastContents);
- lastContents = new XSSFRichTextString(sst.getEntryAt(idx)).toString();
- nextIsString = false;
- }
-
- if (name.equals("v")) {
- // System.out.println(MessageFormat.format("当前列定位:{0},当前行:{1},当前列:{2},当前值:{3}",
- // cellPosition, curRowNum,
- // curColIndex, lastContents));
- if (Objects.isNull(head)) {
- curRowData.add(lastContents);
- } else {
- curRowData.set(curColIndex, lastContents);
- }
- curRowIsBlank = false;
- // 这是一个新行
- if (isNewRow(cellPosition)) {
- if (Objects.nonNull(curRowData)) {
- if (curRowIsBlank) {
- curRowData.clear();// 如果当前行是空行,则清空当前行数据
- }
- rows.add(curRowData);
- }
- }
-
- }
- }
-
- @Override
- public void endDocument() throws SAXException {
- if (Objects.nonNull(curRowData) && !curRowIsBlank) {
- rows.add(curRowData);// 最后一行在上面不好加入,最后一行全是空行的不加入
- }
- super.endDocument();
- }
-
- @Override
- public void characters(char[] ch, int start, int length) throws SAXException {
- lastContents += new String(ch, start, length);
- }
-
- @Override
- public void ignorableWhitespace(char[] ch, int start, int length) throws SAXException {
- lastContents += "";
- }
-
- public static void main(String[] args) {
- System.out.println(getColIndex("BC2"));
- }
- }
- import java.util.ArrayList;
- import java.util.List;
- import java.util.Objects;
- import java.util.regex.Pattern;
-
- import org.apache.poi.xssf.model.SharedStringsTable;
- import org.apache.poi.xssf.usermodel.XSSFRichTextString;
- import org.xml.sax.Attributes;
- import org.xml.sax.SAXException;
- import org.xml.sax.helpers.DefaultHandler;
-
- public class SingleRowHandler extends DefaultHandler {
- public final static String FINISH_ROW_MESSAGE = "row data process finish";
-
- private Integer rowNum = null;// rowNum不为空时则标示只需要获取这一行的数据
- private int curRowNum = 1;
- private String cellType = "";
- private SharedStringsTable sst;
- private String lastContents;
- private boolean nextIsString;
- private String cellPosition;
- private List<String> row = new ArrayList<>();
-
- public List<String> getRow() {
- return row;
- }
-
- public SingleRowHandler(SharedStringsTable sst, Integer rowNum) {
- this.sst = sst;
- this.rowNum = rowNum;
- }
-
- public void startElement(String uri, String localName, String name, Attributes attributes) throws SAXException {
- if (name.equals("c")) {
- cellPosition = attributes.getValue("r");
- // 这是一个新行
- if (Pattern.compile("^A[0-9]+$").matcher(cellPosition).find()) {
- curRowNum = Integer.valueOf(cellPosition.substring(1));
- }
- cellType = "";
- cellType = attributes.getValue("t");
- if ("s".equals(cellType)) {
- nextIsString = true;
- } else {
- nextIsString = false;
- }
- }
- // 清楚缓存内容
- lastContents = "";
- if (Objects.nonNull(rowNum) && curRowNum > rowNum) {
- // 获取某一行数据完成 ,暂时不知道怎么能终止excel解析,直接抛出了异常,实际是成功的
- throw new SAXException(FINISH_ROW_MESSAGE);
- }
- }
-
- public void endElement(String uri, String localName, String name) throws SAXException {
- if (nextIsString) {
- int idx = Integer.parseInt(lastContents);
- lastContents = new XSSFRichTextString(sst.getEntryAt(idx)).toString();
- nextIsString = false;
- }
-
- if (name.equals("v")) {
- if (Objects.isNull(rowNum) || rowNum == curRowNum) {
- row.add(lastContents);
- }
- }
- }
-
- public void characters(char[] ch, int start, int length) throws SAXException {
- lastContents += new String(ch, start, length);
- }
- }
目前的瓶颈在数据库层,有大量的数据有更新,目前还没有想到比较好的方式去处理大量的更新
直接访问dubbo 服务的工具类,返回success
原文:https://www.cnblogs.com/ynog/p/13423888.html