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

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

2025-07-01 07:08:05作者:毕习沙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云环境中的虚拟机资源。

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

项目优选

收起
kernelkernel
deepin linux kernel
C
22
6
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
162
2.05 K
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
96
15
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
199
279
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
60
16
Git4ResearchGit4Research
Git4Research旨在构建一个开放、包容、协作的研究社区,让更多人能够参与到科学研究中,共同推动知识的进步。
HTML
23
1
apintoapinto
基于golang开发的网关。具有各种插件,可以自行扩展,即插即用。此外,它可以快速帮助企业管理API服务,提高API服务的稳定性和安全性。
Go
22
0
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
950
557
risc-v64-naruto-pirisc-v64-naruto-pi
基于QEMU构建的RISC-V64 SOC,支持Linux,baremetal, RTOS等,适合用来学习Linux,后续还会添加大量的controller,实现无需实体开发板,即可学习Linux和RISC-V架构
C
19
5