欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~

本文由编程男孩 发表于云+社区专栏

介绍

Kubernetes(常简称为K8s)是用于自动部署、扩展和管理容器化(containerized)应用程序的开源系统。Google设计并捐赠给Linux基金会来使用的。它旨在提供“跨主机集群的自动部署、扩展以及运行应用程序容器的平台”。它支持一系列容器工具, 包括Docker等。

Kubeadm是 Kubernetes 官方推出的部署工具 ,例如API服务器,Controller Manager和Kube DNS,该工具实作类似Docker swarm 一样的部署方式,透过初始化Master 节点来提供给Node快速加入。但是,它的缺点也很明显,它不会创建用户或处理操作系统级依赖关系及其配置的安装。对于这些步骤,可以使用AnsibleSaltStack等配置管理工具。使用这些工具可以更轻松地更改其他集群或重新创建现有集群。

在本教程中,您将使用Ansible和Kubeadm从头开始设置Kubernetes集群,然后给它部署一个容器化的Nginx程序。

目标

您的群集将包含以下物理资源:

  • 一个主节点

主节点(Kubernetes中的节点指的是服务器)负责管理集群的状态。我们将用它运行Etcd,该服务器目的是将工作负载调度到工作节点的组件之间存储集群数据。

  • 两个工作节点

工作节点是运行工作负载(即容器化应用程序和服务)的服务器。一旦工作节点分配了工作负载,工作节点将继续运行您的工作负载,即使计划在调度完成后停止工作也是如此。通过添加工作节点可以增加群集的容量。

完成本教程后,您将拥有一个可以运行容器化应用程序的集群,前提是集群中的服务器具有足够的CPU和RAM资源供应用程序使用。几乎任何传统的Unix应用程序(包括Web应用程序,数据库,守护程序和命令行工具)都可以进行容器化,并在集群上运行。群集本身将在每个节点上消耗大约300-500MB的内存和10%的CPU。

设置群集后,您将部署Web服务器Nginx以确保它正确运行。

准备

  • 本地Linux / macOS /BSD计算机上的SSH密钥对。如果您之前没有使用过SSH密钥,同时使用的是腾讯云的服务器的话,请参考创建 SSH 密钥文档。如果您使用的不是腾讯云的服务器,请自行搜索,本文暂不涉及。本教程的本地计算机是Linux操作系统,请勿使用Windows进行试验。
  • 运行CentOS 7的三台服务器,内存至少为1GB。没有服务器的同学可以在这里购买,不过我个人更推荐您使用免费的腾讯云开发者实验室进行试验,学会安装后在购买服务器。您应该能够以SSH密钥对的root用户身份SSH到每个服务器。请务必将您的公钥添加到主节点上的centos用户帐户。如果您需要有关向特定用户帐户添加SSH密钥的指导,请参阅密钥绑定/解绑服务器文档。
  • Ansible需要安装在您的本地计算机上。有关安装说明,请按照Ansible官方安装文档。
  • 了解如何从Docker镜像启动容器。如果需要复习,请参阅如何安装使用Docker的“第5步 - 运行Docker容器” 。

第1步 - 设置工作区目录和Ansible配置

在本节中,您将在本地计算机上创建一个用作工作区的目录。您还将在本地配置Ansible,以便它可以与远程服务器上的命令进行通信。为此,您将创建一个hosts文件包,其包含例如服务器的IP地址和每个服务器所属的组等信息。

在三台服务器中,一台服务器将作为主服务器master_ip。另外两台服务器则是是工作节点,并拥有IPworker_1_ipworker_2_ip

在本地计算机的主目录中创建一个名为~/kube-cluster/hosts的目录并进入其中:

mkdir ~/kube-cluster
cd ~/kube-cluster

该目录将是本教程的工作区,包含所有Ansible设置。它也将是您运行所有本地命令的目录。

使用vi命令创建一个名为~/kube-cluster/hosts的文件或用您最喜欢的文本编辑器:

vi ~/kube-cluster/hosts

i将以下文本插入到文件中,该文件将指定有关群集逻辑结构的信息:

[masters]
master ansible_host=master_ip ansible_user=root[workers]
worker1 ansible_host=worker_1_ip ansible_user=root
worker2 ansible_host=worker_2_ip ansible_user=root

完成后,按,ESC然后输入:wq将更改写入文件并退出。

