k8s day04

昨日内容回顾:
    - configMap ---> cm
        应用场景: 主要用于配置文件的持久化。
    - secret
        应用场景: 存储敏感数据,并非加密数据。
    - pod探针(probe):
        - livenessProbe:
            健康检查探针,若检查失败,则会重启容器(重新创建容器)。
            值得注意的是,若手动去使用docker去kill容器,是否会重启取决于重启策略,注意,尽管重新拉起容器会计数重启次数。
            
        - readinessProbe
            可用性检查探针,若检查失败,则将容器标记为未就绪状态,与此同时,对于svc的ep资源列表不会自动发现;
    - env获取cm或者secret资源的值

Q1: 请问Pod导入secret资源有几种方式?
    - env 
    - volume
    
Q2: 请问cm资源有几种定义方式?
    - 单行模式,
        KEY: VALUE
    - 多行模式,类文件模式
        KEY : |
            ...
            ...
            ...

Q3: 外网访问K8S集群的Pod有多少种方式?
    - hostNetwork
    - hostPort ---> 1.5.2有效!  1.15.12则无效!【了解即可】
    - Svc
    - Ing
    - ApiServer
    
Q4: 影响Pod调度的方式有哪些?
    - nodeName
    - resources
    - 污点
    - 污点容忍
    - 亲和性
    - 反亲和性
    - 自定义调度器
    - 工作负载调度器 ---> ds,deploy
    ...


kubectl version :
    查看K8S的版本号。
        GitVersion:"v1.5.2", 
        BuildDate:"2017-07-03T15:31:10Z"
         
        GitVersion:"v1.15.12",
        BuildDate:"2020-05-06T05:09:48Z"
        
        
[root@k8s151.oldboyedu.com po]# cat 22-pods-ports.yaml 
kind: Pod
apiVersion: v1
metadata:
  name: oldboyedu-linux82-ports-001
spec:
  nodeName: k8s152.oldboyedu.com
  containers:
  - name: linux82-web
    image: k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.20.1
    # 定义容器的端口映射相关信息
    ports:
      # 容器内服务监听的端口
    - containerPort: 80
      # 指定绑定的宿主机IP地址
      hostIP: 0.0.0.0
      # 指定宿主机的端口
      hostPort: 18888
      # 给映射的端口起名字,要求唯一
      name: myweb
      # 指定协议,有效值为: UDP, TCP, or SCTP.
      protocol: TCP
[root@k8s151.oldboyedu.com po]# 


容器的三种类型:
    网络基础镜像容器:
        pause:v3.1
            ---> 提供网络基础的。
    
    初始化容器:
        initContainers
            ---> 为业务容器提供基础环境准备的。
            
    业务容器:
        containers
            ---> 跑实际业务。

            
初始化容器参考案例:
[root@k8s151.oldboyedu.com po]# cat 23-pods-initContainers.yaml 
--- 

apiVersion: v1
data:
  .dockerconfigjson: eyJhdXRocyI6eyIxMC4wLjAuMjUwIjp7InVzZXJuYW1lIjoiamFzb255aW4yMDIwIiwicGFzc3dvcmQiOiJPbGRib3llZHVAMjAyMiIsImVtYWlsIjoiamFzb255aW5Ab2xkYm95ZWR1LmNvbSIsImF1dGgiOiJhbUZ6YjI1NWFXNHlNREl3T2s5c1pHSnZlV1ZrZFVBeU1ESXkifX19
kind: Secret
metadata:
  name: oldboyedu-harbor
type: kubernetes.io/dockerconfigjson


---

kind: Pod
apiVersion: v1
metadata:
  name: oldboyedu-linux82-initcontianer-002
spec:
  nodeName: k8s152.oldboyedu.com
  imagePullSecrets:
  - name: oldboyedu-harbor
  # 初始化容器,为业务容器提供基础环境准备的。
  initContainers:
  - name: init-web
    image: 10.0.0.250/oldboyedu-linux/stress:v0.1
    command:
    - sleep
    - "30"
  # 我们可以将containers理解为业务容器。初始化容器要先于业务容器运行。
  containers:
  - name: linux82-web
    image: k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.20.1
    # 定义容器的端口映射相关信息
    ports:
      # 容器内服务监听的端口
    - containerPort: 80
      # 指定绑定的宿主机IP地址
      hostIP: 0.0.0.0
      # 指定宿主机的端口,k8s1.5.2会监听端口,K8S1.15.12不会监听端口但能访问哟!
      hostPort: 28888
      # 给映射的端口起名字,要求唯一
      name: myweb
      # 指定协议,有效值为: UDP, TCP, or SCTP.
      protocol: TCP
