当前位置: 首页 > news >正文

Kubernetes--深入理解Service与CoreDNS

文章目录

  • Service功能
      • Service 的常见使用场景
    • Service的模式
      • iptables
      • IPVS
    • Service类型
      • ClusterIP
      • NodePort
      • LoadBalancer
      • ExternalName
    • Service的工作机制
    • Endpoint
      • Endpoint 与 Service 的关系
      • Endpoint 的工作原理
      • 命令操作
  • CoreDNS
    • CoreDNS 的配置
    • CoreDNS 的典型插件
    • Corefile 示例
    • CoreDNS 的工作原理
    • 举例说明

Service功能

在 Kubernetes中,Service是用于将一组Pod以稳定的网络接口暴露出来,公开为一个网络服务的抽象,提供稳定的访问入口。虽然 Pod 的 IP 是动态分配的、会频繁变动,但 Service 通过分配一个固定的虚拟 IP(ClusterIP)来解决 Pod 动态变化的问题,并实现负载均衡,确保客户端始终可以通过统一的方式访问服务。

Service功能:1.服务发现发现一组提供了相同服务的 Pod:标签选择器,在同一 namespace 中筛选符合的条件的Pod;实际上并非由 Service 资源自己完成,而是借助于另一种称为 Endpoints/EndpointSlice 完成的; 集群内的 Pod 可以通过 Service 名称进行通信,Kubernetes 会自动管理这些名称解析。由标签选择器实现2.负载均衡Service作为流量入口和负载均衡器,其入口为ClusterIP:这组筛选出的Pod的IP地址,将作为该Service的后端服务器; Service会将访问请求均匀地分发给后端的多个 Pod,默认使用轮询方式进行负载均衡。由iptables/ipvs实现3.名称解析为该组Pod所代表的服务提供一个名称:依赖于Cluster DNS,对于每个Service,自动生成一个A、PTR和SRV记录由DNS实现

在这里插入图片描述
在这里插入图片描述

Service 的常见使用场景

Service 的常见使用场景:1.前端访问后端服务:一个 Web 前端可能通过 Service 访问后端的多个服务实例。2.微服务架构:Service 是微服务架构中的核心组件,用于不同服务之间的通信。3.服务发现:通过 DNS 或环境变量等方式,Pod 可以发现并访问其他 Pod 提供的服务。

Service的模式

在 Kubernetes 中,Pod的生命周期是短暂的,可能会被终止和重新创建,而 Service 提供了一个持久的访问入口,确保用户或其他服务可以通过固定的 IP 地址或 DNS 名称访问这些 Pod。Kubernetes 中的 Service 支持多种模式,每种模式决定了 Service 如何路由流量到 Pod,以及如何处理集群内外的网络请求。

Kubernetes的Service提供了多种模式来应对不同的网络通信需求:1.iptables模式:当前最常见的默认模式,性能较好,适用于大多数场景。2.IPVS模式:高性能负载均衡模式,适合大规模、高并发的场景,提供更多的负载均衡算法。

iptables

iptables 模式是 Kubernetes 的默认模式,也是当前最常用的 Service 模式。它使用 Linux 内核中的 iptables 来完成流量的路由和转发。

iptables模式工作机制:1.kube-proxy运行时会为每个Service创建一条 iptables 规则。2.这些规则被放入内核中,并在内核层执行流量转发,而不需要经过用户空间。3.内核根据这些规则直接在Pod之间转发流量,实现负载均衡。特点:1.性能更高,因为流量转发完全在内核中完成,不需要用户空间的参与。2.延迟低,处理能力强,适合大规模生产环境。3.当Pod或Service更新时,kube-proxy动态更新iptables规则。

示例: 当有一个 Service my-service,该 Service 选择了多个 Pod,iptables 会创建一个规则集,确保请求可以分发到与这个 Service 相关联的 Pod。流量在 Pod 之间均匀分配。

IPVS

IPVS (IP Virtual Server) 是一种基于内核的负载均衡技术,使用 Linux 虚拟服务器技术(通过 ipvsadm 管理),是 iptables 模式的增强版。IPVS 模式是 Kubernetes 中最新引入的一种 Service 模式,提供了更强的扩展性和性能。

