【K8S系列】深入解析无状态服务

news2025/1/17 18:04:41

 

目录

序言

1. 无服务介绍

1.1 优点

1.2 使用场景

1.3 资源类型

1.4 总结

2 使用介绍

2.1 Deployment

使用场景:

2.2 ReplicaSet

使用场景

2.3 pod

Pod 资源定义示例

2.4 service

创建一个Deployment:

创建一个Service:

总结:

2.5 ingress

安装Ingress控制器

创建Ingress规则

 应用Ingress规则

访问服务

总结:

2.6 configMap

3 总结

使用场景总结

 ReplicaSet 和 Deployment区别总结:


序言

所有幸运和巧合的事,要么是上天注定,要么是一个人偷偷的在努力。

文章标记颜色说明:

  • 黄色:重要标题
  • 红色:用来标记结论
  • 绿色:用来标记一级论点
  • 蓝色:用来标记二级论点

Kubernetes (k8s) 是一个容器编排平台,允许在容器中运行应用程序和服务。今天学习一下无状态服务。

1. 无服务介绍

无状态服务是一种不需要保存任何数据状态的服务,也不需要维护任何会话信息的服务

这些服务通常被设计为可扩展和高可用性的,因为它们可以在任何时间点部署或删除,而不会对应用程序的可用性产生影响。

1.1 优点

无状态服务的优点包括:

  1. 可扩展性:由于无状态服务不需要维护状态信息,因此它们可以轻松地水平扩展,以应对高流量和负载情况。

  2. 高可用性:无状态服务可以通过多个副本来提高可用性,并且它们可以在任何时间点部署或删除,而不会影响应用程序的可用性。

  3. 简单性:由于无状态服务不需要维护状态信息,因此它们通常比有状态服务更简单、更容易维护。

1.2 使用场景

以下是一些无状态服务的使用场景详细介绍:

  1. 网络应用程序:无状态服务非常适合网络应用程序,例如Web服务器、API服务器、负载均衡器等。这些应用程序可以通过多个副本来提高可用性,并且它们可以通过水平扩展来处理更多的请求。

  2. 批处理作业:无状态服务也可以用于批处理作业,例如数据处理、日志分析、图像处理等。这些作业可以在任何时间点启动或停止,并且可以在多个节点上并行运行以提高效率。

  3. 队列服务:无状态服务还可以用于队列服务,例如消息队列、任务队列等。这些服务可以将消息或任务发送到队列中,并由多个工作者节点消费它们,以提高处理效率。

1.3 资源类型

在Kubernetes中,无状态服务资源类型主要包括以下几种:

  1. DeploymentDeployment是一种用于创建可扩展的无状态服务的资源类型。它允许定义副本数,并使用Rolling Update策略来升级服务,从而保持服务的可用性。

  2. ReplicaSetReplicaSet是Deployment的底层实现,用于确保在任何时间点都有指定数量的Pod副本在运行。当Pod崩溃或者被删除时,ReplicaSet会自动创建新的Pod副本,以确保所需的Pod副本数不变。

  3. Pod:Pod是Kubernetes中最小的可部署单元,用于运行一个或多个容器。通常,每个Pod只运行一个容器,但在某些情况下,可能需要在同一个Pod中运行多个容器。

  4. Service:Service是一种用于将多个Pod打包在一起并提供访问它们的统一入口的资源类型。Service可以使用Cluster IP、NodePort或者LoadBalancer等不同类型的服务来暴露Pod。

  5. Ingress :Ingress 是一种 k8s 资源类型,用于将集群内部的 HTTP 和 HTTPS 流量路由到 Service 上。Ingress 可以根据域名或 URL 路径将流量转发到不同的 Service 上,并支持 SSL/TLS 终止和负载均衡等功能。

  6. ConfigMap:ConfigMap 是一种 k8s 资源类型,用于将配置信息注入到无状态服务中。ConfigMap 可以存储键值对和配置文件等信息,并将它们作为环境变量、命令行参数或配置文件挂载到 Pod 中。

