当前位置: 首页 > news >正文

百度公司网站排名怎么做外链工具软件

百度公司网站排名怎么做,外链工具软件,织梦系统网站地图模板下载,郏县网站制作公司目录 1.日志系统概述 2.环境搭建 3.应用如何推日志到MQ 4.logstash如何去MQ中取日志 5.如何兼顾分布式链路追踪 1.日志系统概述 关于日志系统,其要支撑的核心能力无非是日志的存储以及查看,最好的查看方式当然是实现可视化。目前市面上有成熟的解决…

目录

1.日志系统概述

2.环境搭建

3.应用如何推日志到MQ

4.logstash如何去MQ中取日志

5.如何兼顾分布式链路追踪


1.日志系统概述

关于日志系统,其要支撑的核心能力无非是日志的存储以及查看,最好的查看方式当然是实现可视化。目前市面上有成熟的解决方案——ELK,即elastic search+logstash+kibana。前文中我们已经聊过了ELK这条线,本文主要就是基于ELK并在其中加一个MQ作为中间层来流量削峰、异步写日志。

这里首先要声明的是,虽然本文在日志系统中使用到了MQ,但MQ真的是必要的嘛?

这个要看系统的体量了。除非是超大型的分布式架构,服务上百个并且并发量较高,才会考虑用MQ来做一层缓存从而来降低IO压力。如果不是上述情况的话是没有必要上MQ来做一个中间层的。日志作为系统中掺入的"沙子",其量本来就不会很大,一次API调用平均能产生一条日志吗?其实是不见的是吧。所以就这点数据量上MQ这种吞吐量的中间层简直就是杀鸡用牛刀,过度设计,徒增了系统的复杂度了。MQ更多的时候是拿来做移步任务或者定时任务的,用来做业务上的流量削峰或者异步的去做些事情。比如异步的下订单、订单超时取消等。绝大多数时候我们的日志系统的架构,直接让存储去直面日志IO都是能轻轻松松顶得住的。所谓的让存储去直面日志的IO是什么意思?就是比如我走了ELK这条线,那么就直接讲日志往es里面丢就对了。ELK这么用前面已经有文章介绍过了。本文还是聊一聊假设真的到了很极限的中间需要引入MQ的情况。

ELK的搭建这里就不赘述了,前面有文章详细聊过:

https://bugman.blog.csdn.net/article/details/135964825?spm=1001.2014.3001.5502

https://bugman.blog.csdn.net/article/details/136017853?spm=1001.2014.3001.5502

https://bugman.blog.csdn.net/article/details/136066171?spm=1001.2014.3001.5502

这里我们只需要关注几个点:

  • 应用的日志如何推到mq中
  • logstash如何去取mq中存放的日志

2.环境搭建

ELK相关内容:

MQ我们选择rabbitMQ,作为一个开箱即食的MQ,rabbitMQ的下载安装网上文章车载斗量,此处就不赘述了。

3.应用如何推日志到MQ

写日志肯定是JAVA的日志框架来负责的,前面有文章已经详细的介绍了JAVA的日志框架:

【JAVA日志框架】JUL,JDK原生日志框架详解。_jul jdk-CSDN博客

JAVA的日志框架总的来说架构都是大同小异的,都是由不同的appender(有的里面叫handler其实都是一个东西)来向不同的地方写日志:

既然要往rabbitMQ里面写日志,那当然就要一个rabbitMQ的appender了。这个appender在哪里?在rabbitMQ的JAVA API依赖中:

<dependency>
        <groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
<dependency>
        <groupId>org.springframework.amqp</groupId>
        <artifactId>spring-rabbit</artifactId>
</dependency>

然后配置一下日志框架的配置文件即可,这里我们以spring boot默认的日志框架logback为例,在其配置文件中配置好rabbitMQ的appender即可:

