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

Kubernetes与存储管理最佳实践

Kubernetes与存储管理最佳实践1. Kubernetes存储模型Kubernetes存储模型定义了如何在容器化环境中管理和使用存储资源是集群存储管理的基础。1.1 存储模型核心概念VolumePod中的存储卷可被多个容器共享PersistentVolume (PV)集群级别的存储资源PersistentVolumeClaim (PVC)用户对存储资源的请求StorageClass动态存储供应的配置模板VolumeSnapshot存储卷的快照VolumeSnapshotClass快照的配置模板1.2 存储类型类型特点适用场景EmptyDir临时存储Pod删除时丢失临时数据缓存HostPath主机路径开发测试需要访问主机文件NFS网络文件系统共享存储持久化数据Ceph分布式存储高性能高可靠存储AWS EBS云存储云环境中的持久存储GCE PD云存储Google Cloud环境中的持久存储Azure Disk云存储Azure环境中的持久存储Local本地存储高性能存储需要节点亲和性2. 存储插件选择与配置2.1 NFS存储部署NFS服务器# 安装NFS服务器 apt-get install nfs-kernel-server # 创建共享目录 mkdir -p /nfs/share chmod 777 /nfs/share # 配置NFS导出 cat /etc/exports EOF /nfs/share *(rw,sync,no_subtree_check,no_root_squash) EOF # 重启NFS服务 systemctl restart nfs-kernel-server创建NFS PV和PVCapiVersion: v1 kind: PersistentVolume metadata: name: nfs-pv spec: capacity: storage: 10Gi accessModes: - ReadWriteMany nfs: server: nfs-server path: /nfs/share --- apiVersion: v1 kind: PersistentVolumeClaim metadata: name: nfs-pvc namespace: default spec: accessModes: - ReadWriteMany resources: requests: storage: 5Gi storageClassName: 2.2 Ceph存储部署Ceph集群# 安装Cephadm curl -fsSL https://download.ceph.com/keys/release.asc | sudo apt-key add - echo deb https://download.ceph.com/debian-pacific/ $(lsb_release -sc) main | sudo tee /etc/apt/sources.list.d/ceph.list sudo apt update sudo apt install cephadm # 部署Ceph集群 cephadm bootstrap --mon-ip 192.168.1.100创建Ceph RBD存储类apiVersion: storage.k8s.io/v1 kind: StorageClass metadata: name: ceph-rbd defaultClass: false provisioner: kubernetes.io/rbd parameters: monitors: 192.168.1.100:6789 adminId: admin adminSecretName: ceph-secret adminSecretNamespace: kube-system pool: kube userId: kube userSecretName: ceph-user-secret userSecretNamespace: default fsType: ext4 imageFormat: 2 imageFeatures: layering reclaimPolicy: Retain allowVolumeExpansion: true2.3 Local存储创建Local存储类apiVersion: storage.k8s.io/v1 kind: StorageClass metadata: name: local-storage provisioner: kubernetes.io/no-provisioner volumeBindingMode: WaitForFirstConsumer reclaimPolicy: Delete --- apiVersion: v1 kind: PersistentVolume metadata: name: local-pv spec: capacity: storage: 100Gi accessModes: - ReadWriteOnce persistentVolumeReclaimPolicy: Delete storageClassName: local-storage local: path: /mnt/disks/ssd1 nodeAffinity: required: nodeSelectorTerms: - matchExpressions: - key: kubernetes.io/hostname operator: In values: - node13. 持久卷配置3.1 基本PV和PVC配置静态PV配置apiVersion: v1 kind: PersistentVolume metadata: name: static-pv spec: capacity: storage: 20Gi accessModes: - ReadWriteOnce persistentVolumeReclaimPolicy: Retain storageClassName: standard hostPath: path: /data/pv1PVC配置apiVersion: v1 kind: PersistentVolumeClaim metadata: name: app-pvc namespace: default spec: accessModes: - ReadWriteOnce resources: requests: storage: 10Gi storageClassName: standard在Pod中使用PVCapiVersion: v1 kind: Pod metadata: name: app-pod namespace: default spec: containers: - name: app image: nginx:1.21-alpine volumeMounts: - name: app-storage mountPath: /data volumes: - name: app-storage persistentVolumeClaim: claimName: app-pvc3.2 动态存储供应创建StorageClassapiVersion: storage.k8s.io/v1 kind: StorageClass metadata: name: standard provisioner: kubernetes.io/aws-ebs parameters: type: gp2 reclaimPolicy: Delete allowVolumeExpansion: true volumeBindingMode: Immediate使用动态存储apiVersion: v1 kind: PersistentVolumeClaim metadata: name: dynamic-pvc namespace: default spec: accessModes: - ReadWriteOnce resources: requests: storage: 10Gi storageClassName: standard3.3 存储卷快照创建快照类apiVersion: snapshot.storage.k8s.io/v1 kind: VolumeSnapshotClass metadata: name: csi-snapshot-class driver: rbd.csi.ceph.com deletionPolicy: Delete parameters: clusterID: ceph-cluster csi.storage.k8s.io/snapshotter-secret-name: csi-rbd-secret csi.storage.k8s.io/snapshotter-secret-namespace: kube-system创建快照apiVersion: snapshot.storage.k8s.io/v1 kind: VolumeSnapshot metadata: name: app-snapshot namespace: default spec: volumeSnapshotClassName: csi-snapshot-class source: persistentVolumeClaimName: app-pvc从快照恢复apiVersion: v1 kind: PersistentVolumeClaim metadata: name: app-restored namespace: default spec: dataSource: name: app-snapshot kind: VolumeSnapshot apiGroup: snapshot.storage.k8s.io accessModes: - ReadWriteOnce resources: requests: storage: 10Gi storageClassName: standard4. 存储性能优化4.1 存储类型选择存储类型性能特点适用场景SSD高IOPS低延迟数据库缓存HDD大容量低成本归档备份NVMe极高IOPS极低延迟高性能计算实时分析4.2 存储参数调优文件系统选择ext4通用文件系统稳定可靠xfs大文件高性能btrfs快照数据压缩挂载选项apiVersion: v1 kind: PersistentVolume metadata: name: optimized-pv spec: capacity: storage: 100Gi accessModes: - ReadWriteOnce hostPath: path: /data/ssd mountOptions: - noatime - nodiratime - barrier0 - discard4.3 应用级优化数据库存储优化apiVersion: apps/v1 kind: StatefulSet metadata: name: postgres namespace: default spec: serviceName: postgres replicas: 1 selector: matchLabels: app: postgres template: metadata: labels: app: postgres spec: containers: - name: postgres image: postgres:13 env: - name: POSTGRES_PASSWORD value: password volumeMounts: - name: postgres-data mountPath: /var/lib/postgresql/data subPath: postgres volumeClaimTemplates: - metadata: name: postgres-data spec: accessModes: - ReadWriteOnce resources: requests: storage: 50Gi storageClassName: local-storage缓存存储优化apiVersion: apps/v1 kind: Deployment metadata: name: redis namespace: default spec: replicas: 1 selector: matchLabels: app: redis template: metadata: labels: app: redis spec: containers: - name: redis image: redis:6 command: - redis-server - --appendonly - yes volumeMounts: - name: redis-data mountPath: /data volumes: - name: redis-data persistentVolumeClaim: claimName: redis-pvc5. 存储监控与故障排查5.1 存储监控Prometheus存储指标apiVersion: monitoring.coreos.com/v1 kind: ServiceMonitor metadata: name: storage-monitor namespace: monitoring spec: selector: matchLabels: app: csi-node-driver-registrar namespaceSelector: matchNames: - kube-system endpoints: - port: metrics interval: 15sGrafana存储仪表板{ dashboard: { id: null, title: Storage Metrics, panels: [ { title: PV Usage, type: graph, targets: [ { expr: kubelet_volume_stats_available_bytes{namespace\default\} }, { expr: kubelet_volume_stats_used_bytes{namespace\default\} } ] }, { title: PVC Status, type: table, targets: [ { expr: kube_persistentvolumeclaim_status_phase{phase\Bound\} } ] } ] } }5.2 故障排查存储故障排查命令# 检查PV状态 kubectl get pv # 检查PVC状态 kubectl get pvc # 检查StorageClass kubectl get storageclass # 检查Pod存储卷 kubectl describe pod app-pod | grep -A 20 Volumes # 检查节点存储 kubectl describe node node1 | grep -A 10 Capacity # 查看存储事件 kubectl get events | grep -i storage常见存储问题排查问题排查命令可能原因PVC pendingkubectl describe pvc app-pvc无可用PVStorageClass配置错误Pod stuck in ContainerCreatingkubectl describe pod app-pod存储卷挂载失败权限问题存储性能慢iostat -x 1存储IO瓶颈文件系统问题存储容量不足kubectl exec -it app-pod -- df -hPVC容量不足需要扩容6. 存储安全6.1 数据加密使用加密存储类apiVersion: storage.k8s.io/v1 kind: StorageClass metadata: name: encrypted-storage provisioner: kubernetes.io/aws-ebs parameters: type: gp2 encrypted: true reclaimPolicy: Delete allowVolumeExpansion: true使用KMS加密apiVersion: storage.k8s.io/v1 kind: StorageClass metadata: name: kms-encrypted provisioner: kubernetes.io/aws-ebs parameters: type: gp2 encrypted: true kmsKeyId: arn:aws:kms:us-east-1:123456789012:key/12345678-1234-1234-1234-123456789012 reclaimPolicy: Delete allowVolumeExpansion: true6.2 访问控制使用RBAC控制存储资源apiVersion: rbac.authorization.k8s.io/v1 kind: Role metadata: name: storage-manager namespace: default rules: - apiGroups: [] resources: [persistentvolumes, persistentvolumeclaims] verbs: [get, list, create, delete] - apiGroups: [storage.k8s.io] resources: [storageclasses] verbs: [get, list] --- apiVersion: rbac.authorization.k8s.io/v1 kind: RoleBinding metadata: name: storage-manager-binding namespace: default subjects: - kind: User name: admin apiGroup: rbac.authorization.k8s.io roleRef: kind: Role name: storage-manager apiGroup: rbac.authorization.k8s.io7. 多集群存储7.1 跨集群存储使用Rook Ceph# 安装Rook kubectl create -f https://raw.githubusercontent.com/rook/rook/master/deploy/examples/common.yaml kubectl create -f https://raw.githubusercontent.com/rook/rook/master/deploy/examples/operator.yaml kubectl create -f https://raw.githubusercontent.com/rook/rook/master/deploy/examples/cluster.yaml创建跨集群存储类apiVersion: storage.k8s.io/v1 kind: StorageClass metadata: name: rook-ceph-block provisioner: rook-ceph.rbd.csi.ceph.com parameters: clusterID: rook-ceph pool: replicapool imageFormat: 2 imageFeatures: layering csi.storage.k8s.io/provisioner-secret-name: rook-csi-rbd-provisioner csi.storage.k8s.io/provisioner-secret-namespace: rook-ceph csi.storage.k8s.io/controller-expand-secret-name: rook-csi-rbd-provisioner csi.storage.k8s.io/controller-expand-secret-namespace: rook-ceph csi.storage.k8s.io/node-stage-secret-name: rook-csi-rbd-node csi.storage.k8s.io/node-stage-secret-namespace: rook-ceph reclaimPolicy: Delete allowVolumeExpansion: true volumeBindingMode: Immediate7.2 存储同步使用Velero进行备份# 安装Velero velero install \ --provider aws \ --plugins velero/velero-plugin-for-aws:v1.2.0 \ --bucket velero \ --secret-file ./credentials-velero \ --backup-location-config regionus-east-1 \ --snapshot-location-config regionus-east-1 # 创建备份 velero backup create app-backup --include-namespaces default # 恢复备份 velero restore create --from-backup app-backup8. 最佳实践8.1 存储设计最佳实践选择合适的存储类型根据应用需求选择存储类型合理规划存储容量根据应用数据增长趋势规划存储容量使用StorageClass通过StorageClass统一管理存储配置实施存储备份定期备份重要数据监控存储使用实时监控存储使用情况和性能优化存储参数根据应用特点调整存储参数考虑高可用性使用分布式存储提高可靠性数据加密对敏感数据实施加密存储8.2 PVC管理最佳实践合理设置存储请求根据实际需求设置存储容量使用合适的访问模式根据应用需求选择访问模式启用存储扩容为需要增长的应用启用存储扩容管理存储生命周期及时清理不再使用的PVC使用标签管理为PVC添加标签便于管理8.3 性能优化最佳实践选择高性能存储对IO密集型应用使用SSD或NVMe调整挂载选项优化文件系统挂载选项使用本地存储对需要低延迟的应用使用本地存储实施缓存策略合理使用缓存减少存储IO优化应用配置根据存储特性调整应用配置9. 实践案例9.1 数据库存储配置PostgreSQL存储配置apiVersion: apps/v1 kind: StatefulSet metadata: name: postgres namespace: database spec: serviceName: postgres replicas: 3 selector: matchLabels: app: postgres template: metadata: labels: app: postgres spec: containers: - name: postgres image: postgres:13 env: - name: POSTGRES_PASSWORD valueFrom: secretKeyRef: name: postgres-secret key: password - name: POSTGRES_REPLICATION_PASSWORD valueFrom: secretKeyRef: name: postgres-secret key: replication-password ports: - containerPort: 5432 volumeMounts: - name: postgres-data mountPath: /var/lib/postgresql/data subPath: postgres volumeClaimTemplates: - metadata: name: postgres-data spec: accessModes: - ReadWriteOnce resources: requests: storage: 100Gi storageClassName: local-storage9.2 大规模存储部署Ceph存储集群配置apiVersion: ceph.rook.io/v1 kind: CephCluster metadata: name: rook-ceph namespace: rook-ceph spec: cephVersion: image: ceph/ceph:v16.2.7 dataDirHostPath: /var/lib/rook mon: count: 3 mgr: count: 1 osd: count: 6 storage: storageClassDeviceSets: - name: set1 count: 6 portable: true resources: requests: cpu: 500m memory: 1Gi limits: cpu: 2 memory: 4Gi placement: labels: rook.io/osd: true volumeClaimTemplates: - metadata: name: data spec: accessModes: - ReadWriteOnce resources: requests: storage: 100Gi storageClassName: local-storage10. 总结Kubernetes与存储管理最佳实践需要考虑以下因素存储模型理解Kubernetes存储模型的核心概念存储选择根据应用需求选择合适的存储类型存储配置合理配置PV、PVC和StorageClass性能优化调整存储参数和应用配置提高性能监控与排查部署存储监控及时发现和解决问题存储安全实施数据加密和访问控制多集群存储规划跨集群存储方案最佳实践遵循存储设计和管理的最佳实践通过以上实践可以构建一个高效、可靠、安全的存储环境为应用提供良好的存储支持确保数据的安全和可用性。