Ingress 和 Service、ConfigMap 一样,都是 Kubernetes 中的资源对象,它们都是抽象的概念,不包含任何具体的状态信息。Ingress 只是定义了一组规则,而 Service 则定义了如何暴露一个或多个 Pod,以便可以从集群内部或外部访问它们。因此,Ingress 和 Service 都可以看作是无状态的 Kubernetes 资源对象。

总之,使用Kubernetes中的无状态服务资源类型,可以更轻松地管理和扩展无状态服务,并提高其可用性和可靠性。

1.4 总结

无状态服务并不适用于所有的应用程序。一些应用程序可能需要维护会话信息、状态信息或持久化数据,这就需要使用有状态服务

因此,在设计应用程序时,需要考虑应用程序的特定要求,以确定应该使用无状态服务还是有状态服务。 

2 使用介绍

2.1 Deployment

Deployment资源控制器将用户定义的Deployment对象转换为实际运行的Pods,并确保Pods的状态与用户定义的状态一致。如果某个Pod因为某些原因被删除了,Deployment控制器会启动一个新的Pod,以确保在任何时候都有指定数量的Pods在运行。

Deployment 是 Kubernetes 中一种常用的资源类型,用于定义一组可扩展的 Pod,并确保它们按照所需的副本数在集群中运行。

Deployment 可以:

  • 确保应用程序在集群中始终以所需的副本数运行。
  • 自动升级应用程序,以便部署新的版本。
  • 自动回滚到以前的版本,以便应对故障情况。
  • 通过滚动升级、重启或暂停来更新部署。

下面是一个使用 Deployment 创建一个可扩展的 nginx 服务的示例:

apiVersion: apps/v1
kind: Deployment #资源类型
metadata:
  name: nginx-deployment
spec:
  replicas: 3
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:latest
        ports:
        - containerPort: 80

该示例使用了 Deployment 资源来创建一个名为 nginx-deployment 的部署。该部署将创建 3 个副本,并使用 label 选择器来识别与该部署关联的 Pod。

该示例的 Pod 使用了 nginx:latest 镜像,并且暴露了容器端口 80。

要部署该示例,将 YAML 文件保存为 nginx-deployment.yaml 并运行以下命令:

kubectl apply -f nginx-deployment.yaml

该命令将在集群中创建一个名为 nginx-deployment 的 Deployment,并自动创建与其相关的 3 个 Pod。

要更新部署的镜像,可以通过编辑 YAML 文件并运行以下命令来轻松更新:

kubectl apply -f nginx-deployment.yaml

Kubernetes 将自动将更新部署,并逐步将所有 Pod 升级到新版本。

总结一下,Deployment 资源是 Kubernetes 中一个非常有用的资源类型,它使得容器化应用程序的部署和管理变得更加容易和可靠。

使用场景:

  1. 应用程序部署:使用 Kubernetes Deployment 可以轻松地部署您的应用程序,并确保它们始终以所需的方式运行。您可以定义应用程序的副本数、容器映像、存储和网络设置等。

  2. 应用程序升级和回滚:使用 Kubernetes Deployment 可以轻松地升级和回滚您的应用程序。您可以定义应用程序的新版本,并控制升级的速率和流程。如果需要回滚,则可以通过简单的命令将应用程序回退到旧版本。

  3. 水平扩展:使用 Kubernetes Deployment 可以根据负载自动扩展应用程序。您可以定义水平扩展规则,并让 Kubernetes 自动扩展您的应用程序。

  4. 服务发现和负载均衡:使用 Kubernetes Deployment 可以轻松地为您的应用程序定义服务发现和负载均衡规则。Kubernetes 可以自动将流量路由到正确的副本集,并确保它们始终处于健康状态。

  5. 多环境部署:使用 Kubernetes Deployment 可以轻松地在不同的环境(如开发、测试和生产)之间部署应用程序。您可以使用不同的配置文件和策略来定义不同的部署规则,从而确保您的应用程序在不同的环境中始终以所需的方式运行。