[root@k8s151.oldboyedu.com po]# 


静态Pod:
vim  /var/lib/kubelet/config.yaml 
...
staticPodPath: /etc/kubernetes/manifests

温馨提示:
    (1)静态Pod是由kubelet启动时通过"staticPodPath"配置参数指定路径
    (2)静态Pod创建的Pod名称会自动加上kubelet节点的主机名,比如"-k8s151.oldboyedu.com",会忽略"nodeName"字段哟;
    (3)静态Pod的创建并不依赖API-Server,而是直接基于kubelet所在节点来启动Pod;
    (4)静态Pod的删除只需要将其从staticPodPath指定的路径移除即可;
    (5)静态Pod路径仅对Pod资源类型有效,其他类型资源将不被创建哟
    (6)咱们的kubeadm部署方式就是基于静态Pod部署的哟;

rc简介:
replicationcontrollers控制器简称"rc",可以保证指定数量的Pod始终存活,rc通过标签选择器来关联Pod。
    
    
[root@k8s151.oldboyedu.com rc]# cat 01-rc-nginx.yaml 
kind: ReplicationController
apiVersion: v1
metadata:
  name: oldboyedu-linux82-rc-web
spec:
  # 指定Pod的副本数量,若不指定,则默认值为1.
  replicas: 3
  # 定义标签选择器,即用于关联Pod的标签。
  selector:
     school: oldboyedu
  # 定义Pod的模板
  template:
     metadata:
        name: linux82-web
        labels:
           school: oldboyedu
           class: linux82
     spec:
        # nodeName: k8s152.oldboyedu.com
        containers:
        - name: linux82-web
          image: k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.20.1
[root@k8s151.oldboyedu.com rc]# 


创建RS资源用于测试svc:
[root@k8s151.oldboyedu.com rs]# cat 01-rs-nginx.yaml 
kind: ReplicaSet
apiVersion: extensions/v1beta1
metadata:
  name: oldboyedu-linux82-rs-web
spec:
  # 指定Pod的副本数量,若不指定,则默认值为1.
  replicas: 3
  # 定义标签选择器,即用于关联Pod的标签。
  selector:
     # 相比于rc资源,rs资源支持的功能更加强大,不仅仅支持标签选择器,还支持表达式(matchExpressions)
     matchLabels:
        school: oldboyedu
  # 定义Pod的模板
  template:
     metadata:
        name: linux82-web
        labels:
           school: oldboyedu
           class: linux82
     spec:
        # nodeName: k8s152.oldboyedu.com
        containers:
        - name: linux82-web
          image: k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.20.1
          livenessProbe:
            tcpSocket:
               port: 80
            failureThreshold: 3
            initialDelaySeconds: 15
            periodSeconds: 1
            successThreshold: 1
            timeoutSeconds: 1
          readinessProbe:
            httpGet:
               port: 80
               path: /oldboyedu.html
            failureThreshold: 3
            initialDelaySeconds: 15
            periodSeconds: 1
            successThreshold: 1
            timeoutSeconds: 1
[root@k8s151.oldboyedu.com rs]# 


创建svc资源:
[root@k8s151.oldboyedu.com rs]# cat ../svc/01-svc-nginx.yaml 
apiVersion: v1
kind: Service
metadata:
  name: linux82-svc-web
spec:
  # 映射Pod端口信息
  ports:
    # 指定SVC的端口
  - port: 9999
    # 指定Pod提供服务的端口
    targetPort: 80
  # 指定标签,用于匹配关联的POD
  selector:
     class: linux82
[root@k8s151.oldboyedu.com rs]# 

查看所有的svc:
kubectl get svc


查看指定svc的详细信息:
kubectl describe svc linux82-svc-web


