k8s-----19、Helm

news2024/9/24 13:26:07

Helm

  • 1、引入
  • 2、概述
    • 2.1 重点
    • 2.2 V3版本的Helm
      • 2.2.1 与之前版本的不同之处
      • 2.2.2 V3版本的运行流程
  • 3、安装和配置仓库、一些附带操作
    • 3.1 安装
    • 3.2 配置仓库
    • 3.3 常用命令
    • 3.4 添加helm的自动补齐
  • 4、快速部署应用(weave应用)
  • 5、 自行创建Chart
    • 5.1 Chart目录内容解析
    • 5.2 简单安装部署
    • 5.3 应用升级回退
  • 6、Chart模板实现高效复用
    • 6.1 在values.yaml文件中定义全局变量
    • 6.2 在templates中的yaml文件中定义变量

1、引入

  • K8S 上的应用对象,都是由特定的资源描述组成,包括 deployment、service 等。都保存 各自文件中或者集中写到一个配置文件。然后 kubectl apply –f 部署。如果应用只由一 个或几个这样的服务组成,上面部署方式足够了。而对于一个复杂的应用,会有很多类似 上面的资源描述文件,例如微服务架构应用,组成应用的服务可能多达十个,几十个。如 果有更新或回滚应用的需求,可能要修改和维护所涉及的大量资源文件,而这种组织和管 理应用的方式就显得力不从心了。且由于缺少对发布过的应用版本管理和控制,使 Kubernetes 上的应用维护和更新等面临诸多的挑战,主要面临以下问题:(1)如何将这 些服务作为一个整体管理 (2)这些资源文件如何高效复用 (3)不支持应用级别的版本管理

2、概述

2.1 重点

  • Helm 是一个 Kubernetes 的包管理工具,就像 Linux 下的包管理器,如 yum/apt 等,可以 很方便的将之前打包好的 yaml 文件部署到 kubernetes 上。
  • Helm 有 3 个重要概念: (1)helm:一个命令行客户端工具,主要用于 Kubernetes 应用 chart 的创建、打包、发 布和管理。 (2)Chart:简单理解就是把yaml文件进行打包,是yaml文件的集合。官方描述为应用描述,一系列用于描述 k8s 资源相关文件的集合。 (3)Release:基于 Chart 的部署实体。一个 chart 被 Helm 运行后将会生成对应的一个 release;将在 k8s 中创建出真实运行的资源对象。通俗来说,每次部署后都会对应一个版本,也是所说的release。主要是为了进行版本管理。

2.2 V3版本的Helm

2.2.1 与之前版本的不同之处

  • 删除了Tiller
  • release可以在不同命名空间中进行重用
  • 可以将Chart直接推送到docker镜像仓库中

2.2.2 V3版本的运行流程

在这里插入图片描述

3、安装和配置仓库、一些附带操作

3.1 安装

官网下载V3版本Helm

 [root@master helm]# tar zxvf helm-v3.8.2-linux-amd64.tar.gz 
linux-amd64/
linux-amd64/helm
linux-amd64/LICENSE
linux-amd64/README.md
[root@master helm]# ls
helm-v3.0.0-linux-amd64.tar.gz  helm-v3.8.2-linux-amd64.tar.gz  linux-amd64
[root@master helm]# cd linux-amd64/
[root@master linux-amd64]# ls
helm  LICENSE  README.md
[root@master linux-amd64]# mv helm /usr/bin/  #移动 

3.2 配置仓库

##添加仓库: helm repo add 自己起仓库名字   仓库地址 
[root@master ~]# helm repo add stable http://mirror.azure.cn/kubernetes/charts  ##添加微软仓库
"stable" has been added to your repositories
[root@master ~]# helm repo add aliyun https://kubernetes.oss-cn-hangzhou.aliyuncs.com/charts 添加阿里云仓库
"aliyun" has been added to your repositories
[root@master ~]# helm repo update  ##更新仓库

[root@master ~]# helm repo list  ##列出仓库信息
NAME  	URL                                                   
stable	http://mirror.azure.cn/kubernetes/charts              
aliyun	https://kubernetes.oss-cn-hangzhou.aliyuncs.com/charts

[root@master ~]# helm repo remove stable   ##删除仓库
"stable" has been removed from your repositories
[root@master ~]# helm repo list
NAME  	URL                                                   
aliyun	https://kubernetes.oss-cn-hangzhou.aliyuncs.com/charts

3.3 常用命令

