AKS使用Azure File实现动态持久化存储

本文作者|搪瓷小娃娃

本文来源|搪瓷小娃娃博客园


如我们所知,Kubernetes通过 Volume 为集群中的容器提供存储,通过Persistent Volume 和 Persistent Volume Claim实现Volume 的静态供给和动态供给。Azure File和Azure Disk 也在Kubernetes 支持的动态供给 PV 的 Provisioner之列(如下图:https://kubernetes.io/docs/concepts/storage/storage-classes/#provisioner),本篇文章就带领大家操作一遍,如何动态创建Azure File 文件共享,以供集群中的多个Pod使用。

640?wx_fmt=png


(1)准备工作

创建好一个AKS集群,并且升级Azure CLI到最新版本

登录到你创建好的集群中,确认下各Node节点状态是否正常:

640?wx_fmt=png


(2)添加StorageClass

创建一个azure-file-sc.yaml文件并编辑如下:

640?wx_fmt=png

如上我们创建的这个Storage Class封装的名称(name)为azurefile, provisioner指定为kubernetes.io/azure-file,参数parameter部分,指定冗余形式,目前支持Standard的三张,其他暂不支持:

  • Standard_LRS - standard locally redundant storage (LRS)

  • Standard_GRS - standard geo-redundant storage (GRS)

  • Standard_RAGRS - standard read-access geo-redundant storage (RA-GRS)

创建好之后执行 kubectl apply -f azure-file-sc.yaml。



(3)创建集群角色并绑定

作为Azure平台上的服务,AKS仍然使用的RBAC去控制集群的权限和安全。为了使Azure平台能够创建所需要的存储资源,这一步我们需要添加一个集群角色:


---

apiVersion: rbac.authorization.k8s.io/v1

kind: ClusterRole

metadata:

  name: system:azure-cloud-provider

rules:

- apiGroups: ['']

  resources: ['secrets']

  verbs:     ['get','create']

---

apiVersion: rbac.authorization.k8s.io/v1

kind: ClusterRoleBinding

metadata:

  name: system:azure-cloud-provider

roleRef:

  kind: ClusterRole

  apiGroup: rbac.authorization.k8s.io

  name: system:azure-cloud-provider

subjects:

- kind: ServiceAccount

  name: persistent-volume-binder

  namespace: kube-system

执行kubectl apply -f azure-pvc-roles.yaml 如下:

640?wx_fmt=png


(4)创建PVC:

这一步就是动态申请存储资源的文件了,命名这个PVC yaml文件为azure-file-pvc.yml,编辑如下,指定metadata为第(2)步中的StorageClassName,配置好访问模式和容量,编辑好保存并运行,可以看到这个PVC已经被成功创建。


apiVersion: v1

kind: PersistentVolumeClaim

metadata:

  name: azurefile

spec:

  accessModes:

    - ReadWriteMany

  storageClassName: azurefile

  resources:

    requests:

      storage: 5Gi


640?wx_fmt=png


(5)使用并检验

首先我们创建一个pod,命令为mypod1.yml,这个pod运行的是一个busybox镜像,通过PVC将Azure File mount 到容器的/datatest目录中。


apiVersion: v1

kind: Pod

metadata:

  name: mypod1

spec:

  containers:

  - image: busybox

    name: mycontainer1

    volumeMounts:

    - mountPath: /datatest

      name: datatest

    args:

    - /bin/sh

    - -c

    - sleep 30000

  volumes:

  - name: datatest

    persistentVolumeClaim:

      claimName: my-azurefile-pvc


然后依次执行:


kubectl apply -f mypod1.yaml

#查看pod状态

kubectl get pod -o wide

#在pod里的datatest目录下创建一个名字为hello的文件

kubectl exec mypod1 touch /datatest/hello


640?wx_fmt=png

如上是截图,在pod中创建完名字为hello的文件后,我们检验下这个文件有没有更新到Azure File中,这里说明一下,AKS动态配置完后的AzureFile会默认创建在MC_的集群中,portal上找到这个存储账户进去,找到Azure File下面的文件,如截图,发现hello.txt已经存在了。

640?wx_fmt=png

640?wx_fmt=png

以上就是整个实验过程,演示了AKS如何使用Azure File实现动态持久化存储。希望对大家有用。

640?wx_fmt=jpeg

原文地址:https://www.cnblogs.com/changruijun/p/10941339.html

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

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

相关文章

AGC005D - ~K Perm Counting(组合数学,背包,dp)

AGC005D - ~K Perm Counting Solution 经典数排列个数题,写了个大麻烦容斥。 直接容斥,考虑求出fif_ifi​表示有iii个位置∣pi−i∣k|p_i-i|k∣pi​−i∣k的方案数。一个位置iii满足∣pi−i∣k|p_i-i|k∣pi​−i∣k,要么piikp_iikpi​ik&a…

Codeforces Round #704 (Div. 2) D. Genius‘s Gambit 构造 + 细节

传送门 题意: 给a,b,ka,b,ka,b,k,要求用aaa个000和bbb个111组成二进制xxx和yyy,并且x−yx-yx−y恰好有kkk个111,并且xxx和yyy不含前导零。 思路: 首先需要看到不含前导零,一开始没看见wa5了。让后一个很明…

ASP.NET Core 应用程序状态

在ASP.NET Core中,由多种途径可以对应用程序状态进行管理,使用哪种途径,由检索状态的时机和方式决定。应用程序状态指的是用于描述当前状况的任意数据。包括全局和用户特有的数据。开发人员可以根据不同的因素来选择不同的方式存储状态数据&a…

HDU6218 2017ACM/ICPC亚洲区沈阳站 Bridge(Set,线段树)

HDU6218 2017ACM/ICPC亚洲区沈阳站 Bridge Solution 我们考虑维护在环上的边的个数,答案就是总边数减去环上边数。 环的形态是这样的:(0,l),(0,l1)...(0,r),(1,r),(1,r−1)...(1,l)(0,l),(0,l1)...(0,r),(1,r),(1,r-1)...(1,l)(0,l),(0,l1)...(0,r),(…

Codeforces Round #704 (Div. 2) E. Almost Fault-Tolerant Database 思维

传送门 题意: 给nnn个长度为mmm的数组,要求构造一个长度为mmm的数组,使得这个数组与前面nnn个数组同一位置最多两个元素不同。 思路: 我们为了方便构造,可以先把要构造的数组看成nnn个数组的第一个数组,让…

Asp.net core使用MediatR进程内发布/订阅

1、背景最近,一个工作了一个月的同事离职了,所做的东西怼了过来。一看代码,惨不忍睹,一个方法六七百行,啥也不说了吧,实在没法儿说。介绍下业务场景吧,一个公共操作A,业务中各个地方…

[APIO2018] New Home 新家(线段树,二分答案,离散化)

[APIO2018] New Home 新家 Solution 对于时间轴我们直接离散化扫描线,维护每一个商店的加入和删除。 对于询问(x,t)(x,t)(x,t),不好直接回答,这里的关键一步是:我们要求的是kkk种商店最小距离的最大值,于是考虑二分…

Codeforces Round #701 (Div. 2) C. Floor and Mod 数学分块

传送门 题意&#xff1a; 给两个数x,yx,yx,y。现在你计算有多少对a(a<x)a(a<x)a(a<x)和b(b<y)b(b<y)b(b<y)使得⌊ab⌋amodb\left \lfloor \frac{a}{b} \right \rfloora\bmod b⌊ba​⌋amodb。 思路&#xff1a; 因为xxx和yyy都是1e91e91e9的范围&#xff0…

AGC011D - Half Reflector(模拟)

AGC011D - Half Reflector Solution 先考虑改变一次。 我们令LLL表示往左走的球&#xff0c;RRR表示往右走的球&#xff0c;xxx表示任意种类的球&#xff0c;(−x)(-x)(−x)表示与xxx相反种类的球。 当球处于ARAARAARA的状态&#xff08;即有一个向右的球在两个AAA机器人之间…

[开源] FreeSql.Tools Razor 生成器

FreeSql 经过半年的开发和坚持维护&#xff0c;在 0.6.x 版本中完成了几大重要事件&#xff1a;1、按小包拆分&#xff0c;每个数据库实现为单独 dll&#xff1b;2、实现 .net framework 4.5 支持&#xff1b;3、同时支持 MySql.Data、MySqlConnector 的实现&#xff1b;4、自定…

Codeforces Round #701 (Div. 2) D. Multiples and Power Differences 思维构造

传送门 题意&#xff1a; 给定一个矩阵aaa&#xff0c;让你构造一个矩阵bbb&#xff0c;要求矩阵bbb的每个元素是aaa对应位置元素的倍数&#xff0c;且矩阵bbb的每两个相邻元素相差为k4(k>1)k^4(k>1)k4(k>1)。注意aaa的元素范围是1<a<161<a<161<a<…

AGC012D - Colorful Balls(并查集)

AGC012D - Colorful Balls Solution 连边题。 找出www最小的球yyy和www最小且颜色和yyy不同的球zzz。 yyy向所有colt̸coly,wtwy≤Ycol_t\not col_y,w_tw_y\leq Ycolt​​coly​,wt​wy​≤Y的球ttt连边。zzz向所有colt̸coly,wtwz≤Ycol_t\not col_y,w_tw_z\leq Ycolt​…

WebAssembly和Blazor:解决了一个存在十年的老问题

本文要点WebAssembly 是一种新的客户端技术&#xff0c;可以在所有现代浏览器&#xff08;包括移动浏览器&#xff09;中实现近乎原生的性能&#xff0c;而且不需要插件。许多语言&#xff0c;包括 C、C#、Go 和 Rust&#xff0c;都可以编译成面向基于栈的 WebAssembly 虚拟机的…

Educational Codeforces Round 103 (Rated for Div. 2) D. Journey dp

传送门 题意&#xff1a; 给n1n1n1个点&#xff0c;每两个点之间有一个字符L(表示i1连向i)L(表示i1连向i)L(表示i1连向i)或者R(表示i连向i1)R(表示i连向i1)R(表示i连向i1)&#xff0c;每秒可以移动一次&#xff0c;每移动一次每两个点之间的方向会互换&#xff0c;问每个点能到…

LG P4074 [WC2013] 糖果公园(带修莫队,树上莫队)

LG P4074 [WC2013] 糖果公园 Solution 树上带修莫队&#xff0c;主要还是复习带修莫队和树上莫队。 带修莫队&#xff1a; 带修莫队要先对lll分块的序号作为第一关键字&#xff0c;对rrr分块的序号作为第二关键字&#xff0c;时间ttt作为第三关键字排序&#xff0c;然后正常…

《电商后台系统产品逻辑解析》学习笔记

文是我阅读《电商产品经理宝典&#xff1a;电商后台系统产品逻辑全解析》一书的学习笔记&#xff0c;为后续我司做家居电商后台系统储备相关领域的业务知识。一、支撑线后台概览“前端用户的一小步&#xff0c;后台系统的一大步”&#xff0c;平时常见的功能如购物车、优惠券等…

P3403 跳楼机 同余最短路

传送门 题意&#xff1a; 思路&#xff1a; 转换一下题目就是用若干x,y,zx,y,zx,y,z能凑出来多少个<h<h<h的数。先考虑两个数y,zy,zy,z的情况&#xff0c;我们如果能求出来这两个数能凑出来的数设为sumsumsum&#xff0c;让后sumkx<hsumkx<hsumkx<h求出来…

LG P4899 [IOI2018] werewolf 狼人(kruskal重构树,二维数点)

LG P4899 [IOI2018] werewolf 狼人 Solution 我们发现010101限制长这样子&#xff1a; ∃x(minids−>x≥L&maxidx−>e≤R)→1\exist_x(min_{id_{s->x}}\geq L\;\;\And\;\;max_{id_{x->e}}\leq R) \to 1∃x​(minids−>x​​≥L&maxidx−>e​​≤R)…

NopCommerce 4.2的安装与运行

、关于NopCommerceNopCommerce是国外ASP.Net领域一个高质量的B2C开源电商项目&#xff0c;最新版本4.2基于ASP.NET Core MVC 2.2和EF Core 2.2开发&#xff0c;其强大的功能特性和插件机制使其成为了.NET领域开源电商项目的标杆。当然&#xff0c;还有一些其他的开源电商项目如…

P1527 [国家集训队]矩阵乘法 整体二分 + 二维树状数组

传送门 题意&#xff1a; 思路&#xff1a; 算是个整体二分的板子啦&#xff0c;不过这个是二维的矩阵&#xff0c;我们只需要把一位树状数组改成二维的&#xff0c;让后动态维护单点加&#xff0c;区间查询前缀和即可。 //#pragma GCC optimize(2) #include<cstdio>…