相关文章:

Kubernetes与存储管理最佳实践

Kubernetes与存储管理最佳实践 1. Kubernetes存储模型 Kubernetes存储模型定义了如何在容器化环境中管理和使用存储资源,是集群存储管理的基础。 1.1 存储模型核心概念 Volume:Pod中的存储卷,可被多个容器共享PersistentVolume (PV)&#xff…...

CodeSys自定义HTML5控件:从零构建到工程部署的实战指南

1. 为什么需要自定义HTML5控件? 在工业自动化领域,CodeSys作为主流的PLC编程环境,其WebVisu功能允许工程师创建可视化界面。但默认控件库往往无法满足特定需求,比如: 需要展示实时数据曲线图而非简单数值要求特殊交互…...

终极解决ComfyUI-Florence2模型加载问题的完整指南

终极解决ComfyUI-Florence2模型加载问题的完整指南 【免费下载链接】ComfyUI-Florence2 Inference Microsoft Florence2 VLM 项目地址: https://gitcode.com/gh_mirrors/co/ComfyUI-Florence2 如果您正在使用ComfyUI-Florence2视觉语言模型却遇到了加载失败的问题&#…...

GPU集群网络优化实战:万兆以太网 vs InfiniBand,哪种更适合你的AI训练任务?

GPU集群网络优化实战:万兆以太网 vs InfiniBand,哪种更适合你的AI训练任务? 在构建高性能GPU集群时,网络架构的选择往往成为决定整体性能的关键因素。想象一下,当你的AI模型需要处理海量参数更新时,网络带宽…...

