使用阿里云容器服务和容器网络文件系统搭建WordPress网站
1. 创建实验资源
开始实验之前,您需要先创建Kubernetes托管版集群,详情请参考创建Kubernetes托管版集群。
说明 :
您在创建集群过程中,请注意以下事项:
- 用户账户需有100元的余额并通过实名认证,否则无法创建按量付费的ECS实例和负载均衡。
- Kubernetes托管版集群具体计费详情,请参考产品计费。
- 登录容器服务管理控制台。
- 在控制台左侧导航栏中,单击集群。
- 在集群列表页面中,单击页面右上角的创建集群。
- 在集群配置页面,选择ACK托管版,参考如下配置,其他配置默认即可,单击下一步:节点池配置。
参数:
- 集群名称:自定义集群名称。
- 集群规格:选择标准版。
- 地域:选择集群所在地域。
- 付费类型:选择按量付费。
- 专有网络:选择集群的网络。Kubernetes集群仅支持专有网络。您可以在已有VPC列表中选择所需的VPC。如果没有您需要的专有网络,可以通过单击创建专有网络进行创建,请参见创建和管理专有网络。
- 虚拟交换机:选择集群的交换机。
- API Server访问:选择使用EIP暴露API Server。
- 在节点池配置页面,参考如下配置,其他配置保持默认即可,单击下一步:组件配置。
参数说明:
- 实例规格:选择ecs.n4.xlarge。
- 登录方式:选择设置密码。
- 登录密码:自定义登录密码。
- 确认密码:再次输入登录密码。
- 在组件配置页面,在存储插件中选择创建默认NAS文件系统和CNFS容器网络文件系统动态存储类型,其他配置保持默认即可,单击下一步:确认配置。
- 在确认配置页面,选择我已了解和接受上述说明,并已阅读和同意阿里云容器服务Kubernetes版服务条款和免责声明,单击创建集群。
返回如下页面,集群创建中,您需要耐心等待集群创建完成。
说明 :资源创建过程大约需要10分钟。
- 在创建集群页面,等待页面显示集群创建成功后,单击返回集群列表。
返回如下页面,您就可以在集群列表中看到您刚刚创建的ACK集群。
2. 创建WordPress应用
本步骤将指导您如何通过容器服务ACK控制台创建WordPress应用。
- 查看CNFS托管NAS文件系统。
a. 在集群列表页面中,找到您的集群,单击集群名称。
b. 在集群信息页面左侧,选择存储>存储类。
c. 在存储类页面,找到名称为alibabacloud-cnfs-nas,表示CNFS已经托管NAS文件系统。
说明 :本实验在创建ACK集群资源时,已勾选创建默认NAS文件系统和CNFS容器文件系统动态存储类型。
- 在存储类页面左侧,单击命名空间与配额。
- 在命名空间页面,单击创建。
- 在创建命名空间对话框中,名称输入为wordpress,单击确定。
- 在命名空间页面左上方,单击图标。
- 在集群列表页面左侧,单击应用市场。
- 在应用市场页面,在搜索框中输入wordpress,然后单击ack-wordpress-sample。
- 在ack-wordpress-sample页面,单击一键部署。
- 在创建面板的基本信息中,选择您的集群,命名空间选择wordpress,单击下一步。
- 在创建面板的参数配置中,将storageClass修改为alibabacloud-cnfs-nas,单击确定。
注意:在参数配置中,一共有两处storageClass参数需要修改为alibabacloud-cnfs-nas,具体位置可参考下方两张图片。
- 在页面左侧,选择工作负载>容器组。
- 在容器组页面上方,选择命名空间为wordpress。
- 在容器组页面,等待大约一分钟并单击刷新,当所有Pod状态变为Running时,表示您已成功安装WordPress应用。
3. 访问测试网站
本步骤将指导您如何访问WordPress应用并发布博客。
- 在容器组页面左侧,单击集群信息。
- 在集群信息页面,单击通过CloudShell管理集群。
- 在CloudShell中,执行如下命令,查看当前安装的charts。
helm list -nwordpress
返回如下结果,您可以看到当前安装的charts的Name为ack-wordpress-sample-default。
- 在CloudShell中,执行如下命令,查看ack-wordpress-sample-default状态。
helm status ack-wordpress-sample-default
返回如下结果,找到echo Password这一行,并右键复制小括号中的命令。
- 在CloudShell中,执行上一步骤复制的命令,查看WordPress应用的user用户登陆密码。
返回如下结果,您可以看到WordPress应用的user用户登陆密码。
- 在CloudShell上方菜单栏中,单击图标,关闭CloudShell。
- 在集群信息页面左侧,选择网络>服务。
- 在服务页面,找到ack-wordpress-sample-default服务,单击外部端点。
- 在WordPress页面,单击Log in。
- 在WordPress应用后台登录页面,Username输入为user,Password输入为第五步的user用户密码,然后单击Log In。
- 在WordPress后台管理页面左侧,选择Posts>Add New。
- 在编辑页面,输入自定义标题,单击图标,然后单击Image。
- 在编辑页面的Image区域,单击Upload,上传图片。
说明 :您需要在浏览器打开下方链接,下载图片至虚拟桌面后,才可进行上传图片操作。
https://labfileapp.oss-cn-hangzhou.aliyuncs.com/%E5%AE%B9%E5%99%A8%E6%9C%8D%E5%8A%A1%20Container%20Servi.png
- 在编辑页面右侧,单击Publish。
- 在编辑页面右侧,单击PublishPost。
- 在编辑页面右侧,单击View Post。
返回如下页面, 您可以看到发布的博客。
4. CNFS回收站
本步骤将指导您在删除文件后,如何使用CNFS回收站进行数据恢复。
- 切换至容器服务控制台页签。在服务页面,选择工作负载>容器组。
- 在容器组页面,找到WordPress的Pod,单击操作列下的终端,然后单击容器:wordpress。
- 在容器中终端页面,执行如下命令,查看nas挂载目录。
mount |grep nfs
返回如下结果,您可看到nas挂载目录。
- 执行如下命令,进入nas挂载目录。
说明 :您需要将[挂载目录]替换为上一步骤中查询到的nas挂载目录。
cd [挂载目录]
- 执行如下命令,进入wp-content/uploads/2022目录。
cd wp-content/uploads/2022
- 执行如下命令,查看2022目录下的文件。
ls
- 执行如下命令,删除2022目录下的文件。
说明 :您需要将[文件名]替换为上一步骤中查看到的文件名。
rm -rf [文件名]
- 切换至WordPress应用页签并刷新,您会发现您发布的博客中的图片被删除了。
- 切换至容器服务控制台页签。在容器组页面左侧,选择存储>存储卷。
- 在存储卷页面,找到绑定存储声明列下名称为ack-wordpress-sample-default的存储卷,单击回收站。
- 在回收站页面,找到刚刚删除的文件夹,单击恢复。
- 在选择文件的恢复路径对话框中,选择恢复至原路径,单击确定。
- 切换至容器组终端页签。执行如下命令,您可以看到您删除的文件夹已经恢复。
ls
- 切换至WordPress应用页签并刷新,您可以看到您发布的博客中的图片已经恢复。
5. 验证quota
本步骤将指导您如何验证quota是否生效。
- 切换至容器服务控制台页签。找到绑定存储声明列下名称为ack-wordpress-sample-default的存储卷,您可以看到容量有20 Gi。
- 切换至容器组终端页签。执行如下命令,查看磁盘资源占用空间。
df -h
返回如下结果,您可看到/bitnami/wordpress目录的磁盘资源占用空间。
- 执行如下命令,写入临时数据,将存储声明(pvc)绑定的/bitnami/wordpress目录空间填满。
说明: 该命令生效大约需要3分钟,请您耐心等待命令生效。
dd if=/dev/zero of=tmp.25G bs=1G count=25
- 执行如下命令,查看磁盘资源占用空间。
df -h
返回如下结果,您可以看见bitnami/wordpress目录的磁盘占用空间已超出其pvc的容量。
- 执行如下命令,写入20G临时数据,
说明 :该命令生效大约需要3分钟,请您耐心等待命令生效。
dd if=/dev/zero of=tmp.20G bs=1G count=20
返回如下结果,当pvc绑定的目录空间已满时,再次写入临时数据,报错为disk quota execeeded,表示quota已开启。
6. CNFS在线扩容并验证
本步骤将指导您如何对CNFS进行在线扩容,并验证扩容是否成功。
- 切换至容器服务控制台页签。在存储卷页面左侧,单击集群信息。
- 在集群信息页面,单击通过CloudShell管理集群。
- 在CloudShell中,执行如下命令,查看存储声明(pvc)容量。
kubectl get pvc
返回如下结果,您可以看到pvc的容量为20 Gi。
- 在CloudShell中,执行如下命令,查看存储卷(pv)容量。
kubectl get pv
返回如下结果,您可以看到pv的容量为20 Gi。
- 在CloudShell中,执行如下命令,扩容pvc名称为ack-wordpress-sample-default的容量。
kubectl patch pvc ack-wordpress-sample-default -p '{"spec":{"resources":{"requests":{"storage":"50Gi"}}}}'
- 在CloudShell中,执行如下命令,查看pv容量。
kubectl get pv
返回如下结果,您可以看到pv的容量为50 Gi,已扩容成功。
- 在CloudShell中,执行如下命令,查看pvc容量。
说明 :pvc扩容生效大约需要1分钟。
kubectl get pv
返回如下结果,您可以看到pvc的容量为50 Gi,已扩容成功。
- 切换至容器组终端页签。执行如下命令,写入1G临时数据,
说明: 该命令生效大约需要3分钟,请您耐心等待命令生效。
dd if=/dev/zero of=tmp.1G bs=1G count=1
返回如下结果,您可以看到之前的disk quota execeeded报错没有出现,表示您已扩容成功。
7. 释放资源
本步骤将指导您如何释放Kubernetes托管版集群。
- 在集群列表页面,找到您的集群,在操作列下,选择更多>删除。
- 在删除集群对话框中,选择我已知晓以上信息并确认删除集群,单击确定。
返回如下页面,集群状态为删除中,请您耐心等待集群删除完成。
实验地址:https://developer.aliyun.com/adc/scenario/54fd2710f04e4bb2b28722caf99b5475