命令描述
dependency管理 chart 依赖
get下载一个 release。可用子命令:all、hooks、manifest、notes、values
history获取 release 历史
install安装一个 chart
list列出 release
package将 chart 目录打包到 chart 存档文件中
pull从远程仓库中下载 chart 并解压到本地 # helm pull stable/mysql – untar
repo添加,列出,移除,更新和索引 chart 仓库。可用子命令:add、index、 list、remove、update
rollback从之前版本回滚
search根据关键字搜索 chart。可用子命令:hub、repo
show查看 chart 详细信息。可用子命令:all、chart、readme、values
status显示已命名版本的状态
template本地呈现模板
uninstall卸载一个 release
upgrade更新一个 release
version查看 helm 客户端版本

3.4 添加helm的自动补齐

[root@master bash_completion.d]# echo "source <(helm completion bash)" >>  ~/.bash_profile
[root@master bash_completion.d]# source ~/.bash_profile 

[root@master bash_completion.d]# helm completion bash > /usr/share/bash-completion/completions/helm

4、快速部署应用(weave应用)

[root@master ~]# helm install ui aliyun/weave-scope  #出现下面错误是因为仓库的问题,阿里云可能没事实时匹配到k8s,换成微软源可以解决
Error: INSTALLATION FAILED: unable to build kubernetes objects from release manifest: [unable to recognize "": no matches for kind "DaemonSet" in version "extensions/v1beta1", unable to recognize "": no matches for kind "Deployment" in version "apps/v1beta1"]

[root@master ~]# helm repo add stable http://mirror.azure.cn/kubernetes/charts/   ##添加微软仓库
[root@master ~]# helm repo update
[root@master ~]# helm repo list
NAME  	URL                                                   
aliyun	https://kubernetes.oss-cn-hangzhou.aliyuncs.com/charts
stable	http://mirror.azure.cn/kubernetes/charts/  

##部署           
[root@master ~]# helm search repo weave   ##部署的是一个ui界面应用,所以需要对外暴露端口,需要查看SVC的状态是否为NodePort
NAME              	CHART VERSION	APP VERSION	DESCRIPTION                                       
aliyun/weave-cloud	0.1.2        	           	Weave Cloud is a add-on to Kubernetes which pro...
aliyun/weave-scope	0.9.2        	1.6.5      	A Helm chart for the Weave Scope cluster visual...
stable/weave-cloud	0.3.9        	1.4.0      	DEPRECATED - Weave Cloud is a add-on to Kuberne...
stable/weave-scope	1.1.12       	1.12.0     	DEPRECATED - A Helm chart for the Weave Scope c...

##helm install 自己起的名称  仓库里包的名称
[root@master ~]# helm install ui stable/weave-scope
WARNING: This chart is deprecated
W0514 11:23:29.545784   20101 warnings.go:70] rbac.authorization.k8s.io/v1beta1 ClusterRole is deprecated in v1.17+, unavailable in v1.22+; use rbac.authorization.k8s.io/v1 ClusterRole
W0514 11:23:29.546481   20101 warnings.go:70] rbac.authorization.k8s.io/v1beta1 ClusterRoleBinding is deprecated in v1.17+, unavailable in v1.22+; use rbac.authorization.k8s.io/v1 ClusterRoleBinding
W0514 11:23:29.567192   20101 warnings.go:70] rbac.authorization.k8s.io/v1beta1 ClusterRole is deprecated in v1.17+, unavailable in v1.22+; use rbac.authorization.k8s.io/v1 ClusterRole
W0514 11:23:29.569900   20101 warnings.go:70] rbac.authorization.k8s.io/v1beta1 ClusterRoleBinding is deprecated in v1.17+, unavailable in v1.22+; use rbac.authorization.k8s.io/v1 ClusterRoleBinding
NAME: ui
LAST DEPLOYED: Sat May 14 11:23:29 2022
NAMESPACE: default
STATUS: deployed
REVISION: 1
NOTES:
You should now be able to access the Scope frontend in your web browser, by
using kubectl port-forward:

kubectl -n default port-forward $(kubectl -n default get endpoints \
ui-weave-scope -o jsonpath='{.subsets[0].addresses[0].targetRef.name}') 8080:4040

then browsing to http://localhost:8080/.
For more details on using Weave Scope, see the Weave Scope documentation:

https://www.weave.works/docs/scope/latest/introducing/