OpenClaw性能调优:Qwen3-4B-Thinking-2507-GPT-5-Codex-Distill-GGUF长文本处理技巧

OpenClaw性能调优:Qwen3-4B-Thinking-2507-GPT-5-Codex-Distill-GGUF长文本处理技巧 1. 为什么需要长文本优化 上周我尝试用OpenClaw处理一份200页的技术文档摘要任务时,遭遇了典型的"长文本困境"——模型要么漏掉关键段落,要么生…...

AI聚类算法的代码案例实现

AI聚类算法的代码案例实现...

【KS-Downloader】快手无水印内容获取开源工具技术解析

【KS-Downloader】快手无水印内容获取开源工具技术解析 【免费下载链接】KS-Downloader 快手(KuaiShou)视频/图片下载工具;数据采集工具 项目地址: https://gitcode.com/gh_mirrors/ks/KS-Downloader 在短视频内容创作领域&#xff0c…...

SOLIDWORKS自定义属性模板制作全攻略:从零开始驱动模型参数

SOLIDWORKS自定义属性模板制作全攻略:从零开始驱动模型参数 在机械设计领域,SOLIDWORKS作为主流的三维CAD软件,其自定义属性功能往往被初学者低估。想象一下这样的场景:当你需要批量修改上百个零件的材料规格时,是否还…...

