首页
/ 在bbotte项目中利用PowerShell自动化创建Azure云主机指南

在bbotte项目中利用PowerShell自动化创建Azure云主机指南

2025-07-01 22:46:11作者:毕习沙Eudora

前言

在云计算环境中,自动化创建和管理虚拟机是提高运维效率的关键。本文将详细介绍如何在Azure云平台上使用PowerShell脚本自动化创建Linux主机,这是bbotte项目中的一个重要技术实践。

准备工作

1. 环境要求

  • Azure中国区账号(必须使用AzureChinaCloud环境)
  • PowerShell 4.3.1或更高版本
  • Azure PowerShell模块

2. 安装配置

首先需要安装Azure PowerShell模块,可以通过Web平台安装器获取最新版本。

创建自定义镜像

在Azure ARM模式下,我们需要先创建自定义镜像作为后续批量创建主机的模板。

1. 准备基础虚拟机

  1. 创建一台基础虚拟机并完成系统配置
  2. 对于Linux系统,执行一般化操作:
    waagent -deprovision
    
    此命令会清除系统特定信息,使镜像可以用于创建新实例。

2. 标记虚拟机为一般化状态

使用PowerShell将虚拟机标记为Generalized状态:

Set-AzureRmVM -ResourceGroupName <资源组名称> -Name <虚拟机名称> -Generalized

3. 保存虚拟机镜像

Save-AzureRmVMImage -ResourceGroupName <资源组名称> -VMName <虚拟机名称> -DestinationContainerName <容器名称> -VHDNamePrefix <VHD名称前缀>

注意事项

  • 容器名称必须为3-63个小写字母或连字符组成
  • ARM模式下捕获镜像后原虚拟机不会自动删除

使用PowerShell创建主机

1. 登录Azure

Login-AzureRmAccount -EnvironmentName AzureChinaCloud

2. 基础参数设置

$username = "adminuser";
$passwd = ConvertTo-SecureString "yourpassword" -AsPlainText -Force;
$cred = New-Object System.Management.Automation.PSCredential($username, $passwd);
$location = "China East";
$resourceGroup = "test-service";
$storageAccount = "teststorage";
$sourceImageUri = "https://storageaccount.blob.core.chinacloudapi.cn/system/Microsoft.Compute/Images/container/imagename.vhd";

3. 网络配置

创建网络安全组规则

$nsgRuleSSH = New-AzureRmNetworkSecurityRuleConfig -Name ssh-rule -Protocol Tcp `
-Direction Inbound -Priority 1000 -SourceAddressPrefix * -SourcePortRange * `
-DestinationAddressPrefix * -DestinationPortRange 22 -Access Allow

创建网络安全组

$nsg = New-AzureRmNetworkSecurityGroup -ResourceGroupName $resourceGroup `
-Location $location -Name "my-nsg" -SecurityRules $nsgRuleSSH

4. 批量创建主机脚本

for ($i = 1; $i -lt 5; $i++) {
    # 设置主机名称
    $vmName = "host-$i"
    
    # 创建公网IP
    $publicIP = New-AzureRmPublicIpAddress -Name "$vmName-ip" `
    -ResourceGroupName $resourceGroup -Location $location -AllocationMethod Dynamic
    
    # 创建网络接口
    $nic = New-AzureRmNetworkInterface -Name "$vmName-nic" `
    -ResourceGroupName $resourceGroup -Location $location `
    -SubnetId $subnet.Id -PublicIpAddressId $publicIP.Id `
    -NetworkSecurityGroupId $nsg.Id
    
    # 配置虚拟机参数
    $vmConfig = New-AzureRmVMConfig -VMName $vmName -VMSize "Standard_DS1_v2"
    Set-AzureRmVMOperatingSystem -VM $vmConfig -Linux -ComputerName $vmName -Credential $cred
    Set-AzureRmVMOSDisk -VM $vmConfig -Name "$vmName-osdisk" -VhdUri "https://$storageAccount.blob.core.chinacloudapi.cn/vhds/$vmName.vhd" `
    -SourceImageUri $sourceImageUri -Caching ReadWrite -CreateOption FromImage -Linux
    
    # 添加网络接口
    Add-AzureRmVMNetworkInterface -VM $vmConfig -Id $nic.Id -Primary
    
    # 创建虚拟机
    New-AzureRmVM -ResourceGroupName $resourceGroup -Location $location -VM $vmConfig
}

实用技巧

1. 密钥自动配置

为避免密码登录问题,建议使用SSH密钥认证。可以在自定义镜像中加入自动配置脚本:

#!/bin/bash
if [ ! -d /root/.ssh ]; then
    mkdir /root/.ssh
    chmod 700 /root/.ssh
fi

if ! grep -q "your-public-key" /root/.ssh/authorized_keys; then
    echo 'ssh-rsa AAAAB3Nz... your-key-comment' >> /root/.ssh/authorized_keys
fi

将此脚本设置为开机自动执行。

2. 静态IP配置

如需使用静态IP,可以在创建网络接口时指定:

$NIC = New-AzureRmNetworkInterface -Name "$vmName-nic" `
-ResourceGroupName $resourceGroup -Location $location `
-SubnetId $subnet.Id -PublicIpAddressId $publicIP.Id `
-NetworkSecurityGroupId $nsg.Id -PrivateIpAddress "10.0.0.10"

常见问题处理

  1. PowerShell版本兼容性问题:如果遇到接口错误,尝试升级PowerShell版本
  2. 镜像捕获失败:确保虚拟机已完全停止(已取消分配)状态
  3. 主机创建失败:检查资源配额是否足够

总结

通过本文介绍的方法,可以在bbotte项目中实现Azure云主机的自动化创建和管理。这种方法特别适合需要批量部署相同配置主机的场景,大大提高了运维效率和一致性。

关键点回顾:

  1. 必须先创建一般化镜像
  2. 使用PowerShell脚本可以灵活控制创建过程
  3. 合理配置网络和安全组确保访问安全
  4. 使用密钥认证提高安全性

掌握这些技能后,你将能够高效管理Azure云环境中的虚拟机资源。

登录后查看全文
热门项目推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
176
261
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
860
511
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
182
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
259
300
kernelkernel
deepin linux kernel
C
22
5
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
596
57
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
371
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
332
1.08 K