rc资源有两大缺陷:
    (1)不支持声明式更新镜像;
    (2)升级的时候有时候需要运维人员介入解决svc无法自动关联Pod的现象;
        为了避免这种现象发生,将rc资源的selector和svc的selector定义成不一样的关联即可。见视频。

基于rc升级和回滚:
1.创建原始版本
kubectl apply -f 01-rc-svc.yaml -f 02-rc-nginx-old.yaml 

2.测试访问服务
curl -I 10.0.0.53:30088


3.升级
kubectl rolling-update oldboyedu-linux82-rc-web-old -f 03-rc-nginx-update-new.yaml --update-period=1s
        oldboyedu-linux82-rc-web-old:
            表示现有的rc名称。
        -f 03-rc-nginx-update-new.yaml 
            基于哪个文件升级或回滚。
        --update-period=1s
            升级的间隔时间。

4.升级后运行需要解决用户无法访问Pod的情况
    方案一: 
        使用旧的svc,即给新的pod打标签。
kubectl label  pods --all class=linux82
# kubectl label  pods --all class-  # 删除标签

    方案二:
        使用新的svc。
kubectl delete -f 01-rc-svc.yaml 
kubectl apply -f 04-rc-svc-new.yaml 


5.回滚
kubectl rolling-update oldboyedu-linux82-rc-web-new -f 02-rc-nginx-old.yaml  --update-period=1s
kubectl delete -f 04-rc-svc-new.yaml
kubectl apply -f  01-rc-svc.yaml 

资源清单:
[root@k8s151.oldboyedu.com test]# cat 01-rc-svc.yaml 
apiVersion: v1
kind: Service
metadata:
  name: linux82-svc-web-nodeport-002
spec:
  type: NodePort
  ports:
  - port: 9999
    targetPort: 80
    nodePort: 30088
  selector:
     class: linux82
[root@k8s151.oldboyedu.com test]# 
[root@k8s151.oldboyedu.com test]# cat 02-rc-nginx-old.yaml 
kind: ReplicationController
apiVersion: v1
metadata:
  name: oldboyedu-linux82-rc-web-old
spec:
  # 指定Pod的副本数量,若不指定,则默认值为1.
  replicas: 3
  # 定义标签选择器,即用于关联Pod的标签。
  selector:
     school: oldboyedu
  # 定义Pod的模板
  template:
     metadata:
        name: linux82-web
        labels:
           school: oldboyedu
           class: linux82
     spec:
        # nodeName: k8s152.oldboyedu.com
        containers:
        - name: linux82-web
          image: k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.14
[root@k8s151.oldboyedu.com test]# 
[root@k8s151.oldboyedu.com test]# cat 03-rc-nginx-update-new.yaml 
kind: ReplicationController
apiVersion: v1
metadata:
  name: oldboyedu-linux82-rc-web-new
spec:
  replicas: 3
  selector:
     school: oldboyedu-new
  template:
     metadata:
        name: linux82-web
        labels:
           school: oldboyedu-new
           address: beijing-linux82
     spec:
        containers:
        - name: linux82-web
          image: k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.16
[root@k8s151.oldboyedu.com test]# 
[root@k8s151.oldboyedu.com test]# cat 04-rc-svc-new.yaml 
apiVersion: v1
kind: Service
metadata:
  name: linux82-svc-web-nodeport-002-new
spec:
  type: NodePort
  ports:
  - port: 9999
    targetPort: 80
    nodePort: 30088
  selector:
     school: oldboyedu-new
     address: beijing-linux82
[root@k8s151.oldboyedu.com test]# 

deoloyment资源控制器: ---> 声明式更新
[root@k8s151.oldboyedu.com deploy]# cat 01-deploy-nginx.yaml 
kind: Deployment
apiVersion: extensions/v1beta1
metadata:
  name: oldboyedu-linux82-deploy-nginx
