ide 日志 乱码_IDE日志分析方法pt。 1个

ide 日志 乱码

介绍

我认为大多数软件工程师都了解日志的重要性。 它们已成为软件开发的一部分。 如果无法解决问题,我们尝试在日志中查找原因。 对于一些简单的情况,当错误阻止应用程序打开窗口时,这可能就足够了。 您可以在日志中找到问题,然后在Google上查找并应用解决方案。 但是,如果要修复包含许多组件的大型产品中的错误,则分析日志成为主要问题。 通常,维护工程师(正在修复不开发新功能的错误)需要处理数百兆字节的日志。 日志通常分为50-100 MB的独立文件并压缩。

有几种方法可以使这项工作更轻松。 我将描述一些现有的解决方案,然后解释解决此问题的理论方法。 这篇博客文章不会讨论任何具体的实现。

现有解决方案

文本编辑器

此解决方案实际上不是解决方案,它是大多数人在需要阅读文本文件时会采取的措施。 一些文本编辑器可能具有有用的功能,例如颜色选择,书签,可以使工作更轻松。 但是,文本编辑器仍然没有一个不错的解决方案。

圆锯

该工具可以使用log4j模式从日志中提取字段。 听起来不错,但这些字段在文字中已经很明显了。 显然,与简单的文本编辑器相比,改进是微不足道的。

LogStash

这个项目看起来还不错。 但是这种方法非常具体。 即使我从描述中从未使用过此工具,但我了解到他们使用ElasticSearch和简单的文本搜索来分析日志。 日志必须上传到某处并建立索引。 之后,该工具可能会显示最常用的单词,用户可以使用文本搜索等。听起来不错,似乎有所改进。 不幸的是没有那么多。 缺点如下:

  • 需要一些时间才能开始使用日志。 必须上传它们,将它们编入索引。 工作完成后,必须从系统中删除这些日志。 如果打算对日志进行分析和丢弃,则看起来有些过大。
  • 很多组件涉及很多必需的配置。
  • 全文搜索对日志不是很有用。 通常,工程师正在寻找类似“使用参数678678678创建的连接2345”之类的东西。 查找“使用参数创建”将返回所有连接。 寻找“连接2345”将返回所有此类语句,但是通常只有一个-创建此连接时。

其他基于云的解决方案

有很多基于云的解决方案可用。 他们大多数有商业计划,有些有免费计划。 它们提供通知,可视化和其他功能,但主要原理与LogStash相同。

日志分析说明

要了解为什么这些解决方案在分析复杂问题时效果不佳,我们需要尝试了解工作流程。 这是文本编辑器的示例工作流程:

  1. 工程师收到了1 GB的日志,其中包含该bug发生在23:00的信息,请求ID为12345。
  2. 首先,他或她会尝试在这段时间内发现任何错误或异常。
  3. 如果失败,则工程师必须为该请求重建事件流。 他或她开始寻找诸如“已创建连接”,“已删除连接”,“请求移至此阶段”之类的语句,以试图缩小问题的时间范围。
  4. 这通常是成功的(即使可能需要很多时间),现在很明显,问题是在将连接111移到状态Q之后发生的。
  5. 经过多一点的挖掘之后,工程师发现这与连接222进入状态W一致。
  6. 最终,工程师高兴地看到,将连接222移动到新状态的线程还修改了另一个影响连接111的变量。最后是根本原因。

在此工作流程中,我们看到工程师大部分时间都在寻找带有某些参数的标准字符串。 如果可以简化的话……

IDE方法

IDE方法包括几个部分。

  1. 正则表达式 。 使用正则表达式,可以指定模板并在日志中搜索它。 使用正则表达式查找标准字符串要简单得多。
  2. 正则表达式配置 。 这里的想法是,标准字符串如“创建的连接\ d {5} \ w {2}”,“连接\ d {5} \ w {2}移到阶段\ w {7}”,“连接\ d { 5} \ w {2}已删除”不会经常更改。 编写正则表达式每次都很难找到它,因为这样的正则表达式可能真的很长很复杂。 如果可以通过单击按钮来配置和使用它们,则会更加容易。
  3. IDE 。 我们需要某种IDE来将其结合在一起。 要读取配置,请显示日志文件和存储的正则表达式,并显示文本和搜索结果。 最好像这样: 日志分析
  4. 颜色特征 。 从经验中我知道,当您可以用颜色标记一些字符串以在日志中轻松查看日志时,日志分析要容易得多。 大多数商业日志分析器工具都使用颜色选择。 IDE应该对此提供帮助。

