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

做的网站电脑上跟手机上不一样如何做简易网站

做的网站电脑上跟手机上不一样,如何做简易网站,网站维护公司,企业宣传片模板需求 我想做一个类似腾讯云网关日志最终以仪表方式呈现#xff0c;比如说qps、p99、p95的请求响应时间等等 流程图 数据流转就像标题 nginx ---- rsyslog ---- kafka — clickhouse — grafana 部署 kafka kafka 相关部署这里不做赘述#xff0c;只要创…需求 我想做一个类似腾讯云网关日志最终以仪表方式呈现比如说qps、p99、p95的请求响应时间等等 流程图 数据流转就像标题 nginx ---- rsyslog ---- kafka — clickhouse — grafana 部署 kafka kafka 相关部署这里不做赘述只要创建一个topic 就可以 这里kafka地址是 192.168.1.180,topic是 rsyslog 设置 rsyslog 具体是啥东西这个我这里也不做介绍本人也是一个后端开发不是做运维的只知道这个东西性能不错算是logstash 平替把 # 安装rsyslog-kafka 插件 yum install -y rsyslog-kafka # 创建一个配置vim /etc/rsyslog.d/rsyslog_nginx_kafka_cluster.confconf 内容 module(loadimudp) input(typeimudp port514)# nginx access log rsyslog server(local) kafka module(loadomkafka)template(namenginxLog typestring string%msg%)if $inputname imudp then {# 这里的名字和下面nginx 配置tag 相同if ($programname nginx_access_log) thenaction(typeomkafkatemplatenginxLog# kafka 地址broker[192.168.1.180:9092]# topic 名字topicrsyslog_nginxpartitions.autoonconfParam[socket.keepalive.enabletrue]) }:rawmsg, contains, nginx_access_log ~最后重启rsyslog 即可 nginx http 节点中设置如下 log_format jsonlog {host: $host,server_addr: $server_addr,remote_addr:$remote_addr,time_format:$time_ms,time_sec:$times,timestamp:$timestamp,method:$request_method,request_url:$request_uri,status:$status,upstream_name:$upstream_name,http_user_agent:$http_user_agent,upstream_addr:$upstream_addr,trace_id:$http_traceid,upstream_status:$upstream_status,upstream_response_time:$upstream_response_time,request_time:$request_time,nginx_host:$nginx_host};# 配置rsyslogtag 和上文rsyslog 中相同access_log syslog:server192.168.1.179,facilitylocal7,tagnginx_access_log,severityinfo jsonlog;#access_log /var/log/nginx/access.log jsonlog;配置实际转发upstream upstream testcontrol{server 192.168.10.123:8081; }server {listen 18081;server_name _;# 设置up nameset $upstream_name testcontrol;include /etc/nginx/conf/time.conf;location / {proxy_set_header traceid $http_traceid;proxy_set_header n-t $msec;#proxy_set_header X-Real-IP $remote_addr;proxy_pass http://testcontrol;}location ~ /status {stub_status on;} }/etc/nginx/conf/time.conf; 配置 set $nginx_host 192.168.8.64; if ($time_iso8601 ~ ^(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2}):(\d{2})) {set $year $1;set $month $2;set $day $3;set $hour $4;set $minutes $5;set $seconds $6;set $time_sec $1-$2-$3 $4:$5:$6;}# 获取毫秒时间戳并拼接到$time_zh之后if ($msec ~ (\d)\.(\d)) {# 时间戳-msset $timestamp $1$2;# 时间戳-sset $times $1;# 格式化之后的时间msset $time_ms $time_sec.$2;# traceId方便查日志set $http_traceid $nginx_host#$timestamp#$request_id; }clickhouse 先创建一个 nginx_gw_log 表 create table app_logs.nginx_gw_log (timestamp DateTime64(3, Asia/Shanghai),server_addr String,remote_addr String,time_sec DateTime(Asia/Shanghai),method String,request_url String,status Int16,upstream_name String,http_user_agent String,upstream_addr String,trace_id String,upstream_status String,upstream_response_time String,request_time Int32,nginx_host String,host String ) engine MergeTree PARTITION BY toYYYYMMDD(timestamp)ORDER BY timestampTTL toDateTime(timestamp) toIntervalDay(1);上面设置了过期1天可以自由修改 添加kafka 引擎 create table app_logs.nginx_gw_log_kafka (timestamp DateTime64(3, Asia/Shanghai),server_addr String,remote_addr String,time_sec DateTime(Asia/Shanghai),method String,request_url String,status Int32,upstream_name String,http_user_agent String,upstream_addr String,trace_id String,upstream_status String,upstream_response_time String,request_time Decimal32(3),nginx_host String,host String ) engine Kafka()SETTINGS kafka_broker_list 192.168.1.180:9092,kafka_topic_list rsyslog_nginx,kafka_group_name nginx_ck,kafka_format JSONEachRow,kafka_skip_broken_messages 100000,kafka_num_consumers 1;最后设置mv CREATE MATERIALIZED VIEW app_logs.nginx_gw_log_mv TO app_logs.nginx_gw_log AS SELECT timestamp,server_addr,remote_addr,time_sec,method,request_url,status,upstream_name,http_user_agent,upstream_addr,trace_id,upstream_status,upstream_response_time,toInt32(multiply(request_time, 1000)) as request_time,host FROM app_logs.nginx_gw_log_kafka;这里做了一个类型转换因为nginxrequest-time 单位是s我想最终呈现在grafana 中是ms所以这里做了转换当然grafana中也可以做 上面都配置完了之后可以先验证下保证数据最终到ck如果有问题需要再每个节点调试比如先调试nginx-rsyslog 可以先不配置kafka 输出配置为console或者文件输出都可以具体这里就不写了 grafana {annotations: {list: [{builtIn: 1,datasource: {type: grafana,uid: -- Grafana --},enable: true,hide: true,iconColor: rgba(0, 211, 255, 1),name: Annotations Alerts,target: {limit: 100,matchAny: false,tags: [],type: dashboard},type: dashboard}]},editable: true,fiscalYearStartMonth: 0,graphTooltip: 0,id: 17,links: [],liveNow: false,panels: [{datasource: {type: grafana-clickhouse-datasource,uid: ${datasource}},fieldConfig: {defaults: {color: {mode: palette-classic},custom: {axisCenteredZero: false,axisColorMode: text,axisLabel: ,axisPlacement: auto,barAlignment: 0,drawStyle: line,fillOpacity: 0,gradientMode: none,hideFrom: {legend: false,tooltip: false,viz: false},lineInterpolation: linear,lineWidth: 1,pointSize: 5,scaleDistribution: {type: linear},showPoints: auto,spanNulls: false,stacking: {group: A,mode: none},thresholdsStyle: {mode: off}},mappings: [],thresholds: {mode: absolute,steps: [{color: green,value: null},{color: red,value: 80}]}},overrides: []},gridPos: {h: 9,w: 12,x: 0,y: 0},id: 2,options: {legend: {calcs: [],displayMode: list,placement: bottom,showLegend: true},tooltip: {mode: single,sort: none}},pluginVersion: 9.1.1,targets: [{builderOptions: {database: app_logs,fields: [],filters: [{condition: AND,filterType: custom,key: timestamp,operator: WITH IN DASHBOARD TIME RANGE,restrictToFields: [{label: timestamp,name: timestamp,picklistValues: [],type: DateTime64(3, Asia/Shanghai)},{label: startTime,name: startTime,picklistValues: [],type: DateTime64(3, Asia/Shanghai)}],type: datetime}],groupBy: [],limit: 100,metrics: [{aggregation: count,field: }],mode: list,orderBy: [],table: tk_wx_control_req_kafka,timeField: timestamp,timeFieldType: DateTime64(3, Asia/Shanghai)},datasource: {type: grafana-clickhouse-datasource,uid: ${datasource}},format: 1,meta: {builderOptions: {database: app_logs,fields: [],filters: [{condition: AND,filterType: custom,key: timestamp,operator: WITH IN DASHBOARD TIME RANGE,restrictToFields: [{label: timestamp,name: timestamp,picklistValues: [],type: DateTime64(3, Asia/Shanghai)},{label: startTime,name: startTime,picklistValues: [],type: DateTime64(3, Asia/Shanghai)}],type: datetime}],groupBy: [],limit: 100,metrics: [{aggregation: count,field: }],mode: list,orderBy: [],table: tk_wx_control_req_kafka,timeField: timestamp,timeFieldType: DateTime64(3, Asia/Shanghai)}},queryType: sql,rawSql: SELECT time_sec as a, count() as num FROM \app_logs\.${table_name} where ( timestamp $__fromTime AND timestamp $__toTime )\r\ngroup by a order by a desc ;\r\n,refId: A,selectedFormat: 4}],title: qps,type: timeseries},{datasource: {type: grafana-clickhouse-datasource,uid: ${datasource}},fieldConfig: {defaults: {color: {mode: palette-classic},custom: {axisCenteredZero: false,axisColorMode: text,axisLabel: ,axisPlacement: auto,barAlignment: 0,drawStyle: line,fillOpacity: 0,gradientMode: none,hideFrom: {legend: false,tooltip: false,viz: false},lineInterpolation: linear,lineWidth: 1,pointSize: 5,scaleDistribution: {type: linear},showPoints: auto,spanNulls: false,stacking: {group: A,mode: none},thresholdsStyle: {mode: off}},mappings: [],thresholds: {mode: absolute,steps: [{color: green,value: null},{color: red,value: 80}]}},overrides: []},gridPos: {h: 9,w: 12,x: 12,y: 0},id: 3,options: {legend: {calcs: [],displayMode: list,placement: bottom,showLegend: true},tooltip: {mode: single,sort: none}},pluginVersion: 9.1.1,targets: [{builderOptions: {database: app_logs,fields: [],filters: [{condition: AND,filterType: custom,key: timestamp,operator: WITH IN DASHBOARD TIME RANGE,restrictToFields: [{label: timestamp,name: timestamp,picklistValues: [],type: DateTime64(3, Asia/Shanghai)},{label: startTime,name: startTime,picklistValues: [],type: DateTime64(3, Asia/Shanghai)}],type: datetime}],groupBy: [],limit: 100,metrics: [{aggregation: count,field: }],mode: list,orderBy: [],table: tk_wx_control_req_kafka,timeField: timestamp,timeFieldType: DateTime64(3, Asia/Shanghai)},datasource: {type: grafana-clickhouse-datasource,uid: ${datasource}},format: 1,meta: {builderOptions: {database: app_logs,fields: [],filters: [{condition: AND,filterType: custom,key: timestamp,operator: WITH IN DASHBOARD TIME RANGE,restrictToFields: [{label: timestamp,name: timestamp,picklistValues: [],type: DateTime64(3, Asia/Shanghai)},{label: startTime,name: startTime,picklistValues: [],type: DateTime64(3, Asia/Shanghai)}],type: datetime}],groupBy: [],limit: 100,metrics: [{aggregation: count,field: }],mode: list,orderBy: [],table: tk_wx_control_req_kafka,timeField: timestamp,timeFieldType: DateTime64(3, Asia/Shanghai)}},queryType: sql,rawSql: SELECT time_sec as a, toInt32(quantile(0.95)(request_time)) as num FROM \app_logs\.${table_name} where ( timestamp $__fromTime AND timestamp $__toTime )\r\ngroup by a order by a desc ;,refId: p95,selectedFormat: 4},{builderOptions: {database: app_logs,fields: [],filters: [{condition: AND,filterType: custom,key: timestamp,operator: WITH IN DASHBOARD TIME RANGE,restrictToFields: [{label: timestamp,name: timestamp,picklistValues: [],type: DateTime64(3, Asia/Shanghai)},{label: startTime,name: startTime,picklistValues: [],type: DateTime64(3, Asia/Shanghai)}],type: datetime}],groupBy: [],limit: 100,metrics: [{aggregation: count,field: }],mode: list,orderBy: [],table: tk_wx_control_req_kafka,timeField: timestamp,timeFieldType: DateTime64(3, Asia/Shanghai)},datasource: {type: grafana-clickhouse-datasource,uid: ${datasource}},format: 1,hide: false,meta: {builderOptions: {database: app_logs,fields: [],filters: [{condition: AND,filterType: custom,key: timestamp,operator: WITH IN DASHBOARD TIME RANGE,restrictToFields: [{label: timestamp,name: timestamp,picklistValues: [],type: DateTime64(3, Asia/Shanghai)},{label: startTime,name: startTime,picklistValues: [],type: DateTime64(3, Asia/Shanghai)}],type: datetime}],groupBy: [],limit: 100,metrics: [{aggregation: count,field: }],mode: list,orderBy: [],table: tk_wx_control_req_kafka,timeField: timestamp,timeFieldType: DateTime64(3, Asia/Shanghai)}},queryType: sql,rawSql: SELECT time_sec as a, toInt32(quantile(0.99)(request_time)) as num FROM \app_logs\.${table_name} where ( timestamp $__fromTime AND timestamp $__toTime )\r\ngroup by a order by a desc ;,refId: p99,selectedFormat: 4}],title: 响应时间统计,type: timeseries},{datasource: {type: grafana-clickhouse-datasource,uid: ${datasource}},fieldConfig: {defaults: {color: {mode: thresholds},custom: {align: auto,displayMode: auto,inspect: false},mappings: [],thresholds: {mode: absolute,steps: [{color: green,value: null},{color: red,value: 80}]}},overrides: []},gridPos: {h: 9,w: 12,x: 0,y: 9},id: 4,options: {footer: {fields: ,reducer: [sum],show: false},showHeader: true},pluginVersion: 9.1.1,targets: [{builderOptions: {database: app_logs,fields: [],filters: [{condition: AND,filterType: custom,key: timestamp,operator: WITH IN DASHBOARD TIME RANGE,restrictToFields: [{label: timestamp,name: timestamp,picklistValues: [],type: DateTime64(3, Asia/Shanghai)},{label: startTime,name: startTime,picklistValues: [],type: DateTime64(3, Asia/Shanghai)}],type: datetime}],groupBy: [],limit: 100,metrics: [{aggregation: count,field: }],mode: list,orderBy: [],table: tk_wx_control_req_kafka,timeField: timestamp,timeFieldType: DateTime64(3, Asia/Shanghai)},datasource: {type: grafana-clickhouse-datasource,uid: ${datasource}},format: 1,meta: {builderOptions: {database: app_logs,fields: [],filters: [{condition: AND,filterType: custom,key: timestamp,operator: WITH IN DASHBOARD TIME RANGE,restrictToFields: [{label: timestamp,name: timestamp,picklistValues: [],type: DateTime64(3, Asia/Shanghai)},{label: startTime,name: startTime,picklistValues: [],type: DateTime64(3, Asia/Shanghai)}],type: datetime}],groupBy: [],limit: 100,metrics: [{aggregation: count,field: }],mode: list,orderBy: [],table: tk_wx_control_req_kafka,timeField: timestamp,timeFieldType: DateTime64(3, Asia/Shanghai)}},queryType: sql,rawSql: SELECT request_time as k,request_url,trace_id FROM \app_logs\.${table_name} where ( timestamp $__fromTime AND timestamp $__toTime )\r\n order by k desc limit 10;\r\n,refId: A,selectedFormat: 4}],title: 最耗时,type: table},{datasource: {type: grafana-clickhouse-datasource,uid: ${datasource}},fieldConfig: {defaults: {color: {mode: thresholds},custom: {align: auto,displayMode: auto,inspect: false},mappings: [],thresholds: {mode: absolute,steps: [{color: green,value: null},{color: red,value: 80}]}},overrides: []},gridPos: {h: 9,w: 12,x: 12,y: 9},id: 5,options: {footer: {fields: ,reducer: [sum],show: false},showHeader: true},pluginVersion: 9.1.1,targets: [{builderOptions: {database: app_logs,fields: [],filters: [{condition: AND,filterType: custom,key: timestamp,operator: WITH IN DASHBOARD TIME RANGE,restrictToFields: [{label: timestamp,name: timestamp,picklistValues: [],type: DateTime64(3, Asia/Shanghai)},{label: startTime,name: startTime,picklistValues: [],type: DateTime64(3, Asia/Shanghai)}],type: datetime}],groupBy: [],limit: 100,metrics: [{aggregation: count,field: }],mode: list,orderBy: [],table: tk_wx_control_req_kafka,timeField: timestamp,timeFieldType: DateTime64(3, Asia/Shanghai)},datasource: {type: grafana-clickhouse-datasource,uid: ${datasource}},format: 1,meta: {builderOptions: {database: app_logs,fields: [],filters: [{condition: AND,filterType: custom,key: timestamp,operator: WITH IN DASHBOARD TIME RANGE,restrictToFields: [{label: timestamp,name: timestamp,picklistValues: [],type: DateTime64(3, Asia/Shanghai)},{label: startTime,name: startTime,picklistValues: [],type: DateTime64(3, Asia/Shanghai)}],type: datetime}],groupBy: [],limit: 100,metrics: [{aggregation: count,field: }],mode: list,orderBy: [],table: tk_wx_control_req_kafka,timeField: timestamp,timeFieldType: DateTime64(3, Asia/Shanghai)}},queryType: sql,rawSql: SELECT request_url, count() as num FROM \app_logs\.${table_name} where ( timestamp $__fromTime AND timestamp $__toTime )\r\ngroup by request_url order by request_url desc ;,refId: A,selectedFormat: 4}],title: 接口请求数量,type: table},{datasource: {type: grafana-clickhouse-datasource,uid: ${datasource}},fieldConfig: {defaults: {custom: {align: auto,displayMode: auto,inspect: false},mappings: [],thresholds: {mode: absolute,steps: [{color: green,value: null},{color: red,value: 80}]}},overrides: []},gridPos: {h: 9,w: 12,x: 0,y: 18},id: 6,options: {footer: {fields: ,reducer: [sum],show: false},showHeader: true},pluginVersion: 9.1.1,targets: [{builderOptions: {database: app_logs,fields: [],filters: [{condition: AND,filterType: custom,key: timestamp,operator: WITH IN DASHBOARD TIME RANGE,restrictToFields: [{label: timestamp,name: timestamp,picklistValues: [],type: DateTime64(3, Asia/Shanghai)},{label: startTime,name: startTime,picklistValues: [],type: DateTime64(3, Asia/Shanghai)}],type: datetime}],groupBy: [],limit: 100,metrics: [{aggregation: count,field: }],mode: list,orderBy: [],table: tk_wx_control_req_kafka,timeField: timestamp,timeFieldType: DateTime64(3, Asia/Shanghai)},datasource: {type: grafana-clickhouse-datasource,uid: ${datasource}},format: 1,meta: {builderOptions: {database: app_logs,fields: [],filters: [{condition: AND,filterType: custom,key: timestamp,operator: WITH IN DASHBOARD TIME RANGE,restrictToFields: [{label: timestamp,name: timestamp,picklistValues: [],type: DateTime64(3, Asia/Shanghai)},{label: startTime,name: startTime,picklistValues: [],type: DateTime64(3, Asia/Shanghai)}],type: datetime}],groupBy: [],limit: 100,metrics: [{aggregation: count,field: }],mode: list,orderBy: [],table: tk_wx_control_req_kafka,timeField: timestamp,timeFieldType: DateTime64(3, Asia/Shanghai)}},queryType: sql,rawSql: SELECT DISTINCT host FROM \app_logs\.${table_name} where ( timestamp $__fromTime AND timestamp $__toTime );\r\n,refId: A,selectedFormat: 4}],title: upstream,type: table},{datasource: {type: grafana-clickhouse-datasource,uid: ${datasource}},fieldConfig: {defaults: {custom: {align: auto,displayMode: auto,inspect: false},mappings: [],thresholds: {mode: absolute,steps: [{color: green,value: null},{color: red,value: 80}]}},overrides: []},gridPos: {h: 9,w: 12,x: 12,y: 18},id: 8,options: {footer: {fields: ,reducer: [sum],show: false},showHeader: true},pluginVersion: 9.1.1,targets: [{builderOptions: {database: app_logs,fields: [],filters: [{condition: AND,filterType: custom,key: timestamp,operator: WITH IN DASHBOARD TIME RANGE,restrictToFields: [{label: timestamp,name: timestamp,picklistValues: [],type: DateTime64(3, Asia/Shanghai)},{label: startTime,name: startTime,picklistValues: [],type: DateTime64(3, Asia/Shanghai)}],type: datetime}],groupBy: [],limit: 100,metrics: [{aggregation: count,field: }],mode: list,orderBy: [],table: tk_wx_control_req_kafka,timeField: timestamp,timeFieldType: DateTime64(3, Asia/Shanghai)},datasource: {type: grafana-clickhouse-datasource,uid: ${datasource}},format: 1,meta: {builderOptions: {database: app_logs,fields: [],filters: [{condition: AND,filterType: custom,key: timestamp,operator: WITH IN DASHBOARD TIME RANGE,restrictToFields: [{label: timestamp,name: timestamp,picklistValues: [],type: DateTime64(3, Asia/Shanghai)},{label: startTime,name: startTime,picklistValues: [],type: DateTime64(3, Asia/Shanghai)}],type: datetime}],groupBy: [],limit: 100,metrics: [{aggregation: count,field: }],mode: list,orderBy: [],table: tk_wx_control_req_kafka,timeField: timestamp,timeFieldType: DateTime64(3, Asia/Shanghai)}},queryType: sql,rawSql: SELECT upstream_status,count() as num FROM \app_logs\.${table_name} where ( timestamp $__fromTime AND timestamp $__toTime ) group by upstream_status;\r\n,refId: A,selectedFormat: 4}],title: upstream,type: table},{datasource: {type: grafana-clickhouse-datasource,uid: ${datasource}},fieldConfig: {defaults: {mappings: [],thresholds: {mode: percentage,steps: [{color: green,value: null},{color: orange,value: 70},{color: red,value: 85}]}},overrides: []},gridPos: {h: 9,w: 12,x: 12,y: 27},id: 7,options: {orientation: auto,reduceOptions: {calcs: [lastNotNull],fields: ,values: false},showThresholdLabels: false,showThresholdMarkers: true},pluginVersion: 9.1.1,targets: [{builderOptions: {database: app_logs,fields: [],filters: [{condition: AND,filterType: custom,key: timestamp,operator: WITH IN DASHBOARD TIME RANGE,restrictToFields: [{label: timestamp,name: timestamp,picklistValues: [],type: DateTime64(3, Asia/Shanghai)},{label: startTime,name: startTime,picklistValues: [],type: DateTime64(3, Asia/Shanghai)}],type: datetime}],groupBy: [],limit: 100,metrics: [{aggregation: count,field: }],mode: list,orderBy: [],table: tk_wx_control_req_kafka,timeField: timestamp,timeFieldType: DateTime64(3, Asia/Shanghai)},datasource: {type: grafana-clickhouse-datasource,uid: ${datasource}},format: 1,meta: {builderOptions: {database: app_logs,fields: [],filters: [{condition: AND,filterType: custom,key: timestamp,operator: WITH IN DASHBOARD TIME RANGE,restrictToFields: [{label: timestamp,name: timestamp,picklistValues: [],type: DateTime64(3, Asia/Shanghai)},{label: startTime,name: startTime,picklistValues: [],type: DateTime64(3, Asia/Shanghai)}],type: datetime}],groupBy: [],limit: 100,metrics: [{aggregation: count,field: }],mode: list,orderBy: [],table: tk_wx_control_req_kafka,timeField: timestamp,timeFieldType: DateTime64(3, Asia/Shanghai)}},queryType: sql,rawSql: SELECT count() FROM \app_logs\.${table_name} where ( timestamp $__fromTime AND timestamp $__toTime );\r\n,refId: A,selectedFormat: 4}],title: 请求总数,type: gauge}],schemaVersion: 37,style: dark,tags: [],templating: {list: [{current: {selected: false,text: nginx_gw_log,value: nginx_gw_log},datasource: {type: grafana-clickhouse-datasource,uid: ${datasource}},definition: show tables from app_logs where name nginx_gw_log ,hide: 0,includeAll: false,label: table_name,multi: false,name: table_name,options: [],query: show tables from app_logs where name nginx_gw_log ,refresh: 1,regex: ,skipUrlSync: false,sort: 0,type: query},{current: {selected: false,text: ClickHouse_1.178,value: ClickHouse_1.178},hide: 0,includeAll: false,label: datasource,multi: false,name: datasource,options: [],query: grafana-clickhouse-datasource,queryValue: ,refresh: 1,regex: ,skipUrlSync: false,type: datasource},{current: {isNone: true,selected: false,text: None,value: },datasource: {type: grafana-clickhouse-datasource,uid: ${datasource}},definition: select upstream_name from app_logs.nginx_gw_log,hide: 0,includeAll: false,label: upstream_name,multi: false,name: upstream_name,options: [],query: select upstream_name from app_logs.nginx_gw_log,refresh: 2,regex: ,skipUrlSync: false,sort: 0,type: query},{current: {isNone: true,selected: false,text: None,value: },datasource: {type: grafana-clickhouse-datasource,uid: ${datasource}},definition: select nginx_host from app_logs.nginx_gw_log where upstream_name \$upstream_name\,hide: 0,includeAll: false,label: nginx_host,multi: false,name: nginx_host,options: [],query: select nginx_host from app_logs.nginx_gw_log where upstream_name \$upstream_name\,refresh: 1,regex: ,skipUrlSync: false,sort: 0,type: query}]},time: {from: now-5m,to: now},timepicker: {},timezone: ,title: nginx_gw,uid: lZrbSYOIkA,version: 6,weekStart: }最终呈现效果 隐患点 clickhouse 本身查询qps 就不高如果数据量很大可以考虑集群或者其他的存储doris、es等等不知道nginxrsyslog 对性能有多少影响目前测试单机nginx大几千的qps 都没啥问题 有其他更好方案的小伙伴留言哦
http://www.eeditor.cn/news/125936/