2.2 ReplicaSet

Kubernetes的ReplicaSet(副本集)是一种控制器(Controller),用于确保Pod的副本数始终保持在指定的数量。如果发现副本数低于预期,则ReplicaSet将自动创建新的Pod。相反,如果副本数多于预期,则会删除多余的Pod。

以下是一个ReplicaSet的示例定义:

文件名:example-rs.yaml

apiVersion: apps/v1
kind: ReplicaSet #资源类型
metadata:
  name: example-rs
spec:
  replicas: 3
  selector:
    matchLabels:
      app: example
  template:
    metadata:
      labels:
        app: example
    spec:
      containers:
      - name: example
        image: nginx:latest

逐行解释这个示例:

  • apiVersion: apps/v1:表示使用API版本v1的apps组。
  • kind: ReplicaSet:表示我们定义的是ReplicaSet对象。
  • metadata:包含ReplicaSet的元数据,如名称、标签和注释。
  • name: example-rs:指定ReplicaSet的名称。
  • spec:定义了ReplicaSet的规范,包括副本数、选择器和Pod模板。
  • replicas: 3:指定我们要运行的Pod副本数为3个。
  • selector:指定要选择的Pod标签。
  • matchLabels:指定匹配的标签,与模板中的标签相同。
  • template:定义了要创建的Pod模板。
  • metadata:定义了Pod元数据,如标签。
  • labels:指定Pod标签,与选择器中的标签相同。
  • spec:指定了Pod的规范,如容器和容器映像。
  • containers:定义了Pod中的容器。
  • name: example:定义了容器的名称。
  • image: nginx:latest:定义了容器映像。

创建这个ReplicaSet:

kubectl apply -f example-rs.yaml

这将创建一个名为example-rs的ReplicaSet,并确保有3个标记为app=example的Pod在运行。如果Pod数目低于3个,则ReplicaSet将自动创建新的Pod。

如果要更新ReplicaSet,可以更新Pod模板的定义,并使用以下命令执行滚动更新:

kubectl apply -f example-rs.yaml

这将创建新的Pod,以替换旧的Pod,直到达到指定的副本数。这个过程被称为滚动更新。

要删除ReplicaSet及其所有Pod,可以使用以下命令:

kubectl delete rs example-rs

这个命令,删除名为example-rs的ReplicaSet及其所有Pod。

使用场景

ReplicaSet的主要使用场景包括:

  1. 扩展应用程序:通过创建多个Pod副本并在它们之间负载均衡,可以轻松地扩展应用程序的能力。

  2. 确保高可用性:当一个Pod副本出现故障时,ReplicaSet会自动创建一个新的Pod副本来替代它,从而确保应用程序的高可用性。

  3. 管理滚动升级:通过在ReplicaSet中定义新版本的Pod模板,可以实现滚动升级应用程序,从而最小化应用程序的停机时间。

  4. 确保资源利用率:通过控制Pod副本的数量,可以确保在负载轻的情况下不会浪费资源,同时在负载高峰期间有足够的资源可供使用。

2.3 pod

在 K8s 中,有两种主要类型的 Pod 资源:

  1. Pod 资源定义:这是用于定义 Pod 规格的 YAML 或 JSON 文件。它描述了 Pod 的容器及其相关配置、网络、存储等信息。

  2. Pod 运行时实例:这是由 Pod 资源定义创建的实际运行时实例。在运行时,K8s 负责管理 Pod 实例的生命周期、容器的运行状态以及网络和存储资源的分配。

Pod 资源定义示例

下面是一个 Pod 资源定义的示例:

apiVersion: v1
kind: Pod #资源类型
metadata:
  name: my-pod
spec:
  containers:
    - name: my-container
      image: nginx
      ports:
        - containerPort: 80

2.4 service