利弊

IDE方法的优点:

  1. 无需云服务。 没有在某处加载千兆字节的日志,没有云配置。 只需打开IDE记录日志,打开日志文件夹并开始分析。
  2. 如果IDE是免费的,则整个过程是完全免费的。 无论如何应该比日志服务便宜。

IDE方法的缺点:

  1. 大多数云服务“实时”提供实时通知和日志分析。 这意味着一旦发生指定的异常,便会通知用户。 IDE方法无法做到这一点。
  2. 用户的PC要求更高,因为在Java中使用大字符串会消耗大量内存。 根据我的经验,最低要求为8 GB。

最重要的是,IDE方法适用于分析日志中的复杂问题。 它不能提供云服务的实时功能,但是对于分析和修复错误应该便宜得多,并且容易得多。

最后的想法

如果有人可以实施这种出色的方法,那就太好了! 我的意思是创建具有所有这些功能的IDE,并使每个人的日志分析更加轻松! 我从经验中知道,这可能是一件乏味的工作,比实际困难。 在下一篇文章(第2部分)中,我将解释这种方法的困难/挑战,并提供基于Eclipse框架的可行实现。

翻译自: https://www.javacodegeeks.com/2018/11/ide-approach-log-analysis-pt.html

ide 日志 乱码

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/332924.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

.bash_profile vs .bashrc

请参阅:https://joshstaiger.org/archives/2005/07/bash_profile_vs.html

生成ssh证书(windows)

ssh -keygen -t rsa 生成ssh证书 /home/work/.ssh authorized_keys 客户端建立私钥和公钥 在客户端终端运行命令 ssh-keygen -t rsa https://www.cnblogs.com/ggjucheng/archive/2012/08/19/2646346.html https://blog.csdn.net/qq_36667170/article/details/79094257

日志间隔_在日志中搜索时间间隔

日志间隔介绍 这篇文章与我有关日志分析的迷你系列文章间接相关。 最好阅读两个主要部分,以更好地理解我在说什么。 第1 部分 , 第2部分 。 这篇文章描述了我在实现IDE方法时遇到的一个重要问题。 任务描述 当某人使用日志时,通常只需要调查…

如果在iTerm2中复制命令特别卡,就跟慢动作似的,怎么办?