相关文章:

  • 移动网站 用户体验企业软件定制开发
  • 东莞专业做外贸网站的公司微信下载安装免费2022
  • 营销型网站建设定制南宁网站制
  • 金华金东区建设局网站代刷网站只做软件下载
  • 专门做问卷调查的一个网站荷城网站设计
  • 网站上的二维码在线生成网站
  • 企业网站多少钱一年网页制作素材网站推荐
  • peise网站成都软件开发培训机构
  • 营销网站建设公司效果佛山学校网站建设
  • 企业网站建设备案都需要什么免费开网店的一件代发
  • 网站建设如何开票国外移动端网站模板
  • 做dna胎儿亲子鉴定网站电商设计教程
  • 网站文章更新怎么做在线图片编辑器软件
  • 海珠营销网站建设报价网站链接分析工具
  • 做五金外贸哪个网站比较好软件开发模型的优缺点
  • app开发公司哪里做seo推广平台
  • wordpress添加编辑器海城整站优化
  • 网站上的招牌图怎么做网站标题和关键词一样
  • 怎么查看网站备案号无代码开发平台 免费
  • 深圳培训公司网站建设郑州新一网站建设
  • 网站创建需要多少钱wordpress修改页面地址
  • 比较出名的wordpress网站网站开发使用的软件
  • wordpress 购物导航网站西乡塘网站建设
  • 启动培训网站建设的请示如何完成seo优化
  • 租个网站服务器多少钱大连网站排名优化公司
  • 如何做京东商城一样的网站快速注销网站备案
  • 如何做免费的网站推广人力管理系统
  • 建设网站实训推进网站建设工作计划
  • 密云成都网站建设设计接单渠道
  • 海西网站建设上海网站建设治汇网络