4步永久保存青春记忆:GetQzonehistory让QQ空间备份如此简单

4步永久保存青春记忆:GetQzonehistory让QQ空间备份如此简单 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 在数字时代,我们的青春记忆常常散落在各种社交平台中…...

如何通过系统性抗体研发服务加速创新药物开发?

一、为何现代抗体药物研发需要系统性技术支撑?抗体药物作为生物制药领域的核心组成部分,在肿瘤、自身免疫疾病、神经系统疾病等重大疾病治疗中展现出革命性潜力。然而,从靶点验证到临床候选分子确立的研发过程充满复杂挑战:抗体分…...

别再让设备突然罢工!手把手教你用MATLAB搞预测性维护(附往复泵故障诊断实战)

别再让设备突然罢工!手把手教你用MATLAB搞预测性维护(附往复泵故障诊断实战) 设备突然停机造成的损失有多严重?某化工厂曾因关键泵组突发故障导致全线停产36小时,直接经济损失超过200万元。这种场景在工业领域并不罕见…...

别只盯着Flag!从‘金盾信安杯’赛题看企业级安全实战:文件上传、源码泄露与RSA的坑

企业安全实战:从CTF赛题到真实威胁的防御之道 当安全工程师们在CTF竞赛中破解一道道赛题时,很少有人意识到这些看似游戏化的挑战背后,隐藏着企业安全防护体系中最致命的漏洞原型。本文将带您穿越虚拟赛场与真实战场之间的界限,揭示…...