[root@master ~]# helm list   ##查看部署的应用
NAME	NAMESPACE	REVISION	UPDATED                                	STATUS  	CHART             	APP VERSION
ui  	default  	1       	2022-05-14 11:23:29.478377222 +0800 CST	deployed	weave-scope-1.1.12	1.12.0     
[root@master ~]# helm status ui      #查看部署应用的状态
NAME: ui
LAST DEPLOYED: Sat May 14 11:23:29 2022
NAMESPACE: default
STATUS: deployed
REVISION: 1
NOTES:
You should now be able to access the Scope frontend in your web browser, by
using kubectl port-forward:
kubectl -n default port-forward $(kubectl -n default get endpoints \
ui-weave-scope -o jsonpath='{.subsets[0].addresses[0].targetRef.name}') 8080:4040
then browsing to http://localhost:8080/.
For more details on using Weave Scope, see the Weave Scope documentation:
https://www.weave.works/docs/scope/latest/introducing/


##查看部署情况
[root@master ~]# kubectl get pods   ##查看部署的pod
NAME                                            READY   STATUS    RESTARTS   AGE
weave-scope-agent-ui-d7fv8                      1/1     Running   0          9m21s
weave-scope-agent-ui-mrnb5                      1/1     Running   0          9m21s
weave-scope-agent-ui-nrtrn                      1/1     Running   0          9m21s
weave-scope-cluster-agent-ui-5cbc84db49-fzf7f   1/1     Running   0          9m21s
weave-scope-frontend-ui-6698fd5545-pn8tc        1/1     Running   0          9m21s
web-96d5df5c8-zcshb                             1/1     Running   1          15h
[root@master ~]# kubectl get svc   ##ui-weave-scope的svc状态没有暴露端口
NAME             TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)        AGE
kubernetes       ClusterIP   10.96.0.1       <none>        443/TCP        65d
ui-weave-scope   ClusterIP   10.101.125.54   <none>        80/TCP         9m25s
web              NodePort    10.96.63.223    <none>        80:31281/TCP   15h      
[root@master ~]# kubectl edit svc ui-weave-scope   ## 编辑内部yaml文件,将状态换为NodePort
service/ui-weave-scope edited
[root@master ~]# kubectl describe svc ui-weave-scope
Name:                     ui-weave-scope
Namespace:                default
Labels:                   app=weave-scope
                          app.kubernetes.io/managed-by=Helm
                          chart=weave-scope-frontend-1.1.10
                          component=frontend
                          heritage=Helm
                          release=ui
Annotations:              cloud.weave.works/launcher-info:
                            {
                              "server-version": "master-4fe8efe",
                              "original-request": {
                                "url": "/k8s/v1.7/scope.yaml"
                              },
                              "email-address": "support@weave.works",
                              "source-app": "weave-scope",
                              "weave-cloud-component": "scope"
                            }
                          meta.helm.sh/release-name: ui
                          meta.helm.sh/release-namespace: default
Selector:                 app=weave-scope,component=frontend,release=ui
Type:                     NodePort   ##状态已经修改
IP Families:              <none>
IP:                       10.101.125.54
IPs:                      10.101.125.54
Port:                     http  80/TCP
TargetPort:               http/TCP
NodePort:                 http  31055/TCP
Endpoints:                10.244.2.36:4040
Session Affinity:         None
External Traffic Policy:  Cluster
Events:                   <none>
[root@master ~]# kubectl get svc
NAME             TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)        AGE
kubernetes       ClusterIP   10.96.0.1       <none>        443/TCP        65d
ui-weave-scope   NodePort    10.101.125.54   <none>        80:31055/TCP   15m
web              NodePort    10.96.63.223    <none>        80:31281/TCP   15h


  • 最终布置效果
    在这里插入图片描述

5、 自行创建Chart

5.1 Chart目录内容解析

  • chart.yaml 指当前chart属性配置信息
  • templates 编写的yaml文件放到当前目录
  • values.yaml yaml文件可以使用全局变量

5.2 简单安装部署

[root@master ~]# helm create mychart   ##创建Chart

[root@master ~]# cd mychart/
[root@master mychart]# ls
charts  Chart.yaml  templates  values.yaml
[root@master mychart]# cd templates/
[root@master templates]# ls
deployment.yaml  hpa.yaml      NOTES.txt            service.yaml  
_helpers.tpl     ingress.yaml  serviceaccount.yaml  tests

[root@master mychart]# kubectl create deployment web1 --image=nginx --dry-run -o yaml >
deployment.yaml