您可能还记得在Ansible中用于指定服务器信息的库存文件,例如IP地址,远程用户和服务器分组,以作为执行命令的单个单元进行目标。~/kube-cluster/hosts将是您的库存文件,并且您已向其添加了两个Ansible组(主服务器工作服务器),用于指定集群的逻辑结构。

服务器组中,有一个名为“master”的服务器,其中列出了主节点的IP(master_ip),并指定Ansible应以根用户身份运行远程命令。

同样,在workers组中,有两个工作服务器(worker_1_ipworker_2_ip),它们也需要指定ansible_user为root用户。

在设置服务器清单之后,让我们继续安装操作系统级依赖关系并创建配置设置。

第2步 - 安装Kubernetes的依赖项

在本节中,您将使用CentOS的yum软件包管理器安装Kubernetes所需的软件包。这些包是:

  • Docker - 容器运行时。这是运行容器的组件。Kubernetes正在积极开发对rkt等其他运行容器服务的支持。
  • kubeadm - CLI工具,以标准方式安装和配置群集的各个组件。
  • kubelet - 在所有节点上运行并处理节点级操作的系统服务/程序。
  • kubectl- 通过其API服务器向集群发出命令的CLI工具。

创建工作空间中指定的文件vi ~/kube-cluster/kube-dependencies.yml

vi ~/kube-cluster/kube-dependencies.yml

将下面的内容插到文件内:

- hosts: allbecome: yestasks:- name: install Dockeryum:name: dockerstate: presentupdate_cache: true- name: start Dockerservice:name: dockerstate: started- name: disable SELinuxcommand: setenforce 0- name: disable SELinux on rebootselinux:state: disabled- name: ensure net.bridge.bridge-nf-call-ip6tables is set to 1sysctl:name: net.bridge.bridge-nf-call-ip6tablesvalue: 1state: present- name: ensure net.bridge.bridge-nf-call-iptables is set to 1sysctl:name: net.bridge.bridge-nf-call-iptablesvalue: 1state: present- name: add Kubernetes' YUM repositoryyum_repository:name: Kubernetesdescription: Kubernetes YUM repositorybaseurl: https://packages.cloud.google.com/yum/repos/kubernetes-el7-x86_64gpgkey: https://packages.cloud.google.com/yum/doc/yum-key.gpg https://packages.cloud.google.com/yum/doc/rpm-package-key.gpggpgcheck: yes- name: install kubeletyum:name: kubeletstate: presentupdate_cache: true- name: install kubeadmyum:name: kubeadmstate: present- name: start kubeletservice:name: kubeletenabled: yesstate: started- hosts: masterbecome: yestasks:- name: install kubectlyum:name: kubectlstate: present

文件中的的第一部分内容如下:

  • 容器运行时,安装Docker。
  • 启动Docker服务。
  • 请禁用SELinux,因为Kubernetes尚未完全支持它。
  • 设置网络所需的一些与netfilter相关的sysctl值。这将允许Kubernetes设置iptables规则,以便在节点上接收桥接的IPv4和IPv6网络流量。
  • 将Kubernetes YUM存储库添加到远程服务器的存储库列表中。
  • 安装kubeletkubeadm

第二部分意思是在主节点上设置一下kubectl的任务。

完成后保存并关闭文件。

接下来,执行playbook

ansible-playbook -i hosts ~/kube-cluster/kube-dependencies.yml

完成后,您将看到类似于以下内容的输出:

PLAY [all] ****TASK [Gathering Facts] ****
ok: [worker1]
ok: [worker2]
ok: [master]TASK [install Docker] ****
changed: [master]
changed: [worker1]
changed: [worker2]TASK [disable SELinux] ****
changed: [master]
changed: [worker1]
changed: [worker2]TASK [disable SELinux on reboot] ****
changed: [master]
changed: [worker1]
changed: [worker2]TASK [ensure net.bridge.bridge-nf-call-ip6tables is set to 1] ****
changed: [master]
changed: [worker1]
changed: [worker2]TASK [ensure net.bridge.bridge-nf-call-iptables is set to 1] ****
changed: [master]
changed: [worker1]
changed: [worker2]TASK [start Docker] ****
changed: [master]
changed: [worker1]
changed: [worker2]TASK [add Kubernetes' YUM repository] *****
changed: [master]
changed: [worker1]
changed: [worker2]TASK [install kubelet] *****
changed: [master]
changed: [worker1]
changed: [worker2]TASK [install kubeadm] *****
changed: [master]
changed: [worker1]
changed: [worker2]TASK [start kubelet] ****
changed: [master]
changed: [worker1]
changed: [worker2]PLAY [master] *****TASK [Gathering Facts] *****
ok: [master]TASK [install kubectl] ******
ok: [master]PLAY RECAP ****
master                     : ok=9    changed=5    unreachable=0    failed=0
worker1                    : ok=7    changed=5    unreachable=0    failed=0
worker2                    : ok=7    changed=5    unreachable=0    failed=0  

执行后,Docker,kubeadmkubelet将安装在所有远程服务。kubectl不是必需组件,仅用于执行集群命令。但是我们建议您还是安装它,因为您将仅从主节点运行kubectl命令。

现在安装了所有系统依赖项。让我们设置主节点并初始化集群。

第3步 - 设置主节点

在本节中,您将设置主节点。然而在创建配置之前,我们需要熟悉几个概念,如PodsPod 网络插件

Kubernetes的基本调度单元称为“pods”。它可以把更高级别的抽象内容增加到容器化组件。一个pod一般包含一个或多个容器,这样可以保证它们一直位于主机上,并且可以共享资源。Kubernetes中的每个pod都被分配一个唯一的(在集群内的)IP地址这样就可以允许应用程序使用端口,而不会有冲突的风险。Pod可以定义一个卷,例如本地磁盘目录或网络磁盘,并将其暴露在pod中的一个容器之中。pod可以通过Kubernetes API手动管理,也可以委托给控制器来管理。

每个pod都有自己的IP地址,一个节点上的pod应该能够使用pod的IP访问另一个节点上的pod。单个节点上的容器可以通过本地接口轻松进行通信。然而,pod之间的通信更复杂,并且需要单独的网络组件,该组件可以透明地将流量从一个节点上的pod传送到另一个节点上的pod。此功能由pod网络插件提供。对于这个群集,建议您将使用Flannel选项

在本地计算机上创建一个命名为master.yml的Ansible playbook :

vi ~/kube-cluster/master.yml

将以下内容添加到文件中以初始化集群并安装Flannel:

- hosts: masterbecome: yestasks:- name: initialize the clustershell: kubeadm init --pod-network-cidr=10.244.0.0/16 >> cluster_initialized.txtargs:chdir: $HOMEcreates: cluster_initialized.txt- name: create .kube directorybecome: yesbecome_user: centosfile:path: $HOME/.kubestate: directorymode: 0755- name: copy admin.conf to user's kube configcopy:src: /etc/kubernetes/admin.confdest: /home/centos/.kube/configremote_src: yesowner: centos- name: install Pod networkbecome: yesbecome_user: centosshell: kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/v0.9.1/Documentation/kube-flannel.yml >> pod_network_setup.txtargs:chdir: $HOMEcreates: pod_network_setup.txt

这是上面内容的详解:

  • 第一个任务通过运行kubeadm init初始化集群。传递--pod-network-cidr=10.244.0.0/16参数指定将从中分配pod IP的私有子网。Flannel默认使用上述子网,我们告诉kubeadm使用相同的子网。
  • 第二个任务创建一个.kube目录在/home/centos。此目录将保存配置信息,例如连接到群集所需的管理密钥文件以及群集的API地址。
  • 第三个任务将/etc/kubernetes/admin.conf生成的文件复制kubeadm initcentos用户的主目录。这将允许您用kubectl访问新创建的群集。
  • 最后一个任务运行kubectl apply安装Flannelkubectl apply -f descriptor.[yml|json]是告诉kubectl创建descriptor.[yml|json]文件中描述的对象的语法。kube-flannel.yml文件包含Flannel在群集中设置所需的对象的说明。

完成后保存并关闭文件。执行配置:

ansible-playbook -i hosts ~/kube-cluster/master.yml

完成后,您将看到类似于以下内容的输出:

PLAY [master] ****TASK [Gathering Facts] ****
ok: [master]TASK [initialize the cluster] ****
changed: [master]TASK [create .kube directory] ****
changed: [master]TASK [copy admin.conf to user's kube config] *****
changed: [master]TASK [install Pod network] *****
changed: [master]PLAY RECAP ****
master                     : ok=5    changed=4    unreachable=0    failed=0  

要检查主节点的状态,请使用以下命令通过SSH连接到该节点:

ssh centos@master_ip

进入主节点后,执行:

kubectl get nodes

您现在将看到以下输出:

NAME      STATUS    ROLES     AGE       VERSION
master    Ready     master    1d        v1.10.1

输出表明master节点已完成所有初始化任务,并且处于Ready可以开始接受工作节点并执行发送到API服务器的任务的状态。您现在可以从本地计算机添加工作程序。

第4步 - 设置工作节点

将工作程序添加到集群涉及在每个集群上执行单个命令。此命令包括必要的群集信息,例如主服务器API服务器的IP地址和端口以及安全令牌。只有传入安全令牌的节点才能加入群集。

f反回您的工作区并创建一个名为workers.yml的配置:

vi ~/kube-cluster/workers.yml

将以下文本添加到文件中:

- hosts: masterbecome: yesgather_facts: falsetasks:- name: get join commandshell: kubeadm token create --print-join-commandregister: join_command_raw- name: set join commandset_fact:join_command: "{{ join_command_raw.stdout_lines[0] }}"- hosts: workersbecome: yestasks:- name: join clustershell: "{{ hostvars['master'].join_command }} >> node_joined.txt"args:chdir: $HOMEcreates: node_joined.txt

以下是配置的作用:

  • 第一个配置获取join命令,以便在worker节点上运行。该命令将采用以下格式:kubeadm join --token <token> <master-ip>:<master-port> --discovery-token-ca-cert-hash sha256:<hash>一旦它获得具有的令牌哈希值的命令,该任务就将其设置为可用,以便下一个配置能够访问该信息。
  • 第二个配置有一个任务,它在所有工作节点上运行join命令。完成此任务后,两个工作节点将成为群集的一部分。

完成后保存并关闭文件。执行配置:

ansible-playbook -i hosts ~/kube-cluster/workers.yml

完成后,您将看到类似于以下内容的输出:

PLAY [master] ****TASK [get join command] ****
changed: [master]TASK [set join command] *****
ok: [master]PLAY [workers] *****TASK [Gathering Facts] *****
ok: [worker1]
ok: [worker2]TASK [join cluster] *****
changed: [worker1]
changed: [worker2]PLAY RECAP *****
master                     : ok=2    changed=1    unreachable=0    failed=0
worker1                    : ok=2    changed=1    unreachable=0    failed=0
worker2                    : ok=2    changed=1    unreachable=0    failed=0  

通过添加工作节点,您的群集现在已完全设置并正常运行,工作节点可以随时运行工作负载。让我们验证群集是否按预期工作。

第5步 - 验证群集

集群有时可能在安装过程中失败,因为节点已关闭或主服务器与工作服务器之间的网络连接无法正常工作。让我们验证集群并确保节点正常运行。

您需要从主节点检查群集的当前状态,以确保节点已准备就绪。如果从主节点断开连接,则可以使用以下命令通过SSH将其重新连接到主节点:

ssh centos@master_ip

然后执行以下命令以获取集群的状态:

kubectl get nodes

您将看到类似于以下内容的输出:

NAME      STATUS    ROLES     AGE       VERSION
master    Ready     master    1d        v1.10.1
worker1   Ready     <none>    1d        v1.10.1
worker2   Ready     <none>    1d        v1.10.1

如果所有的节点都具有ReadySTATUS(状态),这意味着它们是集群的一部分,并准备运行工作负载。

但是,如果几个节点拥有NotReadySTATUS(状态),它可能意味着工作节点还没有完成自己的设置。等待大约五到十分钟再重新运行kubectl get node并检查新输出。如果一些节点仍具有NotReady状态,则需要验证并重新运行前面步骤中的命令。

现在您的集群已成功验证,让我们在集群上部署一个示例Nginx应用程序。

第6步 - 在群集上运行应用程序

您现在可以将任何容器化应用程序部署到您的群集。让我们使用部署和服务部署Nginx,以了解如何将此应用程序部署到集群。如果更改Docker镜像名称和任何相关标志(例如portsvolumes),您也可以使用以下命令用于其他容器化应用程序。

在主节点内,执行以下命令以创建名为nginx的部署:

kubectl run nginx --image=nginx --port 80

部署是一种Kubernetes对象,可确保始终根据已定义的模板运行指定数量的pod,即使pod在群集生命周期内崩溃也是如此。上面的部署将使用Docker镜像库的Nginx Docker Image创建一个包含一个容器的pod 。

接下来,运行以下命令以创建名为nginx将公开公共应用程序的服务。它将通过NodePort实现,该方案将通过在群集的每个节点上打开的任意端口访问pod:

kubectl expose deploy nginx --port 80 --target-port 80 --type NodePort

服务是另一种类型的Kubernetes对象,它向内部和外部客户端公开集群内部服务。它们还能够对多个pod进行负载均衡请求,并且是Kubernetes中不可或缺的组件,经常与其他组件交互。

运行以下命令:

kubectl get services

这将输出类似于以下内容的文本:

NAME         TYPE        CLUSTER-IP       EXTERNAL-IP           PORT(S)        AGE
kubernetes   ClusterIP   10.96.0.1        <none>                443/TCP        1d
nginx        NodePort    10.109.228.209   <none>                80:nginx_port/TCP   40m

从上面输出的第三行,您可以检索运行Nginx的端口。Kubernetes将分配一个大于30000自动的随机端口,同时确保该端口尚未受到其他服务的约束。

要测试一切正常,请访问或通过本地计算机上的浏览器。您将看到Nginx熟悉的欢迎页面。http://worker_1_ip:nginx_port或者http://worker_2_ip:nginx_port

如果要删除Nginx应用程序,请先nginx从主节点删除该服务:

kubectl delete service nginx

运行以下命令以确保已删除该服务:

kubectl get services

您将看到以下输出:

NAME         TYPE        CLUSTER-IP       EXTERNAL-IP           PORT(S)        AGE
kubernetes   ClusterIP   10.96.0.1        <none>                443/TCP        1d

然后删除部署:

kubectl delete deployment nginx

运行以下命令以确认这是否有效:

kubectl get deployments
No resources found.

结论

在本教程中,您已使用Kubeadm和Ansible成功在CentOS 7上设置Kubernetes集群以实现自动化。

如果您想知道要在集群设置的情况下如何处理集群,那么下一步就是将自己的应用程序和服务部署到集群上。这是一个链接列表,其中包含可以指导您完成此过程的更多信息:

  • Dockerizing应用程序 - 列出了详细说明如何使用Docker对应用程序进行容器化的示例。
  • Pod概述 - 详细描述了Pod如何工作以及它们与其他Kubernetes对象的关系。Pods在Kubernetes中无处不在,因此了解它们将有助于您的工作。
  • 部署概述 - 这提供了部署的概述。了解部署之类的控制器如何有效地工作,因为它们经常在无状态应用程序中用于扩展和不健康应用程序的自动修复。
  • 服务概述 - 这包括服务,Kubernetes集群中另一个常用对象。了解服务类型及其选项对于运行无状态和有状态应用程序至关重要。

其他重要概念是Volumes,Ingresses和Secrets,所有这些在部署生产应用程序时都派上用场。Kubernetes提供了许多功能和特性。Kubernetes官方文档是了解概念,查找特定于任务的教程以及查找各种对象的API参考的最佳位置。更多Linux教程请前往腾讯云+社区学习更多知识。


参考文献: 《How To Create a Kubernetes 1.10 Cluster Using Kubeadm on CentOS 7》 《只要用 kubeadm 小朋友都能部署 Kubernetes》

问答

如何使用Kubernetes?

相关阅读

安全报告 | 2018上半年互联网恶意爬虫分析:从全景视角看爬虫与反爬虫

安全报告 | SSH 暴力破解趋势:从云平台向物联网设备迁移

给你的CVM安装一个面板吧!

此文已由作者授权腾讯云+社区发布,原文链接:https://cloud.tencent.com/developer/article/1177930?fromSource=waitui

欢迎大家前往腾讯云+社区或关注云加社区微信公众号(QcloudCommunity),第一时间获取更多海量技术实践干货哦~

海量技术实践经验,尽在云加社区!

如何在CentOS上创建Kubernetes集群相关推荐

  1. 使用Gardener在Google Cloud Platform上创建Kubernetes集群

    Gardener是一个开源项目,github地址: https://github.com/gardener/gardener/ 使用Gardener,我们可以在几分钟之内在GCP, AWS, Azur ...

  2. 快速入门容器服务,创建Kubernetes集群

    使用须知 创建集群过程中,容器服务会进行如下操作: 创建 ECS,配置管理节点到其他节点的 SSH 的公钥登录,通过 CloudInit 安装配置 Kubernetes 集群. 创建安全组,该安全组允 ...

  3. 容器编排技术 -- 创建Kubernetes集群

    容器编排技术 -- 创建Kubernetes集群 Kubernetes可以在多种平台运行,从笔记本电脑,到云服务商的虚拟机,再到机架上的裸机服务器.要创建一个Kubernetes集群,根据不同场景需要 ...

  4. 在CentOS上安装ZooKeeper集群

    一共准备3个CentOS虚拟机 172.16.9.194 172.16.9.195 172.16.9.196 上传zookeeper-3.3.6.tar.gz到服务器并解压,3台服务器的目录结构如下 ...

  5. Minikube-运行在笔记本上的Kubernetes集群

    前言 Minikube是一个可以在本地电脑上运行Kubernetes的工具.Minikube会在笔记本电脑中的虚拟机上运行一个单节点的Kubernetes集群,让用户能对Kubernetes进行体验或 ...

  6. aws上创建eks集群

    在aws上创建eks集群前,需要先创建vpc和subnet以及role,因为在创建集群时会用到. 1.创建VPC 对于创建vpc,进入create vpc界面创建即可,这里用的都是默认值. 2.创建s ...

  7. 如何在CentOS7上创建Kubernetes k8s集群

    https://www.digitalocean.com/community/tutorials/how-to-create-a-kubernetes-cluster-using-kubeadm-on ...

  8. Centos离线安装Kubernetes集群

    目录 kuberadmin离线安装K8s集群 环境准备 基础环境配置 安装docker 准备基础镜像以及安装包 镜像 集群初始化 设置.kube/config 安装网络组件 加入node节点 验证集群 ...

  9. 【kubernetes】公有云上的kubernetes集群自动伸缩方案

    kubernetes集群自动伸缩 这里的集群自动伸缩指的是根据集群的资源使用状况,自动的调整集群节点的数目,目的是充分利用集群资源,节省成本.主要应用下面两个场景: 集群资源不足,导致pod部署失败, ...

最新文章

  1. C++ Primer 5th笔记(chap 17 标准库特殊设施)随机数
  2. Java switch case
  3. hibernate中PO对象的三种状态分析以及session中的一些方法的区别
  4. 软件包管理:源码包管理-源码包与RPM包的区别
  5. 解决datafountain比赛提交.csv文件报错问题
  6. 单元测试 代码里面都绝对路径怎么处理_python基础之包,异常处理
  7. SpringMVC学习(二)使用注解开发SpringMVC
  8. Druid连接池原理
  9. 真香啊,Python 轻松制作制作GIF动图
  10. linux logo程序,制作自己的linux启动LOGO
  11. Mac软件卸载:安全彻底地卸载Microsoft Outlook
  12. 一个学习小组有5个人,每个人有三门课的考试成绩。求全组分科的平均成绩和各科总平均成绩。
  13. laravel——实现Email形式的邮箱验证注册以及登陆功能
  14. 我的IT相关网址收藏
  15. 百度直播iOS SDK平台化输出改造
  16. NLP深入学习——过滤停用词(Filtering stop words)
  17. 阿里云安装数据库mysql数据库服务器_阿里云CentOs服务器 安装与配置mysql数据库...
  18. android的发音功能实现,为Android TTS引擎指定发音的最佳做法?
  19. Unity HybridRender 视锥体裁剪
  20. marker 头像 高德地图_手机地图导航软件高德地图1.如何下载高德地图

热门文章

  1. linux下VScode开发ESP32,VsCode设置ESP32工具链+刨根问底点灯
  2. python实现两个接口的依赖关系
  3. mysql olap 函数_Mysql中的窗口函数
  4. android 打包 混淆配置_玩转代码混淆工具:ProGuard
  5. python 元组 列表 字典区别_Python列表、元组、字典、集合、字符串的异同总结
  6. git 修改默认分支为main_Git:基本操作
  7. 利用计算机管理分区,win7增加磁盘分区教学 利用磁盘管理增加分区
  8. rup 裁剪_裁剪师是什么意思
  9. 解决一个输入框可输入多个条件进行查询时,后端该怎么接收参数以及SQL语句如何写
  10. Python编程基础03:变量与数据类型