VS2015+C++实战:手把手教你用海康MVS里的Demo搞定多相机同步采图与保存

VS2015C实战:海康MVS工业相机多机同步采图全流程解析 工业视觉检测系统中,多相机同步采图是个经典需求。上周帮朋友调试8台海康威视相机组成的检测线时,发现网上完整案例实在太少。今天我就以VS2015开发环境为例,带大家深入MVS安装…...

3个高效步骤掌握Godot PCK解析与资源提取技术

3个高效步骤掌握Godot PCK解析与资源提取技术 【免费下载链接】godot-unpacker godot .pck unpacker 项目地址: https://gitcode.com/gh_mirrors/go/godot-unpacker Godot引擎作为开源游戏开发框架的代表,其特有的PCK资源打包格式为游戏分发提供了便利&#…...

Qwen3.5-2B图文对话教程:‘描述这张图’‘提取表格数据’‘生成营销文案’三类实操

Qwen3.5-2B图文对话教程:描述这张图提取表格数据生成营销文案三类实操 1. 认识Qwen3.5-2B轻量化多模态模型 Qwen3.5-2B是阿里云推出的轻量化多模态基础模型,属于Qwen3.5系列的小参数版本(20亿参数)。这个模型特别适合在资源有限…...

如何快速打造现代化Windows提示界面:ModernFlyouts终极指南

如何快速打造现代化Windows提示界面:ModernFlyouts终极指南 【免费下载链接】ModernFlyouts A modern Fluent Design replacement for the old Metro themed flyouts present in Windows. 项目地址: https://gitcode.com/gh_mirrors/mo/ModernFlyouts 你是否…...

手把手排查 DeepSpeed CPUAdam 报错:从 AttributeError 到成功编译 Op 的完整日志分析

深度解析DeepSpeed CPUAdam编译报错:从日志分析到精准修复 当你第一次看到AttributeError: DeepSpeedCPUAdam object has no attribute ds_opt_adam这个错误时,可能会感到困惑。这个错误背后隐藏着DeepSpeed框架中CPUAdam优化器与CUDA环境之间复杂的交互…...

QMCFLAC2MP3终极指南:一键解锁QQ音乐格式限制的完整解决方案

QMCFLAC2MP3终极指南:一键解锁QQ音乐格式限制的完整解决方案 【免费下载链接】qmcflac2mp3 直接将qmcflac文件转换成mp3文件,突破QQ音乐的格式限制 项目地址: https://gitcode.com/gh_mirrors/qm/qmcflac2mp3 你是否曾经从QQ音乐下载了心爱的歌曲…...

从ARXML文件反推软件架构:一个ComM模块的配置实例如何映射到你的C代码