spec:
  replicas: 3
  selector:
     matchLabels:
        school: oldboyedu
  template:
     metadata:
        name: linux82-web
        labels:
           school: oldboyedu
           class: linux82
     spec:
        containers:
        - name: linux82-web
          # image: k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.20.1
          image: k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.18
          livenessProbe:
            tcpSocket:
               port: 80
            failureThreshold: 3
            initialDelaySeconds: 15
            periodSeconds: 1
            successThreshold: 1
            timeoutSeconds: 1
          # readinessProbe:
          #   httpGet:
          #      port: 80
          #      path: /oldboyedu.html
          #   failureThreshold: 3
          #   initialDelaySeconds: 15
          #   periodSeconds: 1
          #   successThreshold: 1
          #   timeoutSeconds: 1

---

apiVersion: v1
kind: Service
metadata:
  name: linux82-svc-web-nodeport-002
spec:
  type: NodePort
  clusterIP: 10.254.100.100
  ports:
  - port: 9999
    targetPort: 80
    nodePort: 30088
  selector:
     class: linux82
[root@k8s151.oldboyedu.com deploy]# 

响应式更新:
kubectl set image deploy oldboyedu-linux82-deploy-nginx linux82-web=k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.16
kubectl set image  资源类型        资源类型名称              容器名称=镜像名称


基于edit编辑:
kubectl edit deployments. oldboyedu-linux82-deploy-nginx 


      副本数量        
old :  5
new :  5

    附加条件:
        old ---> new :
            - 5 + 2 ---> 7 升级过程中最大的pod
            - 5 - 1 ---> 4 最少保证4个可用。

升级需要几次?请说明原因:
    第一次升级:
        old : 3        5    4    5    2    ---> 4
        new : 2        2    2    2    3    ---> 3 
        
    第二次升级:
        old:     3    0    4    2    1    3    6    --->     1
        new:    4    7    2    5    6    4    4    --->    3 +  2 ---> 5
        
    ...


replicas: 8


maxSurge: 5
maxUnavailable: 3

---->

    第一次升级
        old :   5
        new :   8    
        
        

replicas: 7
maxSurge: 2  
    ---> max ---> 9
maxUnavailable: 3 
    ---> min ---> 4


    第一次升级:
        old:    4
        new:    5

    第二次升级:
        old:              0
        new:    5 + 2 --> 7

        
基于deployment升级:
[root@k8s151.oldboyedu.com deploy]# cat 02-deploy-nginx-update-strategy.yaml 
kind: Deployment
apiVersion: extensions/v1beta1
metadata:
  name: oldboyedu-linux82-deploy-nginx-strategy
spec:
  replicas: 5
  selector:
     matchLabels:
        school: oldboyedu
  # 定义升级策略
  strategy:
    # 升级的类型,"Recreate" or "RollingUpdate"
    # Recreate:
    #   先停止所有的Pod运行,然后在批量创建更新。
    #   生产环节中不推荐使用这种策略,因为升级过程中用户将无法访问服务!
    # RollingUpdate:
    #   滚动更新,即先实现部分更新,逐步替换原有的pod,是默认策略。
    type: RollingUpdate
    # 自定义滚动更新的策略
    rollingUpdate:
      # 在原有Pod的副本基础上,多启动Pod的数量。
      maxSurge: 2
      # 在升级过程中最大不可访问的Pod数量.
      maxUnavailable: 1
  template:
     metadata:
        name: linux82-web
        labels:
           school: oldboyedu
           class: linux82
     spec:
        containers:
        - name: linux82-web
          # image: k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.20.1
          #  image: k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.18
          image: nginx:1.14
          livenessProbe:
            tcpSocket:
               port: 80
            failureThreshold: 3
            initialDelaySeconds: 15
            periodSeconds: 1
            successThreshold: 1
            timeoutSeconds: 1
          # readinessProbe:
          #   httpGet:
          #      port: 80
          #      path: /oldboyedu.html
          #   failureThreshold: 3
          #   initialDelaySeconds: 15
          #   periodSeconds: 1
          #   successThreshold: 1
          #   timeoutSeconds: 1

---

apiVersion: v1
kind: Service
metadata:
  name: linux82-svc-web-nodeport-002
spec:
  type: NodePort
  clusterIP: 10.254.100.100
  ports:
  - port: 9999
    targetPort: 80
    nodePort: 30088
  selector:
     class: linux82
    
    