IPVS模式工作机制:1.与iptables类似,kube-proxy监控集群中Service和Pod的变化,但它使用 IPVS 进行流量的路由和负载均衡。2.IPVS 在内核空间中实现,通过内核模块提供负载均衡功能。3.IPVS 支持更多的负载均衡算法,例如轮询(round-robin)、最小连接数、源地址哈希等。特点:1.IPVS比iptables性能更高,能够更快地处理大量规则和服务。2.IPVS支持更多的负载均衡算法,灵活性更强。3.更适合大规模高并发的服务。优点:1.具有比iptables更高的吞吐量和更低的延迟。2.支持动态的服务更新,处理大规模流量的能力较强

Service类型

在 Kubernetes 中,Service 有不同的类型,适用于不同的访问需求。常见的 Service 类型包括:ClusterIP、NodePort、LoadBalancer 和 ExternalName。

常见的 Service 类型1.ClusterIP 是最常见的服务类型,适合集群内部的通信。2.NodePort 允许外部客户端通过节点的 IP 和端口访问集群中的服务。3.LoadBalancer 为云环境中的 Kubernetes 集群提供外部负载均衡,适用于需要在互联网上提供服务的应用。4.ExternalName 服务重定向 DNS 名称,用于 Kubernetes 内部服务访问外部 DNS 名称服务。

在这里插入图片描述

ClusterIP

集群内部使用,东西流量

ClusterIPClient --> Service_IP:Service_Port --> Pod_IP:Pod_Port 功能:这是默认的Service类型,服务只在集群内部暴露,其他集群内的Pod可以通过服务的ClusterIP进行访问。适用场景:只需要在集群内部访问的服务,例如微服务之间的通信。特点:Kubernetes自动分配一个虚拟IP(ClusterIP)作为访问入口。只能在集群内部访问,外部无法直接访问。
apiVersion: v1
kind: Service
metadata:name: my-clusterip-service
spec:selector:app: my-appports:- protocol: TCPport: 80       # 暴露的端口targetPort: 8080  # Pod 内部应用的端口type: ClusterIP

NodePort

NodePortClient --> Node_IP:NodePort --> Pod_IP:Pod_Port功能:服务不仅在集群内部暴露,还通过每个节点上的一个固定端口在集群外部暴露。适用场景:需要从外部访问集群中的服务,但没有使用外部负载均衡器的环境。特点:Kubernetes 在每个节点上开放一个静态端口(范围 30000-32767)。可以通过节点的 IP 地址和指定的端口号从集群外部访问服务。
apiVersion: v1
kind: Service
metadata:name: my-nodeport-service
spec:type: NodePortselector:app: my-appports:- protocol: TCPport: 80         # 服务内部端口targetPort: 8080  # Pod 内部的应用端口nodePort: 30007   # 固定节点上的外部端口

LoadBalancer

LoadBalancerClient --> LB_IP:LB_PORT --> Node_IP:NodePort --> Pod_IP:Pod_Port功能:在支持的云服务平台(如 AWS、GCP、Azure)上,创建一个外部负载均衡器,服务暴露在集群外部,外部客户端可以通过负载均衡器的IP进行访问。适用场景:需要在云环境下,提供一个能够自动扩展和负载均衡的外部服务。特点:Kubernetes 将为Service创建一个外部负载均衡器(如 AWS ELB),并将流量导入集群内部的Service。负载均衡器的 IP 地址是服务的外部访问入口。
apiVersion: v1
kind: Service
metadata:name: my-loadbalancer-service
spec:type: LoadBalancerselector:app: my-appports:- protocol: TCPport: 80         # 负载均衡器暴露的端口targetPort: 8080  # Pod 上实际服务的端口

ExternalName

ExternalName功能:将 Kubernetes 内部的 Service 名称映射到外部 DNS 名称,服务本身不创建ClusterIP,也无法通过内部IP访问。适用场景:集群内部的服务需要访问外部服务时。特点:将Service名称解析为一个外部的DNS名称,而不是一个内部的ClusterIP。不需要暴露端口,只是DNS名称的别名。
apiVersion: v1
kind: Service
metadata:name: my-external-service
spec:type: ExternalNameexternalName: example.com

