探针(agent)
agent会被安装到服务所在的服务器上,负责进行数据的收集,并向oap发送收集的数据。
可观测性分析平台 OAP(Observability Analysis Platform)
接收探针发送的数据进行整合运算,然后将数据存储到对应的存储介质上,比如 Elasticsearch、MySQL等存储服务。OAP默认监听两个端口gRPC协议端口11800、HTTP端口12800,gRPC用于探针上报数据,HTTP端口用于UI连接OAP平台获取数据。
Skywalking UI
Skywalking 提供单独的UI进行数据的查看,UI调用OAP提供的接口,获取对应的数据根据UI模板的配置进行展示。
skywalking 的数据默认会存储在h2,生产环境一般用elasticsearch(已有环境可跳过此步)
为了方便这里用docker 安装elasticsearch
1.数据持久化
#创建持久化目录
mkdir -p /mnt/es/elasticsearch/data
mkdir -p /mnt/es/elasticsearch/logs
mkdir -p /mnt/es/elasticsearch/config
#启动es
docker run -d --name=es7 --restart=always -e "ES_JAVA_OPTS=-Xms512m -Xmx512m" elasticsearch:7.9.0
#复制配置文件到宿主机
docker cp es7:/usr/share/elasticsearch/config/elasticsearch.yml /mnt/es/elasticsearch/config
#删除容器
docker rm -f es7
2.dockers启动elasticsearch
docker run -d --name=es7 \
--restart=always \
-e "ES_JAVA_OPTS=-Xms512m -Xmx512m" \
-p 9200:9200 -p 9300:9300 \
-e "discovery.type=single-node" \
-v /mnt/es/elasticsearch/data:/usr/share/elasticsearch/data \
-v /mnt/es/elasticsearch/logs:/usr/share/elasticsearch/logs \
-v /mnt/es/elasticsearch/config/elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml \
elasticsearch:7.9.0
访问ip:9200出现以下代表安装成功

1.下载包
apm包(包含oap和skywalking-ui)
https://archive.apache.org/dist/skywalking/8.9.1/apache-skywalking-apm-8.9.1.tar.gz
agent包
https://archive.apache.org/dist/skywalking/java-agent/8.9.0/apache-skywalking-java-agent-8.9.0.tgz
2.下载完后解压包,目录结构如下
├── bin # 运行脚本
│ ├── oapService.bat
│ ├── oapServiceInit.bat
│ ├── oapServiceInit.sh # 初始化启动脚本,用于集群环境。为了防止多节点同时启动导致冲突,
# 单节点执行oapServiceInit.sh进行初始化,其他节点执行oapServiceNoInit.sh等待初始化完成后再启动。
│ ├── oapServiceNoInit.bat
│ ├── oapServiceNoInit.sh
│ ├── oapService.sh # OAP 启动并初始化
│ ├── startup.bat
│ ├── startup.sh # 启动并初始化脚本(同时启动OAP与UI)
│ ├── webappService.bat
│ └── webappService.sh # Skywalking UI 启动脚本
├── config # 配置文件
│ ├── alarm-settings.yml # 告警配置
│ ├── application.yml # OAP 主配置文件
│ ├── component-libraries.yml # 组件库配置,定义被监控应用中使用的组件库
│ ├── endpoint-name-grouping.yml # 接口名称分组规则
│ ├── envoy-metrics-rules # envoy 网关监控策略
│ │ ├── envoy-svc-relation.yaml
│ │ └── envoy.yaml
│ ├── fetcher-prom-rules # Prometheus Fetcher 配置文件,用于OAP自监测。
│ │ └── self.yaml
│ ├── gateways.yml # 网关配置,单节点无需配置
│ ├── lal
│ │ ├── default.yaml
│ │ └── envoy-als.yaml
│ ├── log4j2.xml # 日志配置
│ ├── log-mal-rules
│ │ └── placeholder.yaml
│ ├── metadata-service-mapping.yaml
│ ├── meter-analyzer-config
│ │ └── spring-sleuth.yaml
│ ├── oal # oal监控度量指标
│ │ ├── browser.oal
│ │ ├── core.oal
│ │ ├── disable.oal
│ │ ├── dotnet-agent.oal
│ │ ├── event.oal
│ │ ├── java-agent.oal
│ │ └── tcp.oal
│ ├── openapi-definitions
│ │ └── serviceA
│ ├── otel-oc-rules # OpenTelemetry receiver规则
│ │ ├── istio-controlplane.yaml
│ │ ├── k8s-cluster.yaml
│ │ ├── k8s-node.yaml
│ │ ├── k8s-service.yaml
│ │ ├── oap.yaml
│ │ └── vm.yaml
│ ├── service-apdex-threshold.yml # apdex配置
│ ├── trace-sampling-policy-settings.yml # 采样配置
│ ├── ui-initialized-templates # UI配置模板
│ │ ├── apm.yml
│ │ ├── browser.yml
│ │ ├── database.yml
│ │ ├── event.yml
│ │ ├── istio-dp.yml
│ │ ├── istio.yml
│ │ ├── k8s.yml
│ │ ├── self-observability.yml
│ │ ├── spring-sleuth.yml
│ │ ├── topology-endpoint-relation.yml
│ │ ├── topology-endpoint.yml
│ │ ├── topology-instance.yml
│ │ ├── topology-service-instance-relation.yml
│ │ ├── topology-service-relation.yml
│ │ ├── topology-service.yml
│ │ └── vm.yml
│ └── zabbix-rules # zabbix 规则
│ └── agent.yaml
├── config-examples # 配置文件示例
│ ├── alarm-settings.yml
│ ├── lal.yaml
│ └── log-mal.yaml
├── LICENSE
├── licenses
├── NOTICE
├── oap-libs # OAP Jar文件与依赖库
├── README.txt
├── tools # 开发运维工具
│ └── profile-exporter
│ ├── application.yml
│ ├── profile_exporter_log4j2.xml
│ └── profile_exporter.sh
└── webapp # Skywalking UI
├── skywalking-webapp.jar
└── webapp.yml # Skywalking UI 配置文件
3.修改config目录下主配置文件:application.yml
storage:
selector: ${SW_STORAGE:elasticsearch} #存储介质选择es
elasticsearch:
namespace: ${SW_NAMESPACE:""}
clusterNodes: ${SW_STORAGE_ES_CLUSTER_NODES:localhost:9200} #es地址和端口
4.修改webapp目录下webapp.yml
server:
port: 8088 #ui访问端口改为8088避免占用8080端口
5.启动oap和skywalking-ui
sh start.sh
6.访问skywalking-ui
ip:8088