扩展作业:
    (1)使用阿里云部署K8S集群,并将11个游戏将部署到云平台提供访问,要求使用svc的类型为LoadBalancer。
    (2)使用kubeadm1.15或Kubeadm 1.19版本将其etcd数据库独立部署出来,不要使用内置的;
    (3)调研K3S二进制部署,K3S是轻量级的K8S发行版;
    (4)部署ranger管理K8S集群;


常见错误:
    PodFitsHostPorts:
        问题原因:
            和Pod调度节点的端口有所冲突。
        解决方案:
            可能无法提供给"ss -ntl"来观察,需要借助"iptables -t nat -vnL"来观察哟。
            
    Init:ErrImagePull
        问题原因:
            初始化容器拉取镜像失败。
        解决方案:
            一般情况下,请检查网络,权限等维度即可。
            

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

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

相关文章

大数据学习(12)-join优化common join

&&大数据学习&& 🔥系列专栏: 👑哲学语录: 承认自己的无知,乃是开启智慧的大门 💖如果觉得博主的文章还不错的话,请点赞👍收藏⭐️留言📝支持一下博>主哦&#x…

6.6 图的应用

思维导图: 6.6.1 最小生成树 ### 6.6 图的应用 #### 主旨:图的概念可应用于现实生活中的许多问题,如网络构建、路径查询、任务排序等。 --- #### 6.6.1 最小生成树 **概念**:要在n个城市中建立通信联络网,则最少需…

EmoTalk: Speech-Driven Emotional Disentanglement for 3D Face Animation

问题:现存的方法经常忽略面部的情感或者不能将它们从语音内容中分离出来。 方法:本文提出了一种端到端神经网络来分解语音中的不同情绪,从而生成丰富的 3D 面部表情。 1.我们引入了情感分离编码器(EDE),通过交叉重构具有不同情感标签的语音信号来分离语音中的情感和内容。…

Unity3D 基础——使用 Vector3.Lerp 实现缓动效果

让一个物体从当前位置移动到另一个位置 Vector3-Lerp - Unity 脚本 APIhttps://docs.unity.cn/cn/current/ScriptReference/Vector3.Lerp.html 1.在场景中新建两个 Cube 立方体,在 Scene 视图中将两个 Cude的位置错开。 2.新建 C# 脚本 MoveToTarget.cs&#xff08…

OpenResty安装

OpenResty 是一个基于 Nginx 的 Web 平台,它将 Nginx 和 Lua 脚本语言结合起来,提供了更强大的 Web 应用开发和部署能力。OpenResty 仓库是 OpenResty 项目的官方仓库,包含了 OpenResty 的源代码、文档、示例等资源。 OpenResty 仓库地址是&…

关于React

当今的Web开发世界中,React已经成为前端开发的主要工具之一。它的强大和灵活性使开发人员能够构建复杂的用户界面,同时保持代码的可维护性。本篇博客文章将深入探讨React,包括其核心概念、组件化开发、状态管理、性能优化和生态系统。 1. Re…

解决QT中文乱码

选中文本带有中文字符的文件,然后按如下点击 弹出对话框,选择当前操作系统的编码格式,选择Save with Encoding 中文字符前用u8进行标识

qml加载ttf字体库

1,下载获取ttf文件 iconfont-阿里巴巴矢量图标库 字体图标下载 - FontAwesome 字体图标中文Icon 2,添加到项目文件 3,项目添加字体库 #include <QGuiApplication> #include <QQmlApplicationEngine> #include <QFontDatabase> #include <QDebug>in…

排序【七大排序】

文章目录 1. 排序的概念及引用1.1 排序的概念1.2 常见的排序算法 2. 常见排序算法的实现2.1 插入排序2.1.1基本思想&#xff1a;2.1.2 直接插入排序2.1.3 希尔排序( 缩小增量排序 ) 2.2 选择排序2.2.1基本思想&#xff1a;2.2.2 直接选择排序:2.2.3 堆排序 2.3 交换排序2.3.1冒…

老卫带你学---leetcode刷题(46. 全排列)

46. 全排列 问题&#xff1a; 给定一个不含重复数字的数组 nums &#xff0c;返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。 示例 1&#xff1a;输入&#xff1a;nums [1,2,3] 输出&#xff1a;[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]示例 2&#x…