Kubernetes (K8s) Service是一种用于提供网络访问的抽象机制,用于将一组Pods公开为单个网络服务。服务提供了一个虚拟IP地址和一个DNS名称,允许客户端通过这些标识符访问Kubernetes集群中的应用程序。服务还允许负载平衡和自动容错,以确保即使在一个或多个Pod失败时,服务仍然可用。

在Kubernetes中,Service对象是一个Kubernetes API对象,可以使用Kubernetes API或kubectl命令行工具创建、管理和删除它们。

创建一个Service对象时,需要指定一个标签选择器,用于确定要将哪些Pods作为后端。Service还可以使用不同的负载平衡算法(如轮询或IP哈希)将请求路由到后端Pods。

下面是一个简单的Kubernetes Service示例:

创建一个Deployment:

apiVersion: apps/v1
kind: Deployment #资源类型
metadata:
  name: nginx-deployment
spec:
  selector:
    matchLabels:
      app: nginx
  replicas: 3
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:latest
        ports:
        - containerPort: 80

创建一个Service:

apiVersion: v1
kind: Service #资源类型
metadata:
  name: nginx-service
spec:
  selector:
    app: nginx
  type: ClusterIP
  ports:
  - name: http
    port: 80
    targetPort: 80

这个示例创建了一个名为nginx-deployment的Deployment,它运行3个Nginx Pod。

接下来,它创建了一个名为nginx-service的Service,使用selector指定将后端Pods选择器设置为app: nginx

该Service使用默认的ClusterIP类型,并将所有传入流量路由到80端口。

在这个示例中,targetPort被设置为80,因为后端Pods也在80端口上监听。

总结:

此时,可以通过Kubernetes集群内部的虚拟IP地址和DNS名称访问Nginx服务。

例如,在Kubernetes集群中的Pod中,可以使用nginx-service名称来访问该服务。

注意:上述示例仅供参考,具体实现可能因Kubernetes版本和配置而异。请参阅Kubernetes文档以获取更多详细信息和最佳实践建议。 

2.5 ingress

Kubernetes Ingress是一个API对象,它允许管理在集群内的HTTP和HTTPS路由。Ingress充当负载均衡器,将流量路由到集群内的服务。它还可以提供TLS终止和基于名称的虚拟主机。

在Kubernetes中,Ingress控制器是一个运行Ingress规则的实体。许多不同的Ingress控制器可用,如Nginx,Traefik,Istio等,它们具有不同的功能和优缺点。

以下是使用Kubernetes Ingress的示例:

安装Ingress控制器

不同的Ingress控制器安装方式可能不同,这里以Nginx为例:

kubectl apply -f https://raw.githubusercontent.com/kubernetes/ingress-nginx/master/deploy/static/provider/cloud/deploy.yaml

创建Ingress规则

创建一个Ingress对象以定义路由规则。以下示例将指定所有来自/example路径的HTTP请求将被路由到名为example-service的服务上:

apiVersion: networking.k8s.io/v1
kind: Ingress #资源类型
metadata:
  name: example-ingress
  annotations:
    nginx.ingress.kubernetes.io/rewrite-target: /
spec:
  rules:
  - http:
      paths:
      - path: /example
        pathType: Prefix
        backend:
          service:
            name: example-service
            port:
              number: 80

 应用Ingress规则

使用以下命令将Ingress规则应用于Kubernetes集群:

kubectl apply -f example-ingress.yaml

访问服务

可以使用Ingress规则定义的路由访问服务。

http://ip地址/example

总结:

使用Kubernetes Ingress可以轻松地为集群内的服务设置路由规则,并将流量分发到相应的服务上。

同时,Ingress控制器的选择对性能和功能等方面也有一定影响,需要根据具体情况选择合适的控制器。 

2.6 configMap

Kubernetes (k8s) 的 ConfigMap 是一种用于存储非敏感配置数据的 Kubernetes 对象。ConfigMap 可以包含键值对、文件或者纯文本数据,并可以在容器中通过环境变量、命令行参数或者挂载路径的方式使用。