拉取镜像
docker pull apache/skywalking-oap-server:8.9.1
docker pull apache/skywalking-ui:8.9.1
oap安装
docker run --name oap --restart=always -d \
-e TZ=Asia/Shanghai \
-p 12800:12800 \
-p 11800:11800 \
--link es7:es7 \
-e SW_STORAGE=elasticsearch \
-e SW_STORAGE_ES_CLUSTER_NODES=192.168.8.136:9200 \
apache/skywalking-oap-server:8.9.1
skywalking-ui安装
docker run -d --name skywalking-ui \
--restart=always \
-e TZ=Asia/Shanghai \
-p 8088:8080 \
--link oap:oap \
-e SW_OAP_ADDRESS=oap:12800 \
apache/skywalking-ui:8.9.1
1.idea连接agent
# skywalking-agent.jar的本地磁盘的路径
# 在skywalking上显示的服务名
# skywalking的collector服务的IP及端口
-javaagent:D:\middleware\skywalking-agent\skywalking-agent.jar
-DSW_AGENT_NAME=local-userService
-DSW_AGENT_COLLECTOR_BACKEND_SERVICES=192.168.8.136:11800
skywalking-agent采集信息
1.pom文件加入依赖
<dependency>
<groupId>org.apache.skywalking</groupId>
<artifactId>apm-toolkit-logback-1.x</artifactId>
<version>8.8.0</version>
</dependency>
2.logback-spring.xml中加入以下配置
<!--输出到skywalking-->
<appender name="grpc" class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.log.GRPCLogClientAppender">
<encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
<layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.mdc.TraceIdMDCPatternLogbackLayout">
<Pattern>%contextName %d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} [%X{tid}] -%msg%n</Pattern>
</layout>
</encoder>
</appender>
<root level="info">
..........
..........
<appender-ref ref="grpc"/>
</root>