如果在 iTerm2 中复制命令特别卡,就跟慢动作似的。你可以编辑 ~/.zshrc: vim ~/.zshrc增加如下内容: pasteinit() {OLD_SELF_INSERT${${(s.:.)widgets[self-insert]}[2,3]}zle -N self-insert url-quote-magic # I wonder if youd need .ur…

lambda表达式的使用

package com.asx.application.common.utils;import org.junit.Test;import java.util.Comparator; import java.util.function.Consumer;/*** lambda表达式的使用* 1.举例:(o1,o2) -> Integer.compare(o1,o2) ;* 2.格式* ->;lambda操作符 或 箭头操作符* ->…

centos桥接模式怎么联网_今日回收 | 互联网+废品回收模式是怎么兴起的呢?

随着社会的不断发展和进步,废品回收已不再是传统和低效的行业,而是我国现如今整合资源的重要手段。而该行业之所以能够有如此成就,只因其中98%的企业结合了互联网,成功实现了企业转型。据统计,我国目前废品回收的相关企…

文档 修订 非修订区别_修订和不变性

文档 修订 非修订区别这是一个简短的帖子。 我不确定如何启动它。 这是审阅一些现有代码时“为什么我没有想到这一刻”之一。 由于存在NDA,我无法共享实际代码。 它与处理修订有关。 我能与之联系最紧密的是WordPress(WP)如何处理博客文章和修…

终端界面如何改成彩色的

很多朋友说自己的终端一直是黑白的,如何改成彩色的呢?在用户目录的 .profile 里加上这两行即可: export CLICOLOR 1 export LSCOLORSgxfxcxdxbxegedabagacad

深度解析Java可变参数类型以及与数组的区别

可变参数类型:variable argument type 1.可变参数是兼容数组类参数的,但是数组类参数却无法兼容可变参数 //说明:可变参数可以兼容数组参数 public class TestVarArgus {public static void dealArray(int... intArray) {for (int i : intA…

ios nslog 例子_iOS Block实例

iOS之Block详解:Block详解ViewController.h(ARC)#import interface ViewController : UIViewController// 属性声明的block都是全局的__NSGlobalBlock__property (nonatomic, copy) void (^copyBlock)();property (nonatomic, weak) void (^weakBlock)();endViewCon…

boot gwt_带Spring Boot的GWT

boot gwt介绍 我最近一直在研究用Java编写UI代码的选项。 在我以前的文章中,我研究了Eclipse RAP,发现它可以与Spring Boot集成在一个可执行jar中。 这次,我想对GWT做同样的技巧。 每个人都喜欢Spring Boot。 它使很多事情变得更加干净和容易…

工作占用了太多私人时间_下班后还要被逼谈工作,我们应该如何处理?

老板总是下班后在跟我说工作的事情。不理吧,怕领导不高兴,回复了又怕没完没了的占用了自己的私人时间去完成工作,并且以后老板会觉得这样是理所当然,会变本加厉。“幻想花开”是一家装修公司的设计师,公司里的业务量越…

oh-my-zsh中如何去掉命令提示符前缀

终端的提示符前面存在着一长串前缀:用户名主机名,有时候命令稍微长点,一整行就放不下,于是找到了消除前缀的办法: 输入快捷键 Shift Command G,在前往文件夹输入框中输入 ~/.oh-my-zsh/themes/&#xff…

迁移学习 简而言之_简而言之SPIFFE

迁移学习 简而言之我一直在研究SPIFEE(每个人的安全生产身份框架)[1],在这里,我正在按照我现在的理解起草流程,以使任何其他试图了解流程的人受益。 身份注册表 – SPIRE服务器具有自己的身份注册表,该注册…

MyBatisPlus使用教程

lt是小于 gt是大于

cap理论具体含义_架构设计之「 CAP 定理 」

在计算机领域,如果是初入行就算了,如果是多年的老码农还不懂 CAP 定理,那就真的说不过去了。CAP可是每一名技术架构师都必须掌握的基础原则啊。现在只要是稍微大一点的互联网项目都是采用 分布式 结构了,一个系统可能有多个节点组…

用于zsh的高亮插件 zsh-syntax-highlighting

文章目录简介安装配置简介 zsh-syntax-highlighting 插件为 shell zsh 提供语法高亮显示。当命令在 zsh 提示符下输入到交互式终端时,它可以突出显示命令。这有助于在运行命令之前检查命令,特别是捕获语法错误。 主页地址:https://github.c…

项目不能使用fn标签_无服务器,Java和FN项目的第一步

项目不能使用fn标签无服务器不是什么新事物,但是可以说,仍然有很多关于它的炒作,以及它将如何改变一切,以及未来将如何成为无服务器。 除了云提供商提供的无服务器/功能之外,还有越来越多的无服务器项目正在我们的路上…

tomcat目录下创建临时文件,长时间没有使用会被系统清理掉

原因 原因:在linux系统中,spring boot应用服务每次使用java -jar启动后都会在/tmp目录下生成如下目录: hsperfdata_root tomcat.***.9008(中间是一串数字,结尾是应用端口号) tomcat-docbase..9008&#x…

iTerm2的颜色主题/配色主题/配色方案

文章目录直接下载配色方案包使用命令下载安装配色方案直接下载配色方案包 GitHub 主页地址:https://github.com/mbadolato/iTerm2-Color-Schemes 颜色方案下载地址:https://iterm2colorschemes.com/ 下载压缩包后对其进行解压缩,打开目录找…