以下是一个 k8s ConfigMap 的示例 YAML 文件:

apiVersion: v1
kind: ConfigMap #资源类型
metadata:
  name: my-configmap
data:
  CONFIG_VAR1: value1
  CONFIG_VAR2: value2
  CONFIG_FILE: |-
    This is the content of a file in the ConfigMap.
    It can be accessed in a container as a volume.

上面的示例定义了一个名为 my-configmap 的 ConfigMap 对象,其中包含三个键值对:CONFIG_VAR1CONFIG_VAR2CONFIG_FILECONFIG_FILE 中包含了一些纯文本数据,可以在容器中以挂载的方式访问。

下面是一个使用 ConfigMap 的示例 YAML 文件:

apiVersion: v1
kind: Pod #资源类型为pod
metadata:
  name: my-pod
spec:
  containers:
  - name: my-container
    image: nginx
    env:
    - name: VAR1
      valueFrom:
        configMapKeyRef:
          name: my-configmap
          key: CONFIG_VAR1
    - name: VAR2
      valueFrom:
        configMapKeyRef:
          name: my-configmap
          key: CONFIG_VAR2
    volumeMounts:
    - name: config-volume
      mountPath: /etc/config
      readOnly: true
  volumes:
  - name: config-volume
    configMap:
      name: my-configmap

上面的示例定义了一个名为 my-pod 的 Pod 对象,其中包含一个名为 my-container 的容器。

该容器使用了 my-configmap 中的 CONFIG_VAR1CONFIG_VAR2 值,并将 my-configmap 中的 CONFIG_FILE 文件挂载到容器的 /etc/config 目录下。

总的来说,ConfigMap 是一种非常有用的 Kubernetes 对象,可以用于存储配置数据,并将其传递到容器中,以便在运行时使用

3 总结

使用场景总结

以下是一些适合使用无状态服务的业务场景:

  1. Web 应用程序:Web 应用程序通常是无状态的,它们的行为仅取决于用户的请求和输入。无状态服务可以帮助您轻松地扩展 Web 应用程序并提高其可靠性。

  2. 批处理作业:批处理作业通常是独立的任务,它们的执行不需要存储状态信息。无状态服务可以帮助您快速地运行大规模的批处理作业。

  3. 计算密集型应用程序:计算密集型应用程序通常需要大量的计算资源来处理数据。无状态服务可以帮助您快速地扩展应用程序以处理更多的计算任务。

  4. 微服务架构:在微服务架构中,服务通常被设计为无状态的。这是因为无状态服务可以更容易地扩展,并且更容易实现高可用性和负载均衡。

  5. 媒体流服务:媒体流服务通常是无状态的,因为它们不需要存储状态信息。无状态服务可以帮助您快速地扩展媒体流服务以处理更多的请求。

 ReplicaSet 和 Deployment区别总结:

Kubernetes (k8s) ReplicaSet 和 Deployment 是两个常用的 Kubernetes 资源对象,它们都用于管理 Pod 的创建、扩展、缩减和更新。

Deployment 和 ReplicaSet 的使用场景:

  • Deployment:Deployment 资源对象用于管理应用的版本更新。当您需要发布新版本的应用程序时,可以使用 Deployment 对象来创建一个新的 ReplicaSet,然后 Kubernetes 会逐步将 Pod 的数量从旧版本的 ReplicaSet 逐渐缩减到新版本的 ReplicaSet。如果发生故障,Deployment 会自动回滚至上一个可用版本。
  • ReplicaSet:ReplicaSet 资源对象用于管理 Pod 的数量。如果您需要扩展或缩减 Pod 的数量,可以使用 ReplicaSet 对象来定义所需的副本数,并让 Kubernetes 自动创建或删除 Pod,以达到您定义的副本数。