3.在jar包启动命令后加入以下参数
-javaagent:/root/java/apache-skywalking-apm-bin/agent/skywalking-agent.jar
-Dskywalking.agent.service_name=user
-Dskywalking.collector.backend_service=192.168.100.149:11800
#第一个是Agent jar的绝对路径
#第二个是SkyWalking上显示的服务名称
#第三个是SkyWalking OAP的服务的ip:port
例如:aaa-service.jar的启动
nohup java -jar -server
-javaagent:/home/dz_dev/skywaking/agent/skywalking-agent.jar
-Dskywalking.agent.service_name=user-service
-Dskywalking.collector.backend_service=192.168.8.136:11800
aaa-service.jar
Kibana是一个针对Elasticsearch的开源分析及可视化平台,用来搜索、查看交互存储在Elasticsearch索引中的数据。使用Kibana,可以通过各种图表进行高级数据分析及展示。
挂载kibana配置文件
mkdir -p /mnt/es/kibana/config
复制容器内的配置文件
#启动容器
docker run -d --name kibana --link es7:es7 -e ELASTICSEARCH_URL=http://192.168.8.136:9200 -e I18N_LOCALE=zh-CN -p 5601:5601 kibana:7.7.0
#复制配置文件
docker cp kibana://opt/kibana/config/kibana.yml /mnt/es/kibana/config
#删除容器
docker rm -f kibana
修改kibana.yml 配置文件
server.name: kibana
server.host: "0"
#es连接地址
elasticsearch.hosts: [ "http://192.168.8.136:9200" ]
monitoring.ui.container.elasticsearch.enabled: true
#设置kibana中文显示
i18n.locale: zh-CN
运行kibana容器
docker run -d --privileged --name kibana -v /etc/localtime:/etc/localtime:ro -v /mnt/es/kibana/config/kibana.yml:/opt/kibana/config/kibana.yml --link es7:es7 -e ELASTICSEARCH_URL=192.168.8.136:9200 -e I18N_LOCALE=zh-CN -p 5601:5601 kibana:7.7.0
访问kibana
浏览器打开地址 http://{{ip}}:5601
elasticsearch-head 是用于监控 Elasticsearch 状态的客户端插件,包括数据可视化、执行增删改查操作等。
docker pull mobz/elasticsearch-head:5
docker run --restart=always --name elasticsearch-head -d -p 30910:9100 docker.io/mobz/elasticsearch-head:5
解决跨域问题
编辑elasticsearch.yml
#添加跨域配置
http.cors.enabled: true
http.cors.allow-origin: "*"
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当
我有一个围绕一些对象的包装类,我想将这些对象用作散列中的键。包装对象和解包装对象应映射到相同的键。一个简单的例子是这样的:classAattr_reader:xdefinitialize(inner)@inner=innerenddefx;@inner.x;enddef==(other)@inner.x==other.xendenda=A.new(o)#oisjustanyobjectthatallowso.xb=A.new(o)h={a=>5}ph[a]#5ph[b]#nil,shouldbe5ph[o]#nil,shouldbe5我试过==、===、eq?并散列所有无济于事。
我有一些Ruby代码,如下所示:Something.createdo|x|x.foo=barend我想编写一个测试,它使用double代替block参数x,这样我就可以调用:x_double.should_receive(:foo).with("whatever").这可能吗? 最佳答案 specify'something'dox=doublex.should_receive(:foo=).with("whatever")Something.should_receive(:create).and_yield(x)#callthere
Sinatra新手;我正在运行一些rspec测试,但在日志中收到了一堆不需要的噪音。如何消除日志中过多的噪音?我仔细检查了环境是否设置为:test,这意味着记录器级别应设置为WARN而不是DEBUG。spec_helper:require"./app"require"sinatra"require"rspec"require"rack/test"require"database_cleaner"require"factory_girl"set:environment,:testFactoryGirl.definition_file_paths=%w{./factories./test/
我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test
我已经构建了一些serverspec代码来在多个主机上运行一组测试。问题是当任何测试失败时,测试会在当前主机停止。即使测试失败,我也希望它继续在所有主机上运行。Rakefile:namespace:specdotask:all=>hosts.map{|h|'spec:'+h.split('.')[0]}hosts.eachdo|host|begindesc"Runserverspecto#{host}"RSpec::Core::RakeTask.new(host)do|t|ENV['TARGET_HOST']=hostt.pattern="spec/cfengine3/*_spec.r
我在app/helpers/sessions_helper.rb中有一个帮助程序文件,其中包含一个方法my_preference,它返回当前登录用户的首选项。我想在集成测试中访问该方法。例如,这样我就可以在测试中使用getuser_path(my_preference)。在其他帖子中,我读到这可以通过在测试文件中包含requiresessions_helper来实现,但我仍然收到错误NameError:undefinedlocalvariableormethod'my_preference'.我做错了什么?require'test_helper'require'sessions_hel
我正在玩HTML5视频并且在ERB中有以下片段:mp4视频从在我的开发环境中运行的服务器很好地流式传输到chrome。然而firefox显示带有海报图像的视频播放器,但带有一个大X。问题似乎是mongrel不确定ogv扩展的mime类型,并且只返回text/plain,如curl所示:$curl-Ihttp://0.0.0.0:3000/pr6.ogvHTTP/1.1200OKConnection:closeDate:Mon,19Apr201012:33:50GMTLast-Modified:Sun,18Apr201012:46:07GMTContent-Type:text/plain
只是想确保我理解了事情。据我目前收集到的信息,Cucumber只是一个“包装器”,或者是一种通过将事物分类为功能和步骤来组织测试的好方法,其中实际的单元测试处于步骤阶段。它允许您根据事物的工作方式组织您的测试。对吗? 最佳答案 有点。它是一种组织测试的方式,但不仅如此。它的行为就像最初的Rails集成测试一样,但更易于使用。这里最大的好处是您的session在整个Scenario中保持透明。关于Cucumber的另一件事是您(应该)从使用您的代码的浏览器或客户端的角度进行测试。如果您愿意,您可以使用步骤来构建对象和设置状态,但通常您