在此例中,访问 my-external-service 时,会被重定向到 example.com,适用于在 Kubernetes 集群内访问外部服务的场景。

Service的工作机制

在这里插入图片描述

Service 的工作机制:1.标签选择器(Label Selector):Service 通过标签选择器将服务与一组 Pod 关联起来。只要 Pod 的标签符合 Service 的选择器条件,这些 Pod 就会成为 Service 的后端。2.Endpoints:Service 维护一个 Endpoints 对象,记录了符合标签选择器的所有 Pod 的 IP 地址和端口。负载均衡时,Service 会将请求转发到 Endpoints 中的 Pod。

Endpoint

在 Kubernetes 中,Endpoint 是用来连接服务和实际提供服务的 Pod 的资源。Endpoint 对象负责维护一组 IP 地址和端口信息,这些信息指向在集群中运行的实际 Pod,使得客户端可以通过 Service 访问这些 Pod。

Endpoint概念1.Service:在Kubernetes中,Service 是一种抽象,用于定义一组 Pod 的访问策略。Service 通过 ClusterIPNodePort 或 LoadBalancer 等方式暴露应用程序,但它并不直接与 Pod 关联。2.Endpoint:Endpoint则是与 Service 相关联的资源,存储了与该服务相关联的实际 Pod 的 IP 地址和端口列表。当一个 Service 被创建时,Kubernetes 控制平面会自动生成与该 Service 对应的 Endpoint,用来维护服务和实际运行的 Pod 之间的映射。

Endpoint 与 Service 的关系

Endpoint 与 Service 的关系1.Service 是访问 Pod 的抽象层,Endpoint 是 Service 和 Pod 之间的桥梁。2.当一个 Service 选择了一组 Pod(通常是通过标签选择器),这些 Pod 的 IP 地址和端口会被加入到对应的 Endpoint 中。3.当客户端请求 Service 的 IP 和端口时,Service 会查找对应的 Endpoint 并将流量路由到 Endpoint 中定义的 Pod。

Endpoint 的工作原理

 Endpoint 的工作原理1.当创建一个Service时,Kubernetes会自动创建一个Endpoint对象,该对象包含符合该 Service 标签选择器(label selector)的所有Pod的IP和端口。2.Service 通过 ClusterIP(虚拟 IP)接收请求,查找与之对应的Endpoint,然后将流量发送到匹配的 Pod 中。

命令操作

查看 Service 相关的 Endpoint:

kubectl get endpoints <service-name>

查看 Endpoint 详细信息:

kubectl describe endpoints <service-name>

CoreDNS

CoreDNS 是 Kubernetes 中用于服务发现和内部 DNS 解析的默认 DNS 服务器。在 Kubernetes 集群中,Pod 之间相互通信、外部服务访问、以及服务的动态发现,都依赖于 DNS 解析,CoreDNS 扮演着关键角色。

CoreDNS的作用1.服务发现:Kubernetes使用DNS解析来帮助Pod找到集群中的服务。例如,通过service-name.namespace.svc.cluster.local可以解析到某个服务的ClusterIP。2.DNS解析:CoreDNS为集群内部的Pod和服务提供DNS服务,支持解析内部服务域名和外部域名(如访问互联网的域名)。3.可扩展和插件化:CoreDNS是模块化的,它通过不同的插件(如缓存、负载均衡、重定向等)来增强DNS功能,允许根据需要定制DNS行为。4.集群内网络通信的核心:Pod通过DNS解析服务IP来互相通信,确保了容器化应用在Kubernetes集群中的稳定运行。

CoreDNS 的配置

CoreDNS 的配置文件是一个 Corefile,定义了 DNS 的解析规则。这个配置文件位于 Kubernetes 集群的 ConfigMap 中,通常可以通过以下方式查看:

kubectl get configmap coredns -n kube-system -o yaml

CoreDNS 的典型插件

CoreDNS 是基于插件架构的,每个插件为 CoreDNS 增加了不同的功能。以下是一些常用的插件:

CoreDNS 的典型插件1.kubernetes:这是最关键的插件,负责处理 Kubernetes 内部服务的 DNS 解析。例如将 my-service.my-namespace.svc.cluster.local 解析为服务的 ClusterIP。2.forward:用于将无法在集群内解析的 DNS 查询转发到外部 DNS 服务器(如 8.8.8.8)。3.cache:对 DNS 查询结果进行缓存,以提高查询速度并减少对外部 DNS 服务器的请求。4.log:记录所有 DNS 请求的日志,方便调试和排查问题。5.hosts:允许使用本地 /etc/hosts 文件来解析固定的 IP 地址。

Corefile 示例

以下是一个典型的 Corefile 配置,它包括 kubernetes、forward、log 和 cache 插件。可使用kubectl describe命令查看Corefile 配置。

kubectl describe cm coredns -n kube-system
.:53 {errorsloghealthkubernetes cluster.local in-addr.arpa ip6.arpa {pods insecurefallthrough in-addr.arpa ip6.arpa}forward . /etc/resolv.conf {max_concurrent 1000}cache 30reload
}
配置解读:.:53:表示 CoreDNS 监听 53 端口,处理所有 DNS 请求。errors:在出现错误时记录错误信息。log:记录所有 DNS 请求的日志,帮助调试。health:CoreDNS 会在健康检查时返回 HTTP 200 状态,表明它处于健康状态。kubernetes:负责处理 Kubernetes 内部 DNS 解析,将请求解析为集群内部的 Pod 和服务地址。forward:当 CoreDNS 无法解析请求时,它会将请求转发到外部 DNS 服务器(通常是集群节点的 /etc/resolv.conf 中指定的 DNS 服务器)。cache:缓存查询结果 30 秒,以减少对外部 DNS 服务器的请求负载。

在这里插入图片描述

CoreDNS 的工作原理

CoreDNS 的工作原理1.当一个 Pod 请求一个服务的 DNS 名称(例如 my-service.my-namespace.svc.cluster.local)时,DNS 请求会被 CoreDNS 处理。2.CoreDNS 检查 Corefile 中的配置,首先尝试使用 kubernetes 插件来解析请求。3.如果服务名存在,CoreDNS 将返回服务的 ClusterIP 地址。4.如果请求无法由 Kubernetes 内部解析,CoreDNS 使用 forward 插件将查询转发到外部 DNS 服务器进行解析。

举例说明

假设我们有一个服务 nginx-service,部署在命名空间 web 下,CoreDNS 将负责解析这个服务的 DNS 名称。

部署 nginx-service

首先,我们创建一个简单的 Nginx 服务:

apiVersion: v1
kind: Service
metadata:name: nginx-servicenamespace: web
spec:selector:app: nginxports:- protocol: TCPport: 80targetPort: 80type: ClusterIP

然后,创建 Nginx 的 Deployment:

apiVersion: apps/v1
kind: Deployment
metadata:name: nginxnamespace: web
spec:replicas: 3selector:matchLabels:app: nginxtemplate:metadata:labels:app: nginxspec:containers:- name: nginximage: nginx:1.19.0ports:- containerPort: 80

使用 CoreDNS 进行服务解析
在集群中的其他 Pod 可以通过 DNS 访问 nginx-service:

curl http://nginx-service.web.svc.cluster.local

这个请求将由 CoreDNS 处理,CoreDNS 会使用 kubernetes 插件解析 nginx-service.web.svc.cluster.local,并返回 Nginx 服务的 ClusterIP。然后,Pod 可以通过这个 IP 访问 Nginx 服务。

总结1.CoreDNS 是 Kubernetes 集群内的默认 DNS 服务器,主要负责服务发现和 DNS 解析。2.它使用插件架构,通过 kubernetes 插件解析集群内服务,通过 forward 插件将外部域名请求转发到外部 DNS 服务器。3.配置文件 Corefile 决定了 CoreDNS 的行为,可以通过 ConfigMap 来进行配置和定制。4.CoreDNS 提供了丰富的插件支持,如缓存、日志记录等,帮助优化 DNS 查询的性能和调试体验。