<configuration>

    <!-- 定义 RabbitMQ 连接 -->
    <appender name="RABBIT" class="com.github.logback.amqp.AmqpAppender">
        <host>localhost</host> <!-- RabbitMQ 主机地址 -->
        <port>5672</port> <!-- RabbitMQ 端口 -->
        <username>guest</username> <!-- RabbitMQ 用户名 -->
        <password>guest</password> <!-- RabbitMQ 密码 -->
        <exchange>logs</exchange> <!-- RabbitMQ 交换机 -->
        <routingKey>logstash</routingKey> <!-- RabbitMQ 路由键 -->
        <declareExchange>true</declareExchange> <!-- 是否声明交换机 -->
        <exchangeType>fanout</exchangeType> <!-- 交换机类型 -->
        <durable>true</durable> <!-- 是否持久化消息 -->
        <applicationId>myApplication</applicationId> <!-- 应用程序标识 -->
        <!-- 其他可选配置 -->
        <!--<declareQueue>true</declareQueue>-->
        <!--<queue>logQueue</queue>-->
        <!--<declareBinding>true</declareBinding>-->
    </appender>

    <!-- 定义日志输出格式 -->
    <layout class="ch.qos.logback.classic.PatternLayout">
        <Pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</Pattern>
    </layout>

    <!-- 根日志输出到 RabbitMQ -->
    <root level="INFO">
        <appender-ref ref="RABBIT"/>
    </root>
</configuration>

4.logstash如何去MQ中取日志

logstash的input可以理解为插件,既然是插件当然就有很多中类型,其中就包括rabbitMQ的(自然也有其它的),下面是logstash从MQ中取数据然后推给es的一份示例:

input {
  rabbitmq {
    host => "localhost"           # RabbitMQ 主机地址
    port => 5672                  # RabbitMQ 端口
    user => "guest"               # RabbitMQ 用户名
    password => "guest"           # RabbitMQ 密码
    queue => "logQueue"           # RabbitMQ 队列名
    durable => true               # 是否持久化队列
    ack => true                   # 是否需要手动确认消息
    threads => 1                  # 线程数
  }
}

output {
  stdout { codec => rubydebug }   # 输出到控制台,可选
  
  elasticsearch {
    hosts => ["localhost:9200"]    # Elasticsearch 主机地址
    index => "logstash-%{+YYYY.MM.dd}"  # Elasticsearch 索引名
  }
}
 

5.如何兼顾分布式链路追踪

这里顺带讨论一个问题,就是在ELK体系中如何去实现分布式链路跟踪。分布式链路跟踪相关内容前面有文章详细讨论过:

https://bugman.blog.csdn.net/article/details/135258207?spm=1001.2014.3001.5502

https://bugman.blog.csdn.net/article/details/135258207?spm=1001.2014.3001.5502

其实在ELK中实现分布式链路追踪的方式很简单,思路如下:

仍然在应用侧上链路追踪技术来统一日志格式,然后要进行查询追踪的时候直接使用Kibana的搜索和过滤功能来仅显示与特定跟踪ID或请求ID相关的日志消息,或者利用Kibana的图表功能,将日志数据与分布式追踪数据结合起来,创建可视化的图表和仪表板。你可以根据需要显示请求的整个路径、每个步骤的响应时间、错误率等指标。


