- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个三节点 GCE 集群和一个带有三个副本的单 pod GKE 部署。我像这样创建了 PV 和 PVC:
# Create a persistent volume for web content
apiVersion: v1
kind: PersistentVolume
metadata:
name: nginx-content
labels:
type: local
spec:
capacity:
storage: 5Gi
accessModes:
- ReadOnlyMany
hostPath:
path: "/usr/share/nginx/html"
--
# Request a persistent volume for web content
kind: PersistentVolumeClaim
apiVersion: v1
metadata:
name: nginx-content-claim
annotations:
volume.alpha.kubernetes.io/storage-class: default
spec:
accessModes: [ReadOnlyMany]
resources:
requests:
storage: 5Gi
spec:
containers:
- image: launcher.gcr.io/google/nginx1
name: nginx-container
volumeMounts:
- name: nginx-content
mountPath: /usr/share/nginx/html
ports:
- containerPort: 80
volumes:
- name: nginx-content
persistentVolumeClaim:
claimName: nginx-content-claim
最佳答案
首先,我想指出您的配置中的一个基本差异。请注意,当您使用 PersistentVolumeClaim
时在您的示例中定义,您不使用 nginx-content
PersistentVolume
根本。您可以通过运行轻松验证它:
kubectl get pv
在您的
GKE 集群 .您会注意到,除了您手动创建的
nginx-content
PV
,还有另一个是基于
PVC
自动配置的。你申请的。
PersistentVolumeClaim
您明确指的是
default
的定义与您手动创建的存储类无关
PV
.实际上,即使您完全省略注释:
annotations:
volume.alpha.kubernetes.io/storage-class: default
它将以完全相同的方式工作,即
default
无论如何都会使用存储类。在
上使用默认存储类GKE 意味着
GCE 永久磁盘 将用作您的卷供应商。您可以阅读更多相关信息
here :
Volume implementations such as gcePersistentDisk are configuredthrough StorageClass resources. GKE creates a default StorageClass foryou which uses the standard persistent disk type (ext4). The defaultStorageClass is used when a PersistentVolumeClaim doesn't specify aStorageClassName. You can replace the provided default StorageClasswith your own.
PersistentVolume
可在
ReadOnlyMany
中使用模式,
GCE 永久磁盘 是完全满足您要求的完美解决方案。
ro
多人模式
Pods
同时还有很多人认为更重要的事情
Pods
, 安排在不同的
GKE
nodes
.此外,它的配置非常简单,它适用于
GKE 盒子外面。
ReadWriteMany
中使用您的存储空间模式,我同意像 NFS 这样的东西可能是唯一的解决方案,因为
GCE 永久磁盘 不提供这样的能力。
PVC
开始.这一步实际上已经由你自己完成了,但你在进一步的步骤中有点迷失了。让我解释一下它是如何工作的。
annotations
部分可以省略):
# Request a persistent volume for web content
kind: PersistentVolumeClaim
apiVersion: v1
metadata:
name: nginx-content-claim
spec:
accessModes: [ReadOnlyMany]
resources:
requests:
storage: 5Gi
但是,我想对此添加一项重要评论。你说:
Even though I created the volumes as ReadOnlyMany, only one pod canmount the volume at any given time.
accessModes
的方式。真的有效。事实上,这是一个被广泛误解的概念。首先
您不能在 PVC
中定义访问模式从某种意义上说,将您想要的约束放在那里。支持
访问模式是特定存储类型的固有特征。它们已经由存储提供者定义。
PVC
定义正在请求
PV
支持特定的访问模式或访问模式。注意它的形式是
列表这意味着您可以提供许多不同的访问模式,您希望您的
PV
支持。
ReadOnlyMany
模式的卷。”您要求以这种方式获得满足您要求的存储。但是请记住,您可以得到的比您要求的更多。这也是我们要求
PV
时的场景。支持
ReadOnlyMany
模式在
GCP .它为我们创建了一个
PersistentVolume
满足我们在
accessModes
中列出的要求部分但它也支持
ReadWriteOnce
模式。虽然我们没有要求也支持
ReadWriteOnce
的东西您可能会同意我的观点,内置支持这两种模式的存储完全满足我们对支持
ReadOnlyMany
的要求。 .所以基本上这就是它的工作方式。
PV
由 GCP 自动配置以响应您的
PVC
支持这两个
accessModes
如果您没有在
Pod
中明确指定或
Deployment
您想将其安装在
中的定义只读 模式,默认安装在
读写模式。
Pod
轻松验证它。能够成功挂载
PersistentVolume
:
kubectl exec -ti pod-name -- /bin/bash
并试图在挂载的文件系统上写一些东西。
"Error 400: RESOURCE_IN_USE_BY_ANOTHER_RESOURCE"
特别关注
GCE 永久磁盘 已经被一个
挂载了GKE
node
在
ReadWriteOnce
模式并且它不能被另一个
node
挂载剩下的你的
Pods
被安排。
ReadOnlyMany
模式,您需要在
Deployment
中明确指定它通过添加
readOnly: true
定义
volumes
中的声明部分下
Pod's
模板规范如下:
apiVersion: apps/v1
kind: Deployment
metadata:
name: nginx-deployment
labels:
app: nginx
spec:
replicas: 3
selector:
matchLabels:
app: nginx
template:
metadata:
labels:
app: nginx
spec:
containers:
- name: nginx
image: nginx:1.14.2
ports:
- containerPort: 80
volumeMounts:
- mountPath: "/usr/share/nginx/html"
name: nginx-content
volumes:
- name: nginx-content
persistentVolumeClaim:
claimName: nginx-content-claim
readOnly: true
但是请记住,要能够将其安装在
readOnly
中模式,首先我们需要用数据预先填充这样的卷。否则,您将看到另一条错误消息,指出无法以只读模式安装未格式化的卷。
Pod
仅用于复制已上传到我们的
之一的数据。 GKE 节点 到我们的目的地
PV
.
PersistentVolume
可以通过许多不同的方式处理数据。您可以安装在这样的
Pod
只有您的
PersistentVolume
您将在
Deployment
中使用的并使用
curl
获取您的数据或
wget
从某个外部位置直接将其保存在您的目的地
PV
.由你决定。
Pod
的卷
directory
,
partition
或
disk
(在我的示例中,我使用位于我的 GKE 节点之一上的目录
/var/tmp/test
)在我们的 kubernetes 节点之一上可用。它比
hostPath
更灵活的解决方案因为我们不必关心调度这样的
Pod
到包含数据的特定节点。具体
节点亲和性 规则已在
PersistentVolume
中定义和
Pod
在特定节点上自动调度。
StorageClass
:
apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
name: local-storage
provisioner: kubernetes.io/no-provisioner
volumeBindingMode: WaitForFirstConsumer
PersistentVolume
定义:
apiVersion: v1
kind: PersistentVolume
metadata:
name: example-pv
spec:
capacity:
storage: 10Gi
volumeMode: Filesystem
accessModes:
- ReadWriteOnce
persistentVolumeReclaimPolicy: Delete
storageClassName: local-storage
local:
path: /var/tmp/test
nodeAffinity:
required:
nodeSelectorTerms:
- matchExpressions:
- key: kubernetes.io/hostname
operator: In
values:
- <gke-node-name>
最后
PersistentVolumeClaim
:
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: myclaim
spec:
accessModes:
- ReadWriteOnce
volumeMode: Filesystem
resources:
requests:
storage: 10Gi
storageClassName: local-storage
然后我们可以创建我们的临时
Pod
仅用于从我们的
复制数据GKE 节点 到我们的
GCE 永久磁盘 .
apiVersion: v1
kind: Pod
metadata:
name: mypod
spec:
containers:
- name: myfrontend
image: nginx
volumeMounts:
- mountPath: "/mnt/source"
name: mypd
- mountPath: "/mnt/destination"
name: nginx-content
volumes:
- name: mypd
persistentVolumeClaim:
claimName: myclaim
- name: nginx-content
persistentVolumeClaim:
claimName: nginx-content-claim
您可以在上面看到的路径并不重要。本次任务
Pod
只是为了让我们将数据复制到目的地
PV
.最终我们的
PV
将安装在完全不同的路径中。
Pod
创建并成功挂载两个卷,我们可以通过运行来附加到它:
kubectl exec -ti my-pod -- /bin/bash
随
Pod
只需运行:
cp /mnt/source/* /mnt/destination/
就这样。现在我们可以
exit
并删除我们的临时
Pod
:
kubectl delete pod mypod
一旦它消失了,我们可以申请我们的
Deployment
和我们的
PersistentVolume
终于可以安装在
readOnly
模式由所有
Pods
位于各种
GKE 节点 :
apiVersion: apps/v1
kind: Deployment
metadata:
name: nginx-deployment
labels:
app: nginx
spec:
replicas: 3
selector:
matchLabels:
app: nginx
template:
metadata:
labels:
app: nginx
spec:
containers:
- name: nginx
image: nginx:1.14.2
ports:
- containerPort: 80
volumeMounts:
- mountPath: "/usr/share/nginx/html"
name: nginx-content
volumes:
- name: nginx-content
persistentVolumeClaim:
claimName: nginx-content-claim
readOnly: true
顺便提一句。如果您同意您的
Pods
将只安排在一个特定的节点上,您可以放弃使用
GCE 永久磁盘 并切换到上述
local体积。这样你所有的
Pods
不仅可以读取它,还可以同时写入它。唯一需要注意的是,所有这些
Pods
将在单个节点上运行。
关于kubernetes - 如何在多个 Pod 上安装相同的持久卷?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62309755/
是 if(a == 0 && b == 0 && c == 0) { return; } 一样 if(a == 0) { return; } if(b == 0) { return; } if(c =
我想做这样的事情: Class A Class B extends A Class C extends A B b = new B(); C c = new C(); b->setField("foo
我对 Mysql 世界很天真......:)我试图使用连接从表中查询, 我遇到结果集问题...表结构如下 下面... VIDEO_XXXXX | Field | Type
我最近问过关于从另一个类获取类的唯一实例的问题。 ( How to get specific instance of class from another class in Java? ) 所以,我正
假设我们有两种类型 using t1 = int*; using t2 = int*; 我知道 std::is_same::value会给我们true .什么是,或者是否有模板工具可以实现以下目标?
对于我的一个应用程序,我假设比较 2 个字符串的第一个字符比比较整个字符串是否相等要快。例如,如果我知道只有 2 个可能的字符串(在一组 n 字符串中)可以以相同的字母开头(比如说 'q'),如果是这
我想在我的NXP LPC11U37H主板(ARM Cortex-M0)上分析一些算法,因为我想知道执行特定算法需要多少个时钟周期。 我编写了这些简单的宏来进行一些分析: #define START_C
我在 Excel 中创建了一个宏,它将在 Excel 中复制一个表格,并将行除以我确定的特定数字(默认 = 500 行),并为宏创建的每个部门打开不同的工作表。 使用的代码是这样的: Sub Copy
我想根据第一个字典对第二个字典的值求和。如果我有字典 A 和 B。 A = {"Mark": ["a", "b", "c", "d"], "June": ["e", "a"], "John": ["a
当我这样做时 system()在 Perl 中调用,我通常根据 perldocs 检查返回码.嗯,我是这么想的。大部分时间 $rc!=0对我来说已经足够了。最近我在这里帮助了两个遇到问题的人syste
在我的进度条上,我试图让它检测 div 加载速度。 如果 div 加载速度很快,我想要实现的目标将很快达到 100%。但进度条的加载速度应该与 div 的加载速度一样快。 问题:如何让我的进度条加载
当我获得与本地时间相同的时间戳时,firebase 生成的服务器时间戳是否会自动转换为本地时间,或者我错过了什么? _firestore.collection("9213903123").docume
根据the original OWL definition of OWL DL ,我们不能为类和个体赋予相同的名称(这是 OWL DL 和 OWL Full 之间的明显区别)。 "Punning" i
我有两个输入复选框: 尝试使用 jQuery 来允许两个输入的行为相同。如果选中第一个复选框,则选中第二个复选框。如果未检查第 1 个,则不会检查第 2 个。反之亦然。 我有代码: $('inpu
可以从不同系统编译两个相同的java文件,但它们都有相同的内容操作系统(Windows 7),会生成不同的.class文件(大小)? 最佳答案 是的,您可以检查是否有不同版本的JDK(Java Dev
我正在清理另一个人的正则表达式,他们目前所有的都以结尾 .*$ 那么下面的不是完全一样吗? .* 最佳答案 .*将尽可能匹配,但默认情况下为 .不匹配换行符。如果您要匹配的文本有换行符并且您处于 MU
我使用 Pick ,但是如何编写可以选择多个字段的通用PickMulti呢? interface MyInterface { a: number, b: number, c: number
我有一个 SQL 数据库服务器和 2 个具有相同结构和数据的数据库。我在 2 个数据库中运行相同的 sql 查询,其中一个需要更长的时间,而另一个在不到 50% 的时间内完成。他们都有不同的执行计划。
我需要你的帮助,我有一个包含两列的表,一个 id 和 numpos,我希望 id 和 numops 具有相同的结果。 例子: $cnx = mysql_connect( "localhost", "r
如何将相同的列(在本例中按“级别”排序)放在一起?我正在做一个高分,我从我的数据库中按级别列出它们。如果他们处于同一级别,我希望他们具有相同的 ID。 但是我不想在别人身上显示ID。只有第一个。这是一
我是一名优秀的程序员,十分优秀!