相关文章:

Kubernetes--深入理解Service与CoreDNS

文章目录 Service功能Service 的常见使用场景 Service的模式iptablesIPVS Service类型ClusterIPNodePortLoadBalancerExternalName Service的工作机制EndpointEndpoint 与 Service 的关系Endpoint 的工作原理命令操作 CoreDNSCoreDNS 的配置CoreDNS 的典型插件Corefile 示例Cor…...

AI大模型:开启智能革命新纪元

1.AI大模型技术&#xff1a;智能革命的新引擎 自2022年11月30日OpenAI推出ChatGPT以来&#xff0c;这一大型语言模型&#xff08;LLM&#xff09;迅速走红&#xff0c;标志着AI领域进入了一个新的发展阶段&#xff0c;即AI大模型时代。 这一时代预示着AI正朝着通用人工智能&am…...

快速上手C语言【下】(非常详细!!!)

目录 1. 指针 1.1 指针是什么 1.2 指针类型 1.2.1 指针-整数 1.2.2 指针解引用 1.3 const修饰 1.4 字符指针 1.5 指针-指针 1.6 二级指针 2. 数组 2.1 定义和初始化 2.2 下标引用操作符[ ] 2.3 二维数组 2.4 终极测试 3. 函数 3.1 声明和定义 3.2 传值调用…...

红黑树的理解与实现(详解)

相关的数据结构&#xff1a; 搜索二叉树-CSDN博客 AVL树的创建与检测-CSDN博客 个人主页&#xff1a;敲上瘾-CSDN博客 个人专栏&#xff1a;游戏、数据结构、c语言基础、c学习、算法 目录 一、红黑树规则&#xff1a; 二、红黑树的插入 1.变色 2.单旋变色 3.双旋变色 三、…...

从一到无穷大 #37 Databricks Photon:打响 Spark Native Engine 第一枪

本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。 本作品 (李兆龙 博文, 由 李兆龙 创作)&#xff0c;由 李兆龙 确认&#xff0c;转载请注明版权。 文章目录 引言技术决策JVM vs. Native ExecutionInterpreted Vectorization vs Code-GenRow vs…...

Java 字符串占位格式化

Java 提供了几种方式来处理字符串占位符&#xff0c;最常用的是 String 类的 format 方法和 MessageFormat 类。以下是这两种方法的详细说明和示例。 1、String.format 基本语法&#xff1a; String formatted String.format("格式字符串", 参数1, 参数2, ...); …...

基于netty实现简易版rpc服务-理论分析

1.技术要点 1.1 rpc协议 定义一个rpc协议类&#xff0c;用于rpc服务端和客户端数据交互。 1.2 netty粘包半包处理 由于数据传说使用tcp协议&#xff0c;rpc协议的数据在网络传输过程中会产生三种情况&#xff1a; 1&#xff09;刚好是完整的一条rpc协议数据 2&#xff09;不…...

Elasticsearch高级搜索技术-全文搜索

目录 倒排索引 (Inverted Index) 示例 分词器 (Analyzer) 评分机制 (Scoring) 查询执行 match 查询 match_phrase 查询 全文搜索是Elasticsearch的核心功能之一&#xff0c;它通过复杂的算法和数据结构来提供高效的搜索能力。为了深入理解其工作原理&#xff0c;我们需要…...

案例分享—国外优秀UI卡片设计作品赏析

国外UI设计注重用户体验&#xff0c;倾向于采用简洁的布局、清晰的排版和直观的交互方式&#xff0c;减少用户的认知负担。卡片式设计能够完美利用屏幕空间&#xff0c;使内容一目了然&#xff0c;易于用户快速浏览和阅读&#xff0c;从而提升了整体的用户体验。 更加注重扁平化…...

Go语言基础学习(Go安装配置、基础语法)

一、简介及安装教程 1、为什么学习Go&#xff1f; 简单好记的关键词和语法&#xff1b;更高的效率&#xff1b;生态强大&#xff1b;语法检查严格&#xff0c;安全性高&#xff1b;严格的依赖管理&#xff0c; go mod 命令&#xff1b;强大的编译检查、严格的编码规范和完整的…...

