elfk收集k8s日志(二)
本文介绍通过elk + filebeat方式收集k8s日志,其中filebeat以sidecar方式部署。elfk最新版本:7.6.2
k8s日志收集方案
- 3种日志收集方案:
1. node上部署一个日志收集程序Daemonset方式部署日志收集程序,对本节点 /var/log 和 /var/lib/docker/containers 两个目录下的日志进行采集2. sidecar方式部署日志收集程序每个运行应用程序的pod中附加一个日志收集的容器,使用 emptyDir 共享日志目录让日志容器收集日志3. 应用程序直接推送日志常见的如 graylog 工具,直接修改代码推送日志到es,然后在graylog上展示出来
- 3种收集方案的优缺点:
方案 | 优点 | 缺点 |
---|---|---|
1. node上部署一个日志收集程序 | 每个node仅需部署一个日志收集程序,消耗资源少,对应用无侵入 | 应用程序日志需要写到标准输出和标准错误输出,不支持多行日志 |
2. pod中附加一个日志收集容器 | 低耦合 | 每个pod启动一个日志收集容器,增加资源消耗 |
3. 应用程序直接推送日志 | 无需额外收集工具 | 侵入应用,增加应用复杂度 |
下面测试第1种方案:每个node上部署一个日志收集程序,注意elfk版本保持一致。
SideCar方式收集k8s日志
- 主机说明:
系统 | ip | 角色 | cpu | 内存 | hostname |
---|---|---|---|---|---|
CentOS 7.8 | 192.168.30.128 | master、deploy | >=2 | >=2G | master1 |
CentOS 7.8 | 192.168.30.129 | master | >=2 | >=2G | master2 |
CentOS 7.8 | 192.168.30.130 | node | >=2 | >=2G | node1 |
CentOS 7.8 | 192.168.30.131 | node | >=2 | >=2G | node2 |
CentOS 7.8 | 192.168.30.132 | node | >=2 | >=2G | node3 |
- 搭建k8s集群:
搭建过程省略,具体参考:Kubeadm方式搭建k8s集群 或 二进制方式搭建k8s集群
搭建完成后,查看集群:
kubectl get nodesNAME STATUS ROLES AGE VERSION
master1 Ready master 4d16h v1.14.0
master2 Ready master 4d16h v1.14.0
node1 Ready <none> 4d16h v1.14.0
node2 Ready <none> 4d16h v1.14.0
node3 Ready <none> 4d16h v1.14.0
这里为了方便,直接使用之前的k8s集群,注意删除之前实验的k8s资源对象。
- 部署es集群:
mkdir /elfk & cd /elfkvim elasticsearch.yaml
apiVersion: v1
kind: Service
metadata:name: elasticsearchnamespace: defaultlabels:app: elasticsearch
spec:selector:app: elasticsearchclusterIP: Noneports:- name: apiport: 9200- name: discoveryport: 9300---
apiVersion: apps/v1
kind: StatefulSet
metadata:name: elasticsearchnamespace: default
spec:serviceName: elasticsearchreplicas: 3selector:matchLabels:app: elasticsearchtemplate:metadata:labels:app: elasticsearchspec:containers:- name: elasticsearchimage: docker.elastic.co/elasticsearch/elasticsearch-oss:7.6.2resources:limits:cpu: 1000mrequests:cpu: 100mports:- containerPort: 9200name: apiprotocol: TCP- containerPort: 9300name: discoveryprotocol: TCPenv:- name: "http.host"value: "0.0.0.0"- name: "network.host"value: "_eth0_"- name: "cluster.name"value: "es-cluster"- name: node.namevalueFrom:fieldRef:fieldPath: metadata.name- name: "bootstrap.memory_lock"value: "false"- name: "discovery.seed_hosts"value: "elasticsearch"- name: "cluster.initial_master_nodes"value: "elasticsearch-0,elasticsearch-1,elasticsearch-2"- name: "discovery.seed_resolver.timeout"value: "10s"- name: "discovery.zen.minimum_master_nodes"value: "2"- name: "ES_JAVA_OPTS"value: "-Xms512m -Xmx512m"volumeMounts:- name: datamountPath: /usr/share/elasticsearch/dataterminationGracePeriodSeconds: 30volumes:- name: datahostPath:path: /home/elasticsearch/data #该路径为es数据存储目录,自动创建initContainers:- name: fix-permissionsimage: busyboxcommand: ["sh", "-c", "chown -R 1000:1000 /usr/share/elasticsearch/data"]securityContext:privileged: truevolumeMounts:- name: datamountPath: /usr/share/elasticsearch/data- name: increase-vm-max-mapimage: busyboxcommand: ["sysctl", "-w", "vm.max_map_count=262144"]securityContext:privileged: true- name: increase-fd-ulimitimage: busyboxcommand: ["sh", "-c", "ulimit -n 65536"]securityContext:privileged: true
为了方便,建议提前在所有node节点上拉取elasticsearch镜像:docker pull docker.elastic.co/elasticsearch/elasticsearch-oss:7.6.2
。
kubectl apply -f elasticsearch.yamlkubectl get podNAME READY STATUS RESTARTS AGE
elasticsearch-0 1/1 Running 0 110s
elasticsearch-1 1/1 Running 0 97s
elasticsearch-2 1/1 Running 0 83skubectl get stsNAME READY AGE
elasticsearch 3/3 2m13s
- 部署kibana:
这里为了方便,直接使用NodePort暴露kibana端口。
vim kibana.yaml
apiVersion: v1
kind: Service
metadata:name: kibananamespace: defaultlabels:app: kibana
spec:selector:app: kibanaports:- port: 5601nodePort: 30080type: NodePort---
apiVersion: apps/v1
kind: Deployment
metadata:name: kibananamespace: defaultlabels:app: kibana
spec:selector:matchLabels:app: kibanatemplate:metadata:labels:app: kibanaspec:containers:- name: kibanaimage: docker.elastic.co/kibana/kibana-oss:7.6.2resources:limits:cpu: 1000mrequests:cpu: 100menv:- name: ELASTICSEARCH_HOSTSvalue: "http://elasticsearch:9200"ports:- containerPort: 5601
kubectl apply -f kibana.yamlkubectl get pod |grep kibanakibana-84d7449d95-jg5nt 1/1 Running 0 29skubectl get deploy |grep kibanakibana 1/1 1 1 53s
部署没问题的话,是可以正常访问kibana页面的,浏览器访问ip:30080
,
接下来部署应用程序,收集日志。
- 以sidecar方式部署filebeat收集nginx日志:
vim filebeat-nginx.yaml
apiVersion: v1
kind: Service
metadata:name: nginxnamespace: defaultlabels:app: nginx
spec:selector:app: nginxports:- port: 80nodePort: 30090type: NodePort---
apiVersion: v1
kind: ConfigMap
metadata:name: filebeat-confignamespace: defaultlabels:app: filebeat
data:filebeat.yml: |-filebeat.config:inputs:path: ${path.config}/inputs.d/*.ymlreload.enabled: falsemodules:path: ${path.config}/modules.d/*.ymlreload.enabled: falsefilebeat.inputs:- type: logpaths:- /logdata/*.logtail_files: truefields:pod_name: '${pod_name}'POD_IP: '${POD_IP}'setup.template.name: "nginx-logs"setup.template.pattern: "nginx-logs-*"output.elasticsearch:hosts: ["elasticsearch:9200"]index: "nginx-logs"---
apiVersion: apps/v1
kind: Deployment
metadata:name: nginxnamespace: default
spec:replicas: 1minReadySeconds: 15strategy:rollingUpdate:maxSurge: 1maxUnavailable: 1selector:matchLabels:app: nginxtemplate:metadata:labels:app: nginxspec:terminationGracePeriodSeconds: 30containers:- name: filebeatimage: docker.elastic.co/beats/filebeat-oss:7.6.2args: ["-c", "/etc/filebeat/filebeat.yml","-e",]env:- name: POD_IPvalueFrom:fieldRef:apiVersion: v1fieldPath: status.podIP- name: pod_namevalueFrom:fieldRef:apiVersion: v1fieldPath: metadata.namesecurityContext:runAsUser: 0resources:limits:memory: 200Mirequests:cpu: 200mmemory: 200MivolumeMounts:- name: configmountPath: /etc/filebeat/- name: datamountPath: /usr/share/filebeat/data- name: logdatamountPath: /logdata- name: nginximage: nginx:1.17.0ports:- containerPort: 80volumeMounts:- name: logdatamountPath: /var/log/nginxvolumes:- name: dataemptyDir: {}- name: logdataemptyDir: {}- name: configconfigMap:name: filebeat-configitems:- key: filebeat.ymlpath: filebeat.yml
kubectl apply -f filebeat-nginx.yamlkubectl get pod |grep nginxnginx-865f745bdd-q6xwm 2/2 Running 0 16skubectl describe pod nginx-865f745bdd-q6xwmNormal Scheduled 51s default-scheduler Successfully assigned default/nginx-865f745bdd-q6xwm to node2Normal Pulled 50s kubelet, node2 Container image "docker.elastic.co/beats/filebeat-oss:7.6.2" already present on machineNormal Created 50s kubelet, node2 Created container filebeatNormal Started 50s kubelet, node2 Started container filebeatNormal Pulled 50s kubelet, node2 Container image "nginx:1.17.0" already present on machineNormal Created 50s kubelet, node2 Created container nginxNormal Started 50s kubelet, node2 Started container nginx
访问nginx页面以产生日志:ip:30090
,
- kibana创建索引,查看nginx日志:
可以看到index就是在filebeat配置文件中指定的index——nginx-logs
,添加可用的fields:log.file.path
后,显示日志来源,
因为上面filebeat配置文件中收集的日志路径是/var/log/nginx/*.log
,也可以只指定单个日志(具体的日志路径)并指定index。
- 以sidecar方式部署filebeat收集tomcat日志:
vim filebeat-tomcat.yaml
apiVersion: v1
kind: Service
metadata:name: tomcatnamespace: defaultlabels:app: tomcat
spec:selector:app: tomcatports:- port: 8080nodePort: 30100type: NodePort---
apiVersion: v1
kind: ConfigMap
metadata:name: filebeat-config-tomcatnamespace: defaultlabels:app: filebeat
data:filebeat.yml: |-filebeat.config:inputs:path: ${path.config}/inputs.d/*.ymlreload.enabled: falsemodules:path: ${path.config}/modules.d/*.ymlreload.enabled: falsefilebeat.inputs:- type: logpaths:- /logdata/*.logtail_files: truefields:pod_name: '${pod_name}'POD_IP: '${POD_IP}'setup.template.name: "tomcat-logs"setup.template.pattern: "tomcat-logs-*"output.elasticsearch:hosts: ["elasticsearch:9200"]index: "tomcat-logs"---
apiVersion: apps/v1
kind: Deployment
metadata:name: tomcatnamespace: default
spec:replicas: 1minReadySeconds: 15strategy:rollingUpdate:maxSurge: 1maxUnavailable: 1selector:matchLabels:app: tomcattemplate:metadata:labels:app: tomcatspec:terminationGracePeriodSeconds: 30containers:- name: filebeatimage: docker.elastic.co/beats/filebeat-oss:7.6.2args: ["-c", "/etc/filebeat/filebeat.yml","-e",]env:- name: POD_IPvalueFrom:fieldRef:apiVersion: v1fieldPath: status.podIP- name: pod_namevalueFrom:fieldRef:apiVersion: v1fieldPath: metadata.namesecurityContext:runAsUser: 0resources:limits:memory: 200Mirequests:cpu: 200mmemory: 200MivolumeMounts:- name: configmountPath: /etc/filebeat/- name: datamountPath: /usr/share/filebeat/data- name: logdatamountPath: /logdata- name: tomcatimage: tomcat:8.0.51-alpineports:- containerPort: 8080volumeMounts:- name: logdatamountPath: /usr/local/tomcat/logsvolumes:- name: dataemptyDir: {}- name: logdataemptyDir: {}- name: configconfigMap:name: filebeat-config-tomcatitems:- key: filebeat.ymlpath: filebeat.yml
kubectl apply -f filebeat-tomcat.yamlkubectl get pod |grep tomcattomcat-5c7b6644f4-9hslh 2/2 Running 0 16skubectl describe pod tomcat-5c7b6644f4-9hslhNormal Scheduled 34s default-scheduler Successfully assigned default/tomcat-5c7b6644f4-9hslh to node1Normal Pulled 33s kubelet, node1 Container image "docker.elastic.co/beats/filebeat-oss:7.6.2" already present on machineNormal Created 33s kubelet, node1 Created container filebeatNormal Started 33s kubelet, node1 Started container filebeatNormal Pulled 33s kubelet, node1 Container image "tomcat:8.0.51-alpine" already present on machineNormal Created 33s kubelet, node1 Created container tomcatNormal Started 33s kubelet, node1 Started container tomcat
访问tomcat页面以产生日志:ip:30100
,
- kibana查看tomcat日志:
可以看到index就是在filebeat配置文件中指定的index——tomcat-logs
,添加可用的fields:log.file.path
后,显示日志来源,
因为上面filebeat配置文件中收集的日志路径是/usr/local/tomcat/logs/*.log
,也可以只指定单个日志(具体的日志路径)并指定index。
- 总结:
上面通过sidecar方式部署filebeat收集k8s日志,比使用logagent方式部署filebeat收集k8s日志更加直接,可以指定具体路径并自定义index,在查看日志时也更加方便,缺点就是会增加资源消耗,不过资源消耗在可接受的范围内。
需要注意的是,filebeat对不同应用程序日志收集的ConfigMap名称尽量不要相同,避免冲突和误删除。
上面为了方便,filebeat收集日志是直接输出到es中的,也可以在集群中再部署一个logstash,由filebeat传输到logstash之后进行日志处理再输出到es中,这里就不演示了。
logstash.yaml(参考):
apiVersion: v1
kind: ConfigMap
metadata:name: logstash-confignamespace: default
data:logstash.yml: |http.host: "0.0.0.0"path.config: /usr/share/logstash/pipelinelogstash.conf: |input {beats {port => 5044}}filter {#multiline {#pattern => "^\d{4}-\d{1,2}-\d{1,2}\s\d{1,2}:\d{1,2}:\d{1,2}"#negate => true#what => "previous"#}grok {match => [ "message", "%{TIMESTAMP_ISO8601:logtime} %{LOGLEVEL:level}" ]}}output {elasticsearch {hosts => ["elasticsearch:9200"]index => "your-index-%{+YYYY.MM.dd}"}}---
kind: Service
apiVersion: v1
metadata:name: logstashnamespace: default
spec:selector:app: logstashports:- protocol: TCPport: 5044targetPort: 5044type: ClusterIP---
apiVersion: apps/v1
kind: Deployment
metadata:name: logstashnamespace: default
spec:selector:matchLabels:app: logstashreplicas: 1template:metadata:labels:app: logstashspec:containers:- name: logstashimage: docker.elastic.co/logstash/logstash-oss:7.6.2ports:- containerPort: 5044volumeMounts:- name: configmountPath: /usr/share/logstash/config- name: pipelinemountPath: /usr/share/logstash/pipelinevolumes:- name: configconfigMap:name: logstash-configitems:- key: logstash.ymlpath: logstash.yml- name: pipelineconfigMap:name: logstash-configitems:- key: logstash.confpath: logstash.conf
kubectl get pod |grep logstashlogstash-6b475db5f6-mxxsj 1/1 Running 0 26skubectl logs -f logstash-6b475db5f6-mxxsj[INFO ] 2020-05-17 04:46:22.488 [[main]-pipeline-manager] beats - Beats inputs: Starting input listener {:address=>"0.0.0.0:5044"}
[INFO ] 2020-05-17 04:46:22.501 [[main]-pipeline-manager] javapipeline - Pipeline started {"pipeline.id"=>"main"}
[INFO ] 2020-05-17 04:46:22.532 [Agent thread] agent - Pipelines running {:count=>1, :running_pipelines=>[:main], :non_running_pipelines=>[]}
[INFO ] 2020-05-17 04:46:22.615 [Api Webserver] agent - Successfully started Logstash API endpoint {:port=>9600}
[INFO ] 2020-05-17 04:46:22.639 [[main]<beats] Server - Starting server on port: 5044kubectl get svc |grep logstashlogstash ClusterIP 10.96.103.207 <none> 5044/TCP 1m34s
kubectl get pod |grep nginxnginx-865f745bdd-q6xwm 2/2 Running 0 62mkubectl exec -it nginx-865f745bdd-q6xwm bash[root@nginx-865f745bdd-q6xwm filebeat]# yum install -y telnet[root@nginx-865f745bdd-q6xwm filebeat]# telnet logstash 5044Trying 10.96.103.207...
Connected to logstash.
Escape character is '^]'.
简单测试部署没问题,filebeat容器测试端口连接也没问题,此处省略进一步配置logstash过滤处理日志的过程。
前面提过,sidecar方式部署filebeat的话,elk组件是否部署在k8s集群内无关紧要,只需要连接没问题即可。上面部署的elk组件是在k8s集群内,接下来将elk部署于k8s集群外测试日志收集。
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
相关文章
- spark如果整合Yarn报错或无法查看log需做如下操作
1.修改hadoop的yarn-site.xmlvim /export/servers/hadoop/etc/hadoop/yarn-site.xml<property><name>yarn.resourcemanager.hostname</name><value>node01</value></property><property><name>yarn.nodemanager.aux-services&…...
2024/4/28 0:21:18 - java学习(五)--日期类的方法
日期类也是我们开发时经常碰到的一个类型。特别是涉及到日期类型和字符串类型之间的一些转换时,经常会不知所措。特别是要根据需求,转换成不同的表达形式,或者是截取、比较。下面是根据老九学堂的视频资料,整理的一些例子。package knowledge;import java.text.ParseExcept…...
2024/4/28 0:08:52 - C++ 结构体
结构体是一个构造类型 结构体变量的声明方式定义 struct 结构体类型名 {成员类型 成员名...成员类型 成员名 }声明方式1: 在定义结构体后,使用结构体类型名声明struct PersonInfo {int index;char name[30];short age; };PersonInfo pInfo;方式2:定义结构体时直接声明,…...
2024/4/17 3:12:37 - Problem C: 老师与学生
Problem C: 老师与学生 Description定义Person类, 1.有一个int类型属性age和1个char类型属性sex,分别为年龄和姓名。 2.构造函数和析构函数,输出如样例所示的信息。 定义Student类,是Person类的子类: 1.有一个int类型属性,是学生所在的班级号。 2.构造函数与析构函数,输…...
2024/4/17 3:12:49 - IT项目管理-项目管理过程与领域知识及其关系
IT项目管理-项目管理过程与领域知识及其关系 文章目录IT项目管理-项目管理过程与领域知识及其关系题目分析CMMI项目管理过程-项目计划(PP)知识域*过程矩阵项目管理规划过程组与行业过程PP的联系与区别准备过程 题目了解CMMI项目管理过程-项目计划(PP),使用知识域*过程矩阵…...
2024/4/17 22:48:27 - 入门CV赛题理解
1.赛题数据 对于训练数据每张图片将给出对应得编码标签,和具体的字符框的位置(训练集、测试集和验证集都给出字符位置)、可用于模型训练 在比赛数据的训练集、测试集和验证集中,同一张图片可能包括一个或者多个字符,因此在JSON标注中,会有两个字符的边框信息。 数据指标:…...
2024/4/27 21:17:55 - 文本格式化标签(粗体,斜体,下划线),div标签,span标签
文本格式化标签 在网页中,有时候需要为文字设置粗体,斜体或下划线效果,这就需要HTML中文本格式化标签。 标签语义:突出重要性,比普通文字更重要!!语义 标签加粗 < strong >< /strong >或者< b>< /b >倾斜 < em >< /em >或者< i …...
2024/4/26 2:25:15 - 想成为Python高手,必须看这篇爬虫原理介绍!
前言 本文的文字及图片来源于网络,仅供学习、交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理。 互联网是由一个个站点和网络设备组成的大网,我们通过浏览器访问站点,站点把HTML、JS、CSS代码返回给浏览器,这些代码经过浏览器解析、渲染,将丰…...
2024/4/28 4:59:44 - playbook优化
1.使用变量 1.ansible先实现rsync [root@manager ~]# cd ansible_tasks/ uid = www gid = www port = 873 fake super = yes use chroot = no max connections = 200 timeout = 600 ignore errors read only = false list = false auth users = rsync_backup secrets file = /e…...
2024/4/23 15:22:38 - XXE漏洞原理
XXE漏洞原理 XXE(外部实体注入)是XML外部实体注入。 当应用程序允许引用外部实体时,通过XXE,攻击者可以实现任意文件读取,DOS拒绝服务攻击以及代理扫描内网等。 常规的POST的content-type为application/x-www-form-urlencoded,但只要将其修改为application/json,就可以传…...
2024/4/28 9:20:39 - Anaconda & spyder中的安装第三方库jieba
Anaconda & spyder中的安装第三方库jieba 方法一: Anaconda Prompt中直接pip命令安装 打开Anaconda Prompt输入命令pip install jieba,回车如上图,正在安装。 但是因为外国的网络很不稳定,说一容易安装失败如下图方法二: 方法二 先离线后再本地安装 (此方法是在方法一…...
2024/4/28 2:48:24 - C++ 函数模板
定义 template <类型形式参数表> 返回类型 函数名(形式参数表) {//do something }template<class T> void fun(T t) {//do something }如果采用如下模板,传递了两个不同类型的参数,编译器会产生错误.必须显式标识模板类型 template <class type> type Sum(…...
2024/4/23 15:22:42 - 【Spring Cloud】学习教程(三):服务提供与调用 Eureka【Finchley】
服务提供与调用 Eureka一、服务提供者1.1 POM 包配置1.2 配置文件1.3 启动类1.4 Controller二、服务消费者2.1 使用 LoadBalancerClient2.2 Spring Cloud Ribbon2.3 Spring Cloud Feign踩坑记录三、负载均衡参考 上一篇文章我们介绍了 Eureka 服务注册中心的搭建,这篇文章介绍…...
2024/4/23 15:22:38 - ios RxSwift
RxSwift & MVVM RxSwift介绍(一)——RxSwift初探 RxSwift 学习(一)-- 初探 RxSwift 使用详解系列...
2024/4/26 1:47:09 - 儿童编程那些事--第一课--雾里看花
最近,人工智能(AI)炒的越来越火了,间接带火了儿童编程。于是,AI编程、机器人编程等等更是火遍了城市的大街小巷,大有群魔乱舞、吞噬一切的气势。编程是下一代必备的生活技能也已经成为一个共识。恰好,我也懂那么一点点编程,小孩也正步入学习的深坑,于是,记录下这些点…...
2024/4/23 15:22:35 - 代码精简之道
说明:以下内容来自网络,本人觉得写的非常好,所以分享给大家。1.利用语法1.1.利用三元表达式普通:String title; if (isMember(phone)) {title = "会员"; } else {title = "游客"; }精简:String title = isMember(phone) ? "会员" : "…...
2024/4/23 15:22:31 - 前端工程师市场供与求的关系全面分析
前端工程师缺乏的问题现在是互联网公司遇到的普遍问题,从刚刚起步的初创公司以至于行业巨头都面临这个问题。优秀的前端工程师其实不比国宝熊猫多多少。不少HR都向同行吐槽,公司想要招聘一个前端怎么就这么难呢?市场供求关系就这样,一旦某个职位缺少则其地位就相对高很多。…...
2024/4/23 15:22:30 - 绘王手绘屏一体机Kamvas studio 22登场,为创意提供更广舞台
对设计、绘画类从业者来说,选对装备,就像多了左右手一样,如虎添翼,这是他们对创意工具生产力的不变期待。在过去的2019年,国内知名消费性数位板/数位屏品牌绘王(HUION)推出了多款数位板、数位屏,凭着精致的外观、日益强大的性能,均衡的配置,科技感十足的产品设计,赢得…...
2024/4/25 22:52:50 - 从 0 到 1 入门 IOST 钱包
前言自从比特币主网上线至今,区块链的发展经历了1.0-3.0三个时期的迭代,作为区块链的重要入口,钱包也逐渐发展完善。从最开始的只能储存、收发比特币的单链钱包,到后来能进行链上合约操作的以太坊钱包,再到现在钱包不止是为用户提供存储、流通的资产管理工具,更是一个公链…...
2024/4/18 10:40:47 - IDEA安装及开发工具配置
IDEA安装及开发工具配置1 IDEA简介2 Idea下载安装与破解3 IDEA文件目录介绍4 IDEA优化配置,提高启动和运行速度5 IDEA的setting介绍6 IDEA快捷键介绍 1 IDEA简介 IDEA 全称 IntelliJ IDEA,是java语言开发的集成环境,IntelliJ在业界被公认为最好的java开发工具之一, 尤其在智…...
2024/4/27 3:45:45
最新文章
- 基于HTML+CSS+JavaScript的表白网页
基于HTMLCSSJavaScript的表白网页 前言效果截图(为GIF格式)部分代码领取源码下期更新预报 前言 大部分人都有喜欢的人,学会这个表白代码,下次表白你肯定会成功。 效果截图(为GIF格式) 部分代码 index.htm…...
2024/4/28 10:22:32 - 梯度消失和梯度爆炸的一些处理方法
在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言,在此感激不尽。 权重和梯度的更新公式如下: w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...
2024/3/20 10:50:27 - 开启 Keep-Alive 可能会导致http 请求偶发失败
大家好,我是蓝胖子,说起提高http的传输效率,很多人会开启http的Keep-Alive选项,这会http请求能够复用tcp连接,节省了握手的开销。但开启Keep-Alive真的没有问题吗?我们来细细分析下。 最大空闲时间造成请求…...
2024/4/23 4:15:19 - WPS二次开发专题:WPS SDK实现文档打印功能
作者持续关注WPS二次开发专题系列,持续为大家带来更多有价值的WPS开发技术细节,如果能够帮助到您,请帮忙来个一键三连,更多问题请联系我(QQ:250325397) 在办公场景或者家教场景中经常碰到需要对文档进行打印…...
2024/4/26 8:23:14 - 【外汇早评】美通胀数据走低,美元调整
原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...
2024/4/26 18:09:39 - 【原油贵金属周评】原油多头拥挤,价格调整
原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...
2024/4/28 3:28:32 - 【外汇周评】靓丽非农不及疲软通胀影响
原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...
2024/4/26 23:05:52 - 【原油贵金属早评】库存继续增加,油价收跌
原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...
2024/4/27 4:00:35 - 【外汇早评】日本央行会议纪要不改日元强势
原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...
2024/4/27 17:58:04 - 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响
原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...
2024/4/27 14:22:49 - 【外汇早评】美欲与伊朗重谈协议
原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...
2024/4/28 1:28:33 - 【原油贵金属早评】波动率飙升,市场情绪动荡
原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...
2024/4/27 9:01:45 - 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试
原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...
2024/4/27 17:59:30 - 【原油贵金属早评】市场情绪继续恶化,黄金上破
原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...
2024/4/25 18:39:16 - 【外汇早评】美伊僵持,风险情绪继续升温
原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...
2024/4/28 1:34:08 - 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势
原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...
2024/4/26 19:03:37 - 氧生福地 玩美北湖(上)——为时光守候两千年
原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...
2024/4/28 1:22:35 - 氧生福地 玩美北湖(中)——永春梯田里的美与鲜
原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...
2024/4/25 18:39:14 - 氧生福地 玩美北湖(下)——奔跑吧骚年!
原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...
2024/4/26 23:04:58 - 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!
原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...
2024/4/27 23:24:42 - 「发现」铁皮石斛仙草之神奇功效用于医用面膜
原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...
2024/4/28 5:48:52 - 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者
原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...
2024/4/26 19:46:12 - 广州械字号面膜生产厂家OEM/ODM4项须知!
原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...
2024/4/27 11:43:08 - 械字号医用眼膜缓解用眼过度到底有无作用?
原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...
2024/4/27 8:32:30 - 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...
解析如下:1、长按电脑电源键直至关机,然后再按一次电源健重启电脑,按F8健进入安全模式2、安全模式下进入Windows系统桌面后,按住“winR”打开运行窗口,输入“services.msc”打开服务设置3、在服务界面,选中…...
2022/11/19 21:17:18 - 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。
%读入6幅图像(每一幅图像的大小是564*564) f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...
2022/11/19 21:17:16 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...
win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面,在等待界面中我们需要等待操作结束才能关机,虽然这比较麻烦,但是对系统进行配置和升级…...
2022/11/19 21:17:15 - 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...
有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows,请勿关闭计算机”的提示,要过很久才能进入系统,有的用户甚至几个小时也无法进入,下面就教大家这个问题的解决方法。第一种方法:我们首先在左下角的“开始…...
2022/11/19 21:17:14 - win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...
置信有很多用户都跟小编一样遇到过这样的问题,电脑时发现开机屏幕显现“正在配置Windows Update,请勿关机”(如下图所示),而且还需求等大约5分钟才干进入系统。这是怎样回事呢?一切都是正常操作的,为什么开时机呈现“正…...
2022/11/19 21:17:13 - 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...
Win7系统开机启动时总是出现“配置Windows请勿关机”的提示,没过几秒后电脑自动重启,每次开机都这样无法进入系统,此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一:开机按下F8,在出现的Windows高级启动选…...
2022/11/19 21:17:12 - 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...
有不少windows10系统用户反映说碰到这样一个情况,就是电脑提示正在准备windows请勿关闭计算机,碰到这样的问题该怎么解决呢,现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法:1、2、依次…...
2022/11/19 21:17:11 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...
今天和大家分享一下win7系统重装了Win7旗舰版系统后,每次关机的时候桌面上都会显示一个“配置Windows Update的界面,提示请勿关闭计算机”,每次停留好几分钟才能正常关机,导致什么情况引起的呢?出现配置Windows Update…...
2022/11/19 21:17:10 - 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...
只能是等着,别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚,只能是考虑备份数据后重装系统了。解决来方案一:管理员运行cmd:net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...
2022/11/19 21:17:09 - 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?
原标题:电脑提示“配置Windows Update请勿关闭计算机”怎么办?win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢?一般的方…...
2022/11/19 21:17:08 - 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...
关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!关机提示 windows7 正在配…...
2022/11/19 21:17:05 - 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...
钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...
2022/11/19 21:17:05 - 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...
前几天班里有位学生电脑(windows 7系统)出问题了,具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面,长时间没反应,无法进入系统。这个问题原来帮其他同学也解决过,网上搜了不少资料&#x…...
2022/11/19 21:17:04 - 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...
本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法,并在最后教给你1种保护系统安全的好方法,一起来看看!电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中,添加了1个新功能在“磁…...
2022/11/19 21:17:03 - 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...
许多用户在长期不使用电脑的时候,开启电脑发现电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机。。.这要怎么办呢?下面小编就带着大家一起看看吧!如果能够正常进入系统,建议您暂时移…...
2022/11/19 21:17:02 - 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...
配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!配置windows update失败 还原更改 请勿关闭计算机&#x…...
2022/11/19 21:17:01 - 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...
不知道大家有没有遇到过这样的一个问题,就是我们的win7系统在关机的时候,总是喜欢显示“准备配置windows,请勿关机”这样的一个页面,没有什么大碍,但是如果一直等着的话就要两个小时甚至更久都关不了机,非常…...
2022/11/19 21:17:00 - 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...
当电脑出现正在准备配置windows请勿关闭计算机时,一般是您正对windows进行升级,但是这个要是长时间没有反应,我们不能再傻等下去了。可能是电脑出了别的问题了,来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...
2022/11/19 21:16:59 - 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...
我们使用电脑的过程中有时会遇到这种情况,当我们打开电脑之后,发现一直停留在一个界面:“配置Windows Update失败,还原更改请勿关闭计算机”,等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢࿰…...
2022/11/19 21:16:58 - 如何在iPhone上关闭“请勿打扰”
Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...
2022/11/19 21:16:57