Deployment 和 ReplicaSet 的区别:

  • Deployment 是 ReplicaSet 的上层控制器,它在 ReplicaSet 的基础上增加了更多的更新、回滚和版本管理的功能,因此 Deployment 更适合用于应用程序版本的管理。
  • ReplicaSet 负责确保 Pod 的数量达到指定的副本数,但是它不会关心 Pod 的版本号。因此 ReplicaSet 更适合用于控制相同版本的 Pod 的数量,以确保可用性和容错性。

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

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

相关文章

前置知识——Linux网络虚拟化

Linux网络虚拟化 信息是如何通过网络传输被另一个程序接收到的? 我们讨论的虚拟化网络是狭义的,它指容器间网络。 好了,下面我们就从 Linux 下网络通信的协议栈模型,以及程序如何干涉在协议栈中流动的信息来开始了解吧。 Linux…

基于飞桨实现的特定领域知识图谱融合方案:ERNIE-Gram文本匹配算法

文本匹配任务在自然语言处理领域中是非常重要的基础任务,一般用于研究两段文本之间的关系。文本匹配任务存在很多应用场景,如信息检索、问答系统、智能对话、文本鉴别、智能推荐、文本数据去重、文本相似度计算、自然语言推理、问答系统、信息检索等&…

【MySQL】了解MySQL的Explain,读这一篇够了( ̄∇ ̄)/