STM32—FLASH闪存

1.FLASH简介 STM32F1系列的FLASH包含程序存储器、系统存储器和选项字节三个部分&#xff0c;通过闪存存储器接口&#xff08;外设&#xff09;可以对程序存储器和选项字节进行擦除和编程 我们怎么操作这些存储器呢&#xff1f;这就需要用到这个闪存存储器接口了&#xff0c;闪…...

AP上线的那些事儿(1)capwap建立过程、设备初始化以及二层上线

1、了解FITAP与AC的建立过程 之前我们已经知道了FATAP与FIT是一对双胞胎一样的兄弟&#xff0c;FAT哥哥能够直接独立使用当AP桥接、路由器等&#xff0c;而弟弟FIT则比较薄弱&#xff0c;独自发挥不出功效&#xff0c;需要一位师傅&#xff08;AC&#xff09;来带领&#xff0c…...

10 django管理系统 - 管理员管理 - 新建管理员(通过模态框和ajax实现)

在文章“04 django管理系统 - 部门管理 - 新增部门”中&#xff0c;我们通过传统的新增页面来实现部门的添加。 在本文中&#xff0c;我们通过模态框和ajax来实现管理员的新增。 首先在admin_list.html中新建入口&#xff0c;使用按钮 <div class"panel-heading&quo…...

Mysql中表字段VARCHAR(N)类型及长度的解释

本文将针对MySQL 中 varchar (N)类型字段的存储方式进行解释&#xff0c;主要是对字符和字节的关系的理解。 1. varchar (N) 中的 N varchar (N) 中的 N 表示字符数&#xff0c;而不是字节数。这意味着 N 表示你可以存储多少个字符。 字符数&#xff1a;指的是字符的个数&…...

git提交信息写错处理方式

在Git中&#xff0c;你可以通过使用rebase命令来合并提交记录。以下是一个简单的步骤来合并一系列提交&#xff1a; 使用git rebase -i开始交互式变基。在打开的编辑器中&#xff0c;你会看到一个提交列表。若要合并提交&#xff0c;将要合并的提交前面的pick改为squash或s。保…...

C#从零开始学习(用unity探索C#)(unity Lab1)

初次使用Unity 本章所有的代码都放在 https://github.com/hikinazimi/head-first-Csharp Unity的下载与安装 从 unity官网下载Unity Hub Unity的使用 安装后,注册账号,下载unity版本,然后创建3d项目 设置窗口界面布局 3D对象的创建 点击对象,然后点击Move Guzmo,就可以拖动…...

【SpringBoot】15 Echarts+Thymeleaf 绘制各种图表

Gitee仓库 https://gitee.com/Lin_DH/system 介绍 ECharts是百度开源的一个前端组件。它是一个使用 JavaScript 实现的开源可视化库&#xff0c;可以流畅的运行在 PC 和移动设备上&#xff0c;兼容当前绝大部分浏览器&#xff08;IE8/9/10/11&#xff0c;Chrome&#xff0c;…...

网络学习笔记

一、网络的结构与功能 网络的鲁棒性与抗毁性 如果在移走少量节点后网络中的绝大部分节点仍然是连通的&#xff0c;那么就该网络的连通性对节点故障具有鲁棒性 网络上的动力学 动力系统&#xff1a;自旋、振子或混沌的同步、可激发系统 传播过程&#xff1a;信息传播与拥堵…...

[论文笔记]HERMES 3 TECHNICAL REPORT

引言 今天带来论文HERMES 3 TECHNICAL REPORT&#xff0c;这篇论文提出了一个强大的工具调用模型&#xff0c;包含了训练方案介绍。同时提出了一个函数调用标准。 为了简单&#xff0c;下文中以翻译的口吻记录&#xff0c;比如替换"作者"为"我们"。 聊天模…...

MySQL-19.多表设计-一对多-外键

一.多表问题分析 二.添加外键 三.外键约束的问题...

测试微信模版消息推送

进入“开发接口管理”--“公众平台测试账号”&#xff0c;无需申请公众账号、可在测试账号中体验并测试微信公众平台所有高级接口。 获取access_token: 自定义模版消息&#xff1a; 关注测试号&#xff1a;扫二维码关注测试号。 发送模版消息&#xff1a; import requests da…...

