
摘要
在日常开发中,程序员需要经常查询服务器日志来排查问题和调试程序。如果是本地调试还好,但项目一旦发布到服务器上,每次查日志就很麻烦,而且日志量巨大,有时我们无法找到我们需要的信息。经常需要借助第三方工具来执行此类操作。那么我们可不可以在编辑器上运行代码就能完成相应的操作呢?
答案是肯定的!经过研究与测试,我总结了以下的方法,调用次服务就能执行相应的linux命令,无需麻烦借用第三方工具了,在同一个开发工具上就能完成所有的操作。接下来看看代码吧!
程序代码
一、写一个对外提供的services(ReadLogServlet)
public class ReadLogServletextends SlingAllMethodsServlet { private static final LoggerLOG = LoggerFactory.getLogger(ReadLogServlet.class); @Override protected void doPost(final SlingHttpServletRequest request, final SlingHttpServletResponse response)throws ServletException, IOException { request.setCharacterEncoding("UTF-8"); response.setContentType("application/json;charset=utf-8;"); String jsonStr = HttpRequestUtil.getRequestJson(request); try { JSONObject jsonObject =new JSONObject(jsonStr); String commond = jsonObject.getString("command"); String result = executeLinuxCmd(commond); if (result ==null) { LOG.error("result null"); return; } try (PrintWriter printWriter = response.getWriter()) { printWriter.write(result); response.flushBuffer(); }catch (IOException e) { LOG.error("Response writer error:" + e.toString()); } }catch (JSONException e) { }catch (IOException io){ try (PrintWriter printWriter = response.getWriter()) { printWriter.write(io.getMessage()); response.flushBuffer(); }catch (IOException e) { LOG.error("Response writer error:" + e.toString()); } } } //核心代码 public String executeLinuxCmd(String cmd)throws IOException { //System.out.println("got cmd job : " + cmd); Runtime run = Runtime.getRuntime(); // Process process = run.exec(cmd); Process process = run.exec(new String[]{"/bin/sh","-c", cmd}); InputStream in = process.getInputStream(); BufferedReader bs =new BufferedReader(new InputStreamReader(in)); //List list = new ArrayList(); StringBuffer sf =new StringBuffer(); String result =null; while ((result = bs.readLine()) !=null) { //System.out.println("job result [" + result + "]"); //list.add(result); sf.append(result); sf.append("\n"); } in.close(); // process.waitFor(); process.destroy(); return sf.toString(); } }
二、使用postman调用ReadLogServlet(使用其他工具调用也可)

总结:
除了查询日志外,还可执行其他linux命令。大家可继续优化发掘,如果有更好的意见和技术,欢迎留言探讨哦!