目录 ID select_type 查询类型 table 表名 type 关联类型/访问类型 possible_keys MySQL觉得可能要用到的索引 key 实际用到的索引 key_len 用到的索引的长度(比如可用于判断使用了联合索引中的哪几个) ref 表查找值所用的列(表名.字…

Transformer在计算机视觉中的应用-VIT、TNT模型

上期介绍了Transformer的结构、特点和作用等方面的知识,回头看下来这一模型并不难,依旧是传统机器翻译模型中常见的seq2seq网络,里面加入了注意力机制,QKV矩阵的运算使得计算并行。 当然,最大的重点不是矩阵运算&…

行人车辆检测与计数系统(Python+YOLOv5深度学习模型+清新界面)

摘要:行人车辆检测与计数系统用于交通路口行人及车辆检测计数,道路人流量、车流量智能监测,方便记录、显示、查看和保存检测结果。本文详细介绍行人车辆检测,在介绍算法原理的同时,给出Python的实现代码、PyQt的UI界面…

【并发编程Python】一文详解Python并发编程,协程、线程、进程

并发编程简介和一些前缀知识 并发编程是使得程序大幅度提速的。在并发编程中,程序可以同一时间执行多个任务,这有助于提高程序的吞吐量和响应时间。并发编程设计的主要概念包括线程、锁、同步、信号量、进程间通信等。 前缀知识: IO&#x…

Linux中shell内外命令讲解(上)

♥️作者:小刘在C站 ♥️个人主页:小刘主页 ♥️每天分享云计算网络运维课堂笔记,努力不一定有收获,但一定会有收获加油!一起努力,共赴美好人生! ♥️夕阳下,是最美的绽放,树高千尺,落叶归根人生不易,人间真情 前言 本章Linuxshell讲解,感谢观看,干货满满。 目录…

在windows内使用virtualbox搭建安卓x86,以及所遇到的问题解决--2.virtualbox上安卓x86的配置

目录: 简要说明: 1.配置vesa驱动: 2.启用网络连接并配置adb: 3.增强性能的方法: 简要说明: 先进行说明一点个人直接通过vbox VMware这些软件,并不能超越专业的安卓模拟器,大部分模拟器实际…

使用Pytorch实现对比学习SimCLR 进行自监督预训练

SimCLR(Simple Framework for Contrastive Learning of Representations)是一种学习图像表示的自监督技术。 与传统的监督学习方法不同,SimCLR 不依赖标记数据来学习有用的表示。 它利用对比学习框架来学习一组有用的特征,这些特征…

【创作赢红包】Java Web 实战 18 - 计算机网络之网络层协议 and 数据链路层协议

文章目录网络层协议1. IP 协议1.1 报头结构1.2 IP 协议的地址管理动态分配 IP 地址 (DHCP)IP 地址转换 (NAT)IPv61.3 IP 地址的组成2. 路由选择数据链路层1. 以太网协议2. 以太网帧格式2.1 mac 地址2.2 两个特殊的以太网数据帧DNS 域名解析系统六 . 经典面试题 : 从浏览器中输入…

微信小程序 | 基于ChatGPT实现模拟面试小程序

Pre:效果预览 ① 选择职位进行面试 ② 根据岗位职责进行回答 一、需求背景 这两年IT互联网行业进入寒冬期,降本增效、互联网毕业、暂停校招岗位的招聘,各类裁员、缩招的情况层出不穷!对于这个市场来说,在经历了互联网…

小白学Pytorch系列--Torch API (7)

小白学Pytorch系列–Torch API (7) Comparison Ops allclose 此函数检查输入和其他是否满足条件: >>> torch.allclose(torch.tensor([10000., 1e-07]), torch.tensor([10000.1, 1e-08])) False >>> torch.allclose(torch.tensor([10000., 1e-…

MATLAB | 如何自然好看的从图片中提取颜色并制作色卡

在这里研究了一下各种排序算法,写一篇如何由图片一键生成颜色条的方法。 1 关于大量颜色排序 假设有大量颜色怎么对其进行排序呢,首先想到的最简单方法就是将其按照RGB值的大小进行排序,为了方便展示颜色条,这里编写了一个颜色条…

【Pytorch】 理解张量Tensor

本文参加新星计划人工智能(Pytorch)赛道:https://bbs.csdn.net/topics/613989052 这是目录张量Tensor是什么?张量的创建为什么要用张量Tensor呢?总结张量Tensor是什么? 在深度学习中,我们经常会遇到一个概念&#xff…

初探Redis整体架构

文章目录1、Redis为什么选择单线程2、逐步加入多线程3、Redis采用IO多路复用---epoll和Reactor架构4、Redis6/7默认是否开启了多线程?1、Redis为什么选择单线程 这种问法其实并不严谨,为啥这么说呢? Redis几个里程碑式的重要版本 理清一个事实&#…

一文带你安装opencv和常用库(保姆级教程少走80%的弯路)

0.导语 离上一个opencv安装保姆级教程发布已经过去了快一年了,这一年来我收到了来自很多C友的鼓励。打算学opencv的各位朋友都会在安装opencv和各种库过程中浪费掉60%的时间和精力;博主在这一年来尝试各种各样的安装方法,全网搜集各种资料总…

[ 云计算 | Azure ] Chapter 05 | 核心体系结构之管理组、订阅、资源和资源组以及层次关系

本文主要对如下内容进行讲解:Azure云计算的核心体系结构组件中的:资源、订阅和资源组,以及了解 Azure 资源管理器 (ARM) 如何部署资源。 本系列已经更新文章列表: [ 云计算 | Azure ] Chapter 03 | 描述云计算运营中的 CapEx 与…

元宇宙与网络安全

元宇宙是一种虚拟现实空间,用户可以在计算机生成的环境中进行互动。元宇宙的应用范围很广,比如房地产,医疗,教育,军事,游戏等等。它提供了更具沉浸感的体验,更好地现实生活整合,以及…

图像分类算法:ResNet论文解读

图像分类算法:ResNet论文解读 前言 ​ 其实网上已经有很多很好的解读各种论文的文章了,但是我决定自己也写一写,当然,我的主要目的就是帮助自己梳理、深入理解论文,因为写文章,你必须把你所写的东西表达清楚…

游戏工厂:AI(AIGC/ChatGPT)与流程式游戏开发(码客 卢益贵)

关键词:AI(AIGC、ChatGPT、文心一言)、流程式管理、好莱坞电影流程、电影工厂、游戏工厂、游戏开发流程、游戏架构、模块化开发 一、前言 开发周期长、人工成本高、成功率低等使得游戏公司融资比较困难。有的公司凭一个爆款游戏一骑绝尘之后…