从ARXML到C代码:ComM模块配置的逆向工程实战 当你第一次打开ComM_Cfg_SWCD.arxml文件时,那些层层嵌套的XML标签是否让你感到无从下手?作为AUTOSAR开发中最关键的配置文件之一,ARXML实际上是一张精确的"施工图纸"&#x…...

禅道16.4开源版二次开发实战:手把手教你给测试用例新增“测试方式”字段(附完整代码)

禅道16.4开源版二次开发实战:从零构建测试方式字段全流程指南 当测试团队同时管理手工与自动化用例时,原生禅道系统缺少测试类型标识字段的问题会直接导致统计混乱。上周我接手的一个金融项目就遇到这种情况——自动化测试报告总是混入手工用例数据。经过…...

4步解放炉石玩家:开源脚本工具从配置到精通全指南

4步解放炉石玩家:开源脚本工具从配置到精通全指南 【免费下载链接】Hearthstone-Script Hearthstone script(炉石传说脚本) 项目地址: https://gitcode.com/gh_mirrors/he/Hearthstone-Script 你是否也曾遇到这样的困境:每…...

模型蒸馏与量化:为什么大厂急需能把大模型跑在边缘端的SDE?

在2026年的北美科技求职市场中,人工智能的下半场战役已经悄然转移了阵地。当行业内绝大多数求职者还在简历上堆砌“熟练调用大语言模型API”或“基于LangChain构建应用”时,北美头部科技公司(如Apple、Google、Meta)的招聘重心已经…...

新手挖洞实录:我是如何通过一个Vue站点的逻辑缺陷拿到Shell的

从零到一的渗透实战:一位安全新手的Vue站点突破之旅 第一次成功getshell的感觉,就像在黑暗中摸索许久后突然找到开关——那种豁然开朗的兴奋感至今难忘。作为刚踏入安全领域的新人,我决定记录下这段从资产发现到最终突破的完整历程&#xff…...

手把手教你用STM32的ADC读取PT100模块,实现高精度温度采集(附完整代码)

基于STM32的PT100高精度温度采集系统设计与实现 在工业控制和精密测量领域,温度监测的准确性往往直接影响产品质量和生产安全。PT100作为最常用的温度传感器之一,凭借其优异的线性度和稳定性,成为众多工程师的首选。本文将深入探讨如何利用ST…...

八股文的终结:为什么2026年大厂面试开始大规模考察“内存安全”?

在2026年的北美IT求职市场中,底层系统开发(Infrastructure, Backend, Systems Engineering)岗位的技术面试逻辑正在经历一场深刻的底层范式转换。过去几年中,候选人凭借熟练背诵C虚函数表、STL底层源码剖析、以及各类设计模式等标…...

三菱FX2N与士林变频器MODBUS通讯实战指南

1. 硬件连接:从零搭建通讯桥梁 第一次接触三菱FX2N和士林变频器的MODBUS通讯时,最让我头疼的就是硬件接线。别看只是几根线,接错了轻则通讯失败,重则烧毁端口。这里分享几个实操中容易踩的坑: 变频器端接线要点&#x…...

3分钟掌握Playnite便携版:打造你的移动游戏库管理中心

3分钟掌握Playnite便携版:打造你的移动游戏库管理中心 【免费下载链接】Playnite Video game library manager with support for wide range of 3rd party libraries and game emulation support, providing one unified interface for your games. 项目地址: htt…...

避坑指南:微信小程序Painter 2.0海报插件常见问题与优化技巧

避坑指南:微信小程序Painter 2.0海报插件深度优化实战 最近在帮客户重构小程序海报生成功能时,我重新审视了Painter 2.0这个老牌插件。不得不说,经过多次迭代后,它的功能确实强大到令人惊喜——支持从基础文本绘制到复杂阴影效果&…...

如何快速解锁NCM音乐格式:ncmppGui完全指南

如何快速解锁NCM音乐格式:ncmppGui完全指南 【免费下载链接】ncmppGui 一个使用C编写的极速ncm转换GUI工具 项目地址: https://gitcode.com/gh_mirrors/nc/ncmppGui 你是否曾经遇到过这样的情况:从音乐平台下载的歌曲只能在特定应用中播放&#x…...

[GDOUCTF 2023]<ez_ze> SSTI 绕过数字与大括号过滤的实战技巧

1. SSTI注入基础与ez_ze题目背景 SSTI(Server-Side Template Injection)服务器端模板注入是Web安全中常见的漏洞类型,它允许攻击者通过构造恶意模板表达式在服务器端执行任意代码。在CTF竞赛中,这类题目往往通过过滤关键字符来增加…...