[root@master mychart]# kubectl create deployment web1 --image=nginx   ##后续创建svc需要web1存在
[root@master templates]# kubectl expose deployment web1 --port=80 --target-port=80 --type=NodePort --dry-run -o yaml > service.yaml   ##创建service.yaml
[root@master ~]# kubectl delete deployments.apps web1    ##删除,一会通过helm进行安装
[root@master templates]# ls
deployment.yaml  service.yaml


# helm安装
[root@master ~]# helm install web1 mychart/   ##install+ 自己起名称+ Chart目录
NAME: web1
LAST DEPLOYED: Sat May 14 20:15:51 2022
NAMESPACE: default
STATUS: deployed
REVISION: 1
TEST SUITE: None
[root@master ~]# kubectl get svc
NAME             TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)        AGE
kubernetes       ClusterIP   10.96.0.1        <none>        443/TCP        66d
ui-weave-scope   NodePort    10.101.125.54    <none>        80:31055/TCP   8h
web              NodePort    10.96.63.223     <none>        80:31281/TCP   24h
web1             NodePort    10.108.249.102   <none>        80:30502/TCP   7s
[root@master ~]# kubectl get pod 
NAME                                            READY   STATUS              RESTARTS   AGE
web1-6fbb48567f-pdgxv                           1/1     Running   0          13s

5.3 应用升级回退

[root@master ~]# helm history web1 
REVISION	UPDATED                 	STATUS    	CHART        	APP VERSION	DESCRIPTION     
1       	Sat May 14 20:15:51 2022	superseded	mychart-0.1.0	1.16.0     	Install complete
2       	Sat May 14 20:18:18 2022	superseded	mychart-0.1.0	1.16.0     	Upgrade complete
3       	Sat May 14 20:18:31 2022	deployed  	mychart-0.1.0	1.16.0     	Rollback to 1   
[root@master ~]# helm upgrade web1 mychart/   ##升级
Release "web1" has been upgraded. Happy Helming!
NAME: web1
LAST DEPLOYED: Sat May 14 20:18:18 2022
NAMESPACE: default
STATUS: deployed
REVISION: 2
TEST SUITE: None
[root@master ~]# helm rollback web1   ##回退到上一版本
Rollback was a success! Happy Helming!
[root@master ~]# helm rollback web1 2  ##回退到指定版本

6、Chart模板实现高效复用

  • 通过传递参数,动态渲染模板,yaml文件内容动态传入参数生成。主要是通过value.yaml文件

  • 实现主要分为两步:1、通过values.yaml文件定义变量和值;2、在具体的模板下的yaml文件中进行获取变量

  • 一般情况下,yaml文件中不同的有name、label、replicas、tag、port

6.1 在values.yaml文件中定义全局变量

[root@master ~]# cd mychart/
[root@master mychart]# ls
charts  Chart.yaml  templates  values.yaml
[root@master mychart]# vim values.yaml 
[root@master mychart]# cat values.yaml    ##主要修改的变量信息
image: nginx
replicas: 1
tag: 1.16
label: nginx
port: 80

6.2 在templates中的yaml文件中定义变量

  • 通过表达式形式定义变量 {{ .Values.变量名称}} 还有一种常用的定义名字的{{ .Release.Name}}
[root@master templates]# pwd
/root/mychart/templates

[root@master templates]# cat deployment.yaml 
apiVersion: apps/v1
kind: Deployment
metadata:
  creationTimestamp: null
  labels:
    app: {{ .Values.label}}
  name: {{ .Release.Name}}-deploy
spec:
  replicas: {{ .Values.replicas}}
  selector:
    matchLabels:
      app: {{ .Values.label}}
  strategy: {}
  template:
    metadata:
      creationTimestamp: null
      labels:
        app: {{ .Values.label}}
    spec:
      containers:
      - image: {{ .Values.image}}
        name: {{ .Values.label}}
        resources: {}
status: {}

[root@master templates]# cat service.yaml 
apiVersion: v1
kind: Service
metadata:
  creationTimestamp: null
  labels:
    app: {{ .Values.label}}
  name: {{ .Release.Name}}-svc
spec:
  ports:
  - port: {{ .Values.port}}
    protocol: TCP
    targetPort: {{ .Values.port}}
  selector:
    app: {{ .Release.Name}}-svc
  type: NodePort
status:
  loadBalancer: {}
 
 