HTML标签详解 HTML5+CSS3+移动web 前端开发入门笔记(四)

HTML中列表的作用 HTML中的列表&#xff08;List&#xff09;用于呈现按照一定逻辑关系组织的信息&#xff0c;以便用户更好地理解和识别。列表可以分为有序列表、无序列表和定义列表三种类型。 有序列表&#xff08;Ordered List&#xff09;&#xff1a;用于表示按照一定顺序…

GB/T 41510-2022 起重机械安全评估规范 通用要求 摘要

在线预览|GB/T 41510-2022http://c.gb688.cn/bzgk/gb/showGb?typeonline&hcno696806EC48F4105CEF7479EB32C80C9E 知识点&#xff1a; 安全等级定义&#xff0c;设计寿命&#xff0c;剩余寿命&#xff0c;使用寿命。 标准附录有应力的具体解算演示。

vue前端实现打印功能并约束纸张大小---调用浏览器打印功能打印页面部分元素并固定纸张大小

需求是打印指定div实现小票打印功能。调用浏览器的自带打印功能只能实现打印可视区域&#xff0c;所以这里采用截图新窗口打开打印去实现此需求。 1.安装html2canvas库实现截图功能 npm install html2canvas --save2.在需要进行截图和打印的组件中&#xff0c;引入html2canvas…

VScode platformio的使用

一、platformio 工程创建 打开vscode界面你会发现左下多了个家的小图标&#xff0c;点击这里就可以进入platformio。 在右侧Quick Access栏中&#xff0c;有4个选项。可以看得出来&#xff0c;我们这里直接点击创建一个新的工程。 点击New Project打开project配置界面&#x…

LoongArch单机Ceph Bcache加速4K随机写性能测试

LoongArch单机Ceph Bcache加速4K随机写性能测试 两块HDD做OSD [rootceph01 ~]# fio -direct1 -iodepth128 -thread -rwrandwrite -ioenginelibaio -bs4k -size100G -numjobs1 -runtime600 -group_reporting -namemytest -filename/dev/rbd0 mytest: (g0): rwrandwrite, bs(R)…

C++对象模型(14)-- 构造函数语义学:拷贝构造函数和赋值运算赋

1、拷贝构造函数 1.1 什么是拷贝构造函数 拷贝构造函数是一种构造函数&#xff0c;它的功能是创建新对象。也就是说对象还没生成&#xff0c;这时利用另一个对象的拷贝来生成新的对象。 class MyDemo { public:// 默认构造函数MyDemo(){}// 拷贝构造函数MyDemo(const MyDemo…

【微信小程序】6天精准入门(第2天:小程序的视图层、逻辑层、事件系统及页面生命周期)

一、视图层 View 1、什么是视图层 框架的视图层由 WXML 与 WXSS 编写&#xff0c;由组件来进行展示。将逻辑层的数据反映成视图&#xff0c;同时将视图层的事件发送给逻辑层。WXML(WeiXin Markup language) 用于描述页面的结构。WXS(WeiXin Script) 是小程序的一套脚本语言&am…

实验四:回溯算法的设计与分析

某不知名学校大二算法课实验报告 题目来自力扣 第一题&#xff1a;幂集 力扣题目链接&#xff1a;幂集 题目描述&#xff1a; 幂集。编写一种方法&#xff0c;返回某集合的所有子集。集合中不包含重复的元素。 说明&#xff1a;解集不能包含重复的子集。 示例: 输入&#xf…

【C++ Primer Plus学习记录】指针——指针和字符串

数组和指针的特殊关系可以扩展到C-风格字符串。请看下面的代码&#xff1a; char flower[10] "rose"; cout << flower << "s are red\n"; 数组名是第一个元素的地址&#xff0c;因此cout语句中的flower是包含字符r的char元素的地址。cout对…

Leetcode刷题详解——长度最小的子数组

1. 题目链接&#xff1a;209. 长度最小的子数组 2. 题目描述&#xff1a; 给定一个含有 n 个正整数的数组和一个正整数 target 。 找出该数组中满足其总和大于等于 target 的长度最小的 连续子数组 [numsl, numsl1, ..., numsr-1, numsr] &#xff0c;并返回其长度**。**如果不…