VB.net复制Ntag213卡写入UID

本示例使用的发卡器&#xff1a;https://item.taobao.com/item.htm?ftt&id615391857885 一、读取旧Ntag卡的UID和数据 Private Sub Button15_Click(sender As Object, e As EventArgs) Handles Button15.Click轻松读卡技术支持:网站:Dim i, j As IntegerDim cardidhex, …...

JavaScript 中的 ES|QL:利用 Apache Arrow 工具

作者&#xff1a;来自 Elastic Jeffrey Rengifo 学习如何将 ES|QL 与 JavaScript 的 Apache Arrow 客户端工具一起使用。 想获得 Elastic 认证吗&#xff1f;了解下一期 Elasticsearch Engineer 培训的时间吧&#xff01; Elasticsearch 拥有众多新功能&#xff0c;助你为自己…...

python爬虫:Newspaper3k 的详细使用(好用的新闻网站文章抓取和解析的Python库)

更多内容请见: 爬虫和逆向教程-专栏介绍和目录 文章目录 一、Newspaper3k 概述1.1 Newspaper3k 介绍1.2 主要功能1.3 典型应用场景1.4 安装二、基本用法2.2 提取单篇文章的内容2.2 处理多篇文档三、高级选项3.1 自定义配置3.2 分析文章情感四、实战案例4.1 构建新闻摘要聚合器…...

【决胜公务员考试】求职OMG——见面课测验1

2025最新版&#xff01;&#xff01;&#xff01;6.8截至答题&#xff0c;大家注意呀&#xff01; 博主码字不易点个关注吧,祝期末顺利~~ 1.单选题(2分) 下列说法错误的是:&#xff08; B &#xff09; A.选调生属于公务员系统 B.公务员属于事业编 C.选调生有基层锻炼的要求 D…...

.Net Framework 4/C# 关键字(非常用,持续更新...)

一、is 关键字 is 关键字用于检查对象是否于给定类型兼容,如果兼容将返回 true,如果不兼容则返回 false,在进行类型转换前,可以先使用 is 关键字判断对象是否与指定类型兼容,如果兼容才进行转换,这样的转换是安全的。 例如有:首先创建一个字符串对象,然后将字符串对象隐…...

Maven 概述、安装、配置、仓库、私服详解

目录 1、Maven 概述 1.1 Maven 的定义 1.2 Maven 解决的问题 1.3 Maven 的核心特性与优势 2、Maven 安装 2.1 下载 Maven 2.2 安装配置 Maven 2.3 测试安装 2.4 修改 Maven 本地仓库的默认路径 3、Maven 配置 3.1 配置本地仓库 3.2 配置 JDK 3.3 IDEA 配置本地 Ma…...

Python ROS2【机器人中间件框架】 简介

销量过万TEEIS德国护膝夏天用薄款 优惠券冠生园 百花蜂蜜428g 挤压瓶纯蜂蜜巨奇严选 鞋子除臭剂360ml 多芬身体磨砂膏280g健70%-75%酒精消毒棉片湿巾1418cm 80片/袋3袋大包清洁食品用消毒 优惠券AIMORNY52朵红玫瑰永生香皂花同城配送非鲜花七夕情人节生日礼物送女友 热卖妙洁棉…...

React---day11

14.4 react-redux第三方库 提供connect、thunk之类的函数 以获取一个banner数据为例子 store&#xff1a; 我们在使用异步的时候理应是要使用中间件的&#xff0c;但是configureStore 已经自动集成了 redux-thunk&#xff0c;注意action里面要返回函数 import { configureS…...

Linux离线(zip方式)安装docker

目录 基础信息操作系统信息docker信息 安装实例安装步骤示例 遇到的问题问题1&#xff1a;修改默认工作路径启动失败问题2 找不到对应组 基础信息 操作系统信息 OS版本&#xff1a;CentOS 7 64位 内核版本&#xff1a;3.10.0 相关命令&#xff1a; uname -rcat /etc/os-rele…...