ZBLOG

使用client-go 创建StatefulSet 并设置DefaultMode为0775

可以使用 client-go 的 StatefulSet API 创建 StatefulSet 并设置 DefaultMode 为 0775,具体示例如下:

import (
    "k8s.io/api/apps/v1"
)

...

statefulSetClient := kubernetesClient.AppsV1().StatefulSets(namespace)

statefulSet := &v1.StatefulSet{
    ObjectMeta: metav1.ObjectMeta{
        Name:      "example-statefulset",
        Namespace: namespace,
    },
    Spec: v1.StatefulSetSpec{
        Replicas:    &replicas,
        ServiceName: serviceName,
        Selector: &metav1.LabelSelector{
            MatchLabels: labels,
        },
        Template: corev1.PodTemplateSpec{
            ObjectMeta: metav1.ObjectMeta{
                Labels: labels,
            },
            Spec: corev1.PodSpec{
                Containers: []corev1.Container{container},
                SecurityContext: &corev1.PodSecurityContext{
                    FSGroup: &fsGroup, // 设置 fsGroup
                },
                Volumes: []corev1.Volume{volume}, // 添加 volume
            },
        },
        VolumeClaimTemplates: []corev1.PersistentVolumeClaim{pvc}, // 添加 PVC 模板
    },
}

// 设置 DefaultMode 为 0775
statefulSet.Spec.Template.Spec.Containers[0].SecurityContext = &corev1.SecurityContext{
    RunAsUser:          &runAsUser,
    RunAsGroup:         &runAsGroup,
    FsGroup:            &fsGroup,
}
for i, _ := range statefulSet.Spec.VolumeClaimTemplates {
    statefulSet.Spec.VolumeClaimTemplates[i].Spec.AccessModes = []corev1.PersistentVolumeAccessMode{"ReadWriteOnce"}
    statefulSet.Spec.VolumeClaimTemplates[i].Spec.StorageClassName = storageClassName
}

其中,最后一段代码通过设置 Pod 的 SecurityContext 来设置 DefaultMode,注意此处只设置了第一个容器的 SecurityContext。

另外,还可以为 Volume 设置默认权限:

volume := corev1.Volume{
    Name: "data",
    VolumeSource: corev1.VolumeSource{
        PersistentVolumeClaim: &corev1.PersistentVolumeClaimVolumeSource{
            ClaimName: pvc.Name,
            DefaultMode: &defaultMode, // 设置 DefaultMode 为 0775
        },
    },
}

以上示例中,创建的 Volume 使用了 PVC,并通过设置 DefaultMode 属性来指定了默认权限。

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=4904

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?