[root@master ~]# helm install web2 mychart/ --dry-run   ##生成说明成功了
NAME: web2
LAST DEPLOYED: Sat May 14 21:33:23 2022
NAMESPACE: default
STATUS: pending-install
REVISION: 1
TEST SUITE: None
HOOKS:
MANIFEST:
---
# Source: mychart/templates/service.yaml
apiVersion: v1
kind: Service
metadata:
  creationTimestamp: null
  labels:
    app: nginx
  name: web2-svc
spec:
  ports:
  - port: 80
    protocol: TCP
    targetPort: 80
  selector:
    app: web2-svc
  type: NodePort
status:
  loadBalancer: {}
---
# Source: mychart/templates/deployment.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  creationTimestamp: null
  labels:
    app: nginx
  name: web2-deploy
spec:
  replicas: 1
  selector:
    matchLabels:
      app: nginx
  strategy: {}
  template:
    metadata:
      creationTimestamp: null
      labels:
        app: nginx
    spec:
      containers:
      - image: nginx
        name: nginx
        resources: {}
status: {}
[root@master ~]# helm install web2 mychart/ 
NAME: web2
LAST DEPLOYED: Sat May 14 21:35:06 2022
NAMESPACE: default
STATUS: deployed
REVISION: 1
TEST SUITE: None
[root@master ~]# kubectl get pods
NAME                                            READY   STATUS    RESTARTS   AGE
web2-deploy-6799fc88d8-8khvj                    1/1     Running   0          25s
[root@master ~]# kubectl get svc
NAME             TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)        AGE
web2-svc         NodePort    10.101.45.10     <none>        80:30704/TCP   30s

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

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

相关文章

基于springcloud+web实现智慧养老平台系统项目【项目源码+论文说明】

基于springcloudweb实现智慧养老平台演示 摘要 首先,论文一开始便是清楚的论述了系统的研究内容。其次,剖析系统需求分析,弄明白“做什么”,分析包括业务分析和业务流程的分析以及用例分析,更进一步明确系统的需求。然后在明白了系统的需求基础上需要进一步地设计系统,主要包罗…

stm32f10系列的独立看门狗与窗口看门狗

在由单片机构成的微型计算机系统中&#xff0c;由于单片机的工作常常会受到来自外界电磁场的干扰&#xff0c;造 成程序的跑飞&#xff0c;而陷入死循环&#xff0c;程序的正常运行被打断&#xff0c;由单片机控制的系统无法继续工作&#xff0c;会 造成整个系统的陷入停滞状态…

[Note] 汉明码与汉明距离的思考

Hamming distance 定义 汉明距离&#xff0c;定义是两个码字之间的不同的位的数量&#xff0c;例如4’b0000和4’b0011的汉明距离为2&#xff0c;4’b0000和4’b1110的汉明距离为3。 一种编码方式的&#xff08;最小&#xff09;汉明距离&#xff0c;它的定义就是&#xff0c;…

与创新者同行,Doris Summit Asia 2023 线下技术峰会圆满落幕!

10 月 21 日&#xff0c;由飞轮科技主办、阿里云与腾讯云联合主办的 Apache Doris 社区首届线下技术峰会 Doris Summit Asia 2023 在一片热潮中落下帷幕。 本届峰会以「与创新者同行」为主题&#xff0c;设置主论坛和智慧金融与政企、先进智造与电信、企业服务与新经济、互联网…

做地推共享wifi贴的如今都怎么样了?

近年来&#xff0c;随着移动互联网的普及和发展&#xff0c;无线网络已经成为人们日常生活中不可或缺的一部分。然而&#xff0c;很多公共场所的WiFi网络并不方便使用&#xff0c;需要输入密码或者注册账号&#xff0c;给用户带来了不便。为了解决这个问题&#xff0c;一种名为…

元对象系统功能

元对象系统功能 建立工程 布局页面 布局页面 修改原件名称 建立元对象 函数作为接口 增加一些固定的属性 #------------------------------------------------- # # Project created by QtCreator 2023-10-24T21:54:44 # #----------------------------…

LLM在text2sql上的应用 | 京东云技术团队

一、前言&#xff1a; 目前&#xff0c;大模型的一个热门应用方向text2sql它可以帮助用户快速生成想要查询的SQL语句。那对于用户来说&#xff0c;大部分简单的sql都是正确的&#xff0c;但对于一些复杂逻辑来说&#xff0c;需要用户在产出SQL的基础上进行简单修改&#xff0c…

金字塔切分注意力模块PSA学习笔记 (附代码)