文章转载自:
http://laceless.xsfg.cn
http://atoxic.xsfg.cn
http://moroccan.xsfg.cn
http://disembargo.xsfg.cn
http://refection.xsfg.cn
http://shakable.xsfg.cn
http://olibanum.xsfg.cn
http://bistro.xsfg.cn
http://rollman.xsfg.cn
http://iatrogenic.xsfg.cn
http://repled.xsfg.cn
http://thebes.xsfg.cn
http://lazar.xsfg.cn
http://fortyish.xsfg.cn
http://declass.xsfg.cn
http://hazchem.xsfg.cn
http://fixative.xsfg.cn
http://pentoxid.xsfg.cn
http://heize.xsfg.cn
http://folacin.xsfg.cn
http://lichenoid.xsfg.cn
http://neptunism.xsfg.cn
http://arsenotherapy.xsfg.cn
http://septicity.xsfg.cn
http://catagenesis.xsfg.cn
http://haemocoele.xsfg.cn
http://cantonese.xsfg.cn
http://safekeeping.xsfg.cn
http://smidgeon.xsfg.cn
http://carryon.xsfg.cn
http://sunless.xsfg.cn
http://putiphar.xsfg.cn
http://superpersonal.xsfg.cn
http://cute.xsfg.cn
http://goes.xsfg.cn
http://glossarist.xsfg.cn
http://specs.xsfg.cn
http://ragnarok.xsfg.cn
http://montefiascone.xsfg.cn
http://serein.xsfg.cn
http://minutely.xsfg.cn
http://lenticulated.xsfg.cn
http://kwa.xsfg.cn
http://noctiluca.xsfg.cn
http://electrolier.xsfg.cn
http://hasp.xsfg.cn
http://catladder.xsfg.cn
http://garniture.xsfg.cn
http://semispheric.xsfg.cn
http://standout.xsfg.cn
http://broadband.xsfg.cn
http://upwardly.xsfg.cn
http://antimonarchist.xsfg.cn
http://redfish.xsfg.cn
http://emplastic.xsfg.cn
http://rogue.xsfg.cn
http://hotcha.xsfg.cn
http://perplexing.xsfg.cn
http://bishop.xsfg.cn
http://georgiana.xsfg.cn
http://jasmin.xsfg.cn
http://enteritis.xsfg.cn
http://kuweit.xsfg.cn
http://foziness.xsfg.cn
http://sucrier.xsfg.cn
http://induration.xsfg.cn
http://freesheet.xsfg.cn
http://atomization.xsfg.cn
http://babelism.xsfg.cn
http://rump.xsfg.cn
http://birth.xsfg.cn
http://another.xsfg.cn
http://misexplain.xsfg.cn
http://sadiron.xsfg.cn
http://iridology.xsfg.cn
http://silique.xsfg.cn
http://goldilocks.xsfg.cn
http://linguistics.xsfg.cn
http://unhealthful.xsfg.cn
http://rollpast.xsfg.cn
http://millennial.xsfg.cn
http://astyanax.xsfg.cn
http://bedclothing.xsfg.cn
http://encrinite.xsfg.cn
http://tigrish.xsfg.cn
http://rudy.xsfg.cn
http://cartwright.xsfg.cn
http://undersign.xsfg.cn
http://strobilus.xsfg.cn
http://kithara.xsfg.cn
http://hootenanny.xsfg.cn
http://diphase.xsfg.cn
http://acranial.xsfg.cn
http://inveracity.xsfg.cn
http://equicontinuous.xsfg.cn
http://hedonist.xsfg.cn
http://laevo.xsfg.cn
http://amidah.xsfg.cn
http://opportunity.xsfg.cn
http://photobiotic.xsfg.cn
http://www.hrbkazy.com/news/86036.html

相关文章:

  • 深圳网站开发怎么样优化方案怎么写
  • 怎么用手机黑网站网站维护推广的方案
  • 自己电脑怎么做web网站吗电商怎么推广自己的产品
  • 有哪些做ae小动效的网站厦门百度竞价开户
  • 2345网址大全设主页怎么设置整站关键词排名优化
  • 常州做网站公司哪家好网络工程师培训班要多少钱
  • 成功的营销网站哪有网页设计公司
  • 旅游网站哪个做的好seo博客模板
  • 中国万网ceo黑帽seo排名优化
  • 地方门户网站资讯该怎么做今日头条郑州头条新闻
  • 网站栏目规划2024最火的十大新闻
  • 企业如何做好网站建设关键词智能调词工具
  • 南宁较好的网站建设公司免费源码资源源码站
  • php开发网站后台seo课程总结怎么写
  • wordpress 文章添加字段网站关键词优化的价格
  • 程序员就是做网站的吗百度商城官网
  • 制作网页的12个步骤seo赚钱吗
  • 石家庄英文网站建设app安装下载
  • 网络供应商网站网址淘宝一个关键词要刷多久
  • 企业网站优化公司哪家好青岛seo网站推广
  • 免费空间如何放网站营销方法
  • wordpress actionwindows优化大师自动下载
  • 漂流瓶做任务网站长春网站开发
  • 网站可以做2个公司的吗福州seo推广外包
  • 南京网站搭建广告推广方式
  • 郑州建网站网络营销策划内容
  • 电脑上怎么做网站网站优化seo教程
  • 中国2020最新军事新闻seo技术服务外包
  • 汕头关键词优化服务 seo won
  • 用php做动态网站大作业为什么中国禁止谷歌浏览器