腾讯云API SDK (Rust)
这是一个非官方的腾讯云API Rust SDK,提供了与腾讯云API进行交互的Rust实现。
目录
安装和环境配置
- 在Cargo.toml中添加依赖
- 设置环境变量
export TENCENTCLOUD_SECRET_ID="你的腾讯云SecretId"
export TENCENTCLOUD_SECRET_KEY="你的腾讯云SecretKey"
已实现功能
通用功能
- ✅ 腾讯云API签名V3算法完整实现
- ✅ HTTP客户端封装
- ✅ 统一的错误处理
地域与可用区管理
- ✅ 查询地域列表 (DescribeRegions)
- ✅ 查询可用区列表 (DescribeZones)
云服务器实例管理
使用方法
1. 查询地域和可用区
use tencent_cloud_sdk::{TencentCloudClient, services::region::RegionService};
let client = TencentCloudClient::new(secret_id, secret_key);
let region_service = RegionService::new(&client);
let regions = region_service.describe_regions().await?;
let zones = region_service.describe_zones("ap-guangzhou").await?;
2. 创建实例
use tencent_cloud_sdk::{
TencentCloudClient,
services::cvm::instance::{
InstanceService, RunInstancesRequest, Placement, LoginSettings,
SystemDisk, InstanceChargeType
}
};
let client = TencentCloudClient::new(secret_id, secret_key);
let instance_service = InstanceService::new(&client);
let request = RunInstancesRequest {
Placement: Some(Placement {
Zone: Some("ap-guangzhou-6".to_string()),
ProjectId: None,
HostIds: None,
HostIps: None,
DedicatedClusterId: None,
}),
ImageId: Some("img-6n21msk1".to_string()),
InstanceChargeType: Some(InstanceChargeType::Spotpaid), InstanceType: Some("S5.MEDIUM2".to_string()),
SystemDisk: Some(SystemDisk {
DiskType: Some("CLOUD_BSSD".to_string()),
DiskSize: Some(20),
DiskId: None,
}),
InstanceCount: Some(1),
LoginSettings: Some(LoginSettings {
Password: Some("Password123".to_string()),
KeyIds: None,
KeepImageLogin: None,
}),
VirtualPrivateCloud: None,
SecurityGroupIds: None,
InstanceName: Some("test-instance".to_string()),
};
let response = instance_service.run_instances(&request, "ap-guangzhou").await?;
3. 启动/关闭/重启实例
use tencent_cloud_sdk::{
TencentCloudClient,
services::cvm::instance_operation::{
InstanceOperationService, StartInstancesRequest, StopInstancesRequest, RebootInstancesRequest
}
};
let client = TencentCloudClient::new(secret_id, secret_key);
let instance_operation_service = InstanceOperationService::new(&client);
let region = "ap-guangzhou";
let start_request = StartInstancesRequest {
InstanceIds: vec!["ins-xxxxxxxx".to_string()],
};
let start_response = instance_operation_service.start_instances(&start_request, region).await?;
let stop_request = StopInstancesRequest {
InstanceIds: vec!["ins-xxxxxxxx".to_string()],
StopType: Some("SOFT".to_string()), StoppedMode: Some("KEEP_CHARGING".to_string()), ForceStop: None, };
let stop_response = instance_operation_service.stop_instances(&stop_request, region).await?;
let reboot_request = RebootInstancesRequest {
InstanceIds: vec!["ins-xxxxxxxx".to_string()],
StopType: Some("SOFT".to_string()), ForceReboot: None, };
let reboot_response = instance_operation_service.reboot_instances(&reboot_request, region).await?;
4. 查询实例
use tencent_cloud_sdk::{
TencentCloudClient,
services::cvm::instance_query::{InstanceQueryService, DescribeInstancesRequest},
services::cvm::instance::Filter
};
let client = TencentCloudClient::new(secret_id, secret_key);
let instance_query_service = InstanceQueryService::new(&client);
let region = "ap-guangzhou";
let id_request = DescribeInstancesRequest {
InstanceIds: Some(vec!["ins-xxxxxxxx".to_string()]),
Filters: None,
Offset: None,
Limit: None,
};
let id_response = instance_query_service.describe_instances(&id_request, region).await?;
let mut filters = Vec::new();
filters.push(Filter {
Name: "zone".to_string(),
Values: vec!["ap-guangzhou-6".to_string()],
});
let zone_request = DescribeInstancesRequest {
InstanceIds: None,
Filters: Some(filters),
Offset: None,
Limit: Some(20),
};
let zone_response = instance_query_service.describe_instances(&zone_request, region).await?;
let mut filters = Vec::new();
filters.push(Filter {
Name: "instance-state".to_string(),
Values: vec!["RUNNING".to_string()],
});
let state_request = DescribeInstancesRequest {
InstanceIds: None,
Filters: Some(filters),
Offset: None,
Limit: Some(20),
};
let state_response = instance_query_service.describe_instances(&state_request, region).await?;
5. 退还实例
use tencent_cloud_sdk::{
TencentCloudClient,
services::cvm::instance_operation::{InstanceOperationService, TerminateInstancesRequest}
};
let client = TencentCloudClient::new(secret_id, secret_key);
let instance_operation_service = InstanceOperationService::new(&client);
let request = TerminateInstancesRequest {
InstanceIds: vec!["ins-xxxxxxxx".to_string()],
ReleasePrepaidDataDisks: Some(false), };
let response = instance_operation_service.terminate_instances(&request, "ap-guangzhou").await?;
6. 实例询价
use tencent_cloud_sdk::{
TencentCloudClient,
services::cvm::instance_price::{
InstancePriceService, InquiryPriceRunInstancesRequest
},
services::cvm::instance::{
Placement, SystemDisk, InstanceChargeType, InstanceChargePrepaid
}
};
let client = TencentCloudClient::new(secret_id, secret_key);
let instance_price_service = InstancePriceService::new(&client);
let request = InquiryPriceRunInstancesRequest {
Placement: Placement {
Zone: Some("ap-guangzhou-4".to_string()),
ProjectId: None,
HostIds: None,
HostIps: None,
DedicatedClusterId: None,
},
ImageId: "img-eb30mz89".to_string(), InstanceType: "S5.MEDIUM2".to_string(), SystemDisk: Some(SystemDisk {
DiskType: Some("CLOUD_PREMIUM".to_string()), DiskSize: Some(50),
DiskId: None,
}),
InstanceChargeType: Some(InstanceChargeType::Prepaid),
InstanceChargePrepaid: Some(InstanceChargePrepaid {
Period: 1, RenewFlag: Some("NOTIFY_AND_AUTO_RENEW".to_string()), }),
DataDisks: None,
InternetAccessible: None,
InstanceCount: Some(1),
LoginSettings: None,
EnhancedService: None,
VirtualPrivateCloud: None,
};
let response = instance_price_service.inquiry_price_run_instances(&request, "ap-guangzhou").await?;
let instance_price = response.Response.Price.InstancePrice;
println!("实例价格: {}", instance_price.DiscountPrice.unwrap_or(0.0));
if let Some(bandwidth_price) = response.Response.Price.BandwidthPrice {
println!("带宽价格: {}", bandwidth_price.DiscountPrice.unwrap_or(0.0));
}
许可证
MIT许可证