已有研究表明&#xff1a;将注意力模块嵌入到现有CNN中可以带来显著的性能提升。比如&#xff0c;SENet、BAM、CBAM、ECANet、GCNet、FcaNet等注意力机制均带来了可观的性能提升。但是&#xff0c;目前仍然存在两个具有挑战性的问题需要解决。一是如何有效地获取和利用不同尺度…

主流电商平台价格如何高频监测

双十一来临在即&#xff0c;除了商家很兴奋&#xff0c;品牌和消费者同样持续关注&#xff0c;除了关注不同平台的产品上架情况&#xff0c;价格也是这些渠道参与者最为关注的&#xff0c;品牌需要通过掌握各店铺的价格情况&#xff0c;了解市场情况以及各经销商的渠道治理现状…

从零搭建一个PWA应用需要了解哪些知识

在国内由于小程序的风生水起&#xff0c;PWA 应用在国内的状况一直都不是很好&#xff0c;PWA 和小程序有很多的相似性&#xff0c;但是 PWA 是由谷歌发起的技术&#xff0c;小程序是微信发起的技术&#xff0c;所以小程序在国内得到了大力的扶持&#xff0c;很快就在国内技术界…

docker制作java项目镜像

docker制作java项目镜像 环境步骤Dockerfile 运行容器 环境 当前使用win10安装的docker win10安装Docker参考文章 步骤 将Dockerfile文件和jar包放在同一个目录下 编写Dockerfile文件 Dockerfile #设置镜像基础: jdk8-jre , 比jdk内存小 FROM java:8-jre #维护人员信息 MA…

众和策略可靠吗?dde大单净量可信吗?

可靠 DDE大单净量是指股票成交中的单笔生意量较大且净买入或净卖出的数量。这个方针在股票商场中被广泛运用&#xff0c;尤其是在技术剖析中。但是&#xff0c;有时候人们会怀疑DDE大单净量的可信度&#xff0c;下面我们从几个角度进行剖析。 首要&#xff0c;有些人以为DDE大…

持续性输出,继续推荐5款好用的软件

​ 分享是一种神奇的东西&#xff0c;它使快乐增大&#xff0c;它使悲伤减小&#xff0c;坚持分享一些好用的软件给大家&#xff0c;今天继续为大家带来五款好用的小软件。 1.文件解锁工具——Unlocker ​ Unlocker是一款解决Windows文件被占用无法删除或重命名的问题的小工具…

mysql数据库迁移达梦

迁移前准备&#xff1a; 授权给要迁移的数据库的用户&#xff0c;例如此时是 mysql迁移到达梦里面&#xff0c;所以得把你连接这个mysql数据库的这个用户root授权&#xff0c; CREATE USER root IDENTIFIED BY1123456;GRANT ALL privileges ON *.* TO rootroot WITH GRANT OPTI…

微信小程序菜单导航选中自动居中

菜单导航选中自动居中 示例库 代码片段

Qt之自定义事件QEvent

在Qt中,自定义事件的步骤大概如下: 1.创建自定义事件,自定义事件需要继承QEvent 2.使用QEvent::registerEventType()注册自定义事件类型,事件的类型需要在 QEvent::User 和 QEvent::MaxUser 范围之间,在QEvent::User之前是预留给系统的事件 3.使用sendEvent() 和 postEv…

迅为RK3399开发板Android 系统--打印级别设置(printk日志等级设置)

在内核源码 include/linux/kern_levels.h 文件中预定义了内核 log 等级&#xff0c;一共有八个等级&#xff0c;从 0 到 7&#xff0c;优先级依次降低&#xff0c;如下所示&#xff1a; // include/linux/kern_levels.h #define KERN_SOH "\001" /* ASCII Start Of…

Khronos: 面向万亿规模时间线的性能监控引擎建设实践

作者&#xff1a;余文清 阿里巴巴智能引擎事业部自研的 Khronos 系统是阿里内部接入规模最大的性能数据存储引擎。Khronos 支持动态生命周期的存储计算分离架构&#xff0c;采用 schemaless 的 data model 设计&#xff0c;在万亿数据规模下为业务提供易用、高效、经济的服务&a…

自媒体创业秘籍:视频号视频下载助你打造热门账号

​自媒体创业者们都知道&#xff0c;视频号已经成为拓展影响力和吸引更多用户的热门平台之一。然而&#xff0c;要想在这个竞争激烈的市场中脱颖而出&#xff0c;并打造一个热门账号&#xff0c;你需要掌握一些技巧和秘籍。在本文中&#xff0c;我将分享关于视频号视频下载的方…