feat: add CFS and DNSPod references, scripts, and update SKILL.md

This commit is contained in:
joee_yang
2026-03-27 18:48:01 +08:00
parent 1ef378f522
commit 3a01e0f23b

View File

@@ -0,0 +1,117 @@
# 存储资源COS / CFS
---
## COS 对象存储
### Bucket
```hcl
resource "tencentcloud_cos_bucket" "main" {
bucket = "${local.name_prefix}-${data.tencentcloud_user_info.current.app_id}"
acl = "private"
region = var.region
versioning_enable = false
lifecycle_rules {
filter_prefix = "logs/"
expiration {
days = 90
}
transition {
days = 30
storage_class = "STANDARD_IA"
}
}
tags = local.common_tags
}
data "tencentcloud_user_info" "current" {}
```
### 上传对象(示例)
```hcl
resource "tencentcloud_cos_bucket_object" "config" {
bucket = tencentcloud_cos_bucket.main.bucket
key = "configs/app.json"
content = jsonencode({ env = var.environment })
content_type = "application/json"
}
```
### Outputs
```hcl
output "cos_bucket_name" { value = tencentcloud_cos_bucket.main.bucket }
output "cos_bucket_url" { value = "https://${tencentcloud_cos_bucket.main.bucket}.cos.${var.region}.myqcloud.com" }
```
---
## CFS 文件存储
### CFS 文件系统
```hcl
resource "tencentcloud_cfs_file_system" "main" {
name = "${local.name_prefix}-cfs"
availability_zone = var.availability_zones[0]
access_group_id = tencentcloud_cfs_access_group.main.id
protocol = "NFS" # NFS 或 CIFS
storage_type = "SD" # SD=标准存储, HP=高性能存储
vpc_id = var.vpc_id
subnet_id = var.subnet_ids["private-a"]
tags = local.common_tags
}
```
### CFS 权限组
```hcl
resource "tencentcloud_cfs_access_group" "main" {
name = "${local.name_prefix}-cfs-ag"
description = "CFS 权限组 for ${var.environment}"
}
resource "tencentcloud_cfs_access_rule" "allow_vpc" {
access_group_id = tencentcloud_cfs_access_group.main.id
auth_client_ip = var.vpc_cidr # 允许整个 VPC CIDR 访问
priority = 1
rw_permission = "RWP" # RWP=读写, ROP=只读
user_permission = "no_squash"
}
```
### Outputs
```hcl
output "cfs_id" { value = tencentcloud_cfs_file_system.main.id }
output "cfs_mount_ip" { value = tencentcloud_cfs_file_system.main.mount_ip }
# 挂载命令: mount -t nfs -o vers=4 <mount_ip>:/ /mnt/cfs
```
### CVM 挂载 CFSuser_data 示例)
```hcl
locals {
cfs_mount_script = <<-EOT
#!/bin/bash
yum install -y nfs-utils
mkdir -p /mnt/cfs
mount -t nfs -o vers=4,noresvport ${tencentcloud_cfs_file_system.main.mount_ip}:/ /mnt/cfs
echo "${tencentcloud_cfs_file_system.main.mount_ip}:/ /mnt/cfs nfs vers=4,noresvport 0 0" >> /etc/fstab
EOT
}
```
---
## 安全注意事项
- CFS 应放在**私有子网**,不对公网暴露
- 权限组 `auth_client_ip` 收敛到 VPC CIDR避免 `0.0.0.0/0`
- COS Bucket ACL 默认 `private`,按需开启 CDN 或 Website 托管