Provisionando Fedora CoreOS Na Cloud Alibaba (Aliyun)
Esse guia mostra como provisionar novos nós Fedora CoreOS (FCOS) na Cloud Alibaba. Fedora atualmente não publica imagens do Fedora CoreOS com a Cloud Alibaba, então você deve baixar uma imagem Cloud Alibaba do Fedora e realizar o upload da imagem para um de seus baldes Serviços de Armazenamento de Objeto (OSS).
Pré-Requisitos
Antes de provisionar uma máquina FCOS, você deve ter um arquivo de configuração do Ignition contendo suas personalizações. Se você não tiver um, consulte Produzindo um arquivo de Ignition.
Fedora CoreOS has a default core user that can be used to explore the OS. If you want to use it, finalize its configuration by providing e.g. an SSH key.
|
If you do not want to use Ignition to get started, you can make use of the Afterburn support.
Você também precisa ter acesso a uma conta Cloud Alibaba e Serviço de Armazenamento de Objeto (OSS) Ativado. Os exemplos abaixo usam a CLI da Cloud Alibaba e jq como um processador JSON de linha de comando.
Baixando uma imagem de Cloud Alibaba
Fedora CoreOS é designado para ser atualizado automaticamente, com diferentes rotinas por stream. Uma vez que vocẽ tenha escolhido a stream relevante. baixe, verifique, e descomprima a última imagem Cloud Alibaba:
STREAM="stable"
coreos-installer download --decompress -s "${STREAM}" -p aliyun -f qcow2.xz
Alternativamente, você pode manualmente baixar uma imagem Cloud Alibaba da página de Downloads. Verificar o download, seguindo as intruçõesn essa página, e descomprimir.
Atualizando a imagem para Cloud Alibaba
-
Crie qualquer balde que ainda não exista na sua conta Cloud Alibaba com um nome único ou reuse um balde existente:
Exemplo criando um balde OSS Cloud Alibaba (Serviço de Armazenamento de Objeto)REGION="ap-southeast-1" BUCKET_NAME="meu-balde" BUCKET_URL="oss://${NOME_BALDE}" aliyun oss mb "${BUCKET_URL}" --region="${REGION}" --acl=private
-
Realizando o Upload de uma imagem FCOS:
Exemplo realizando o upload do FCOS para um balde OSS Cloud AlibabaDOWNLOADED_IMAGE="./image.qcow2" IMAGE_NAME="my-fcos-image" IMAGE_BLOB="${IMAGE_NAME}.qcow2" aliyun oss cp "${DOWNLOADED_IMAGE}" "${BUCKET_URL}/${IMAGE_BLOB}" \ --region="${REGION}" --acl=private
-
Importe a imagem FCOS que sofreu upload:
Exemplo importando FCOS para ECS Cloud AlibabaTASK_ID=$(aliyun ecs ImportImage \ --region="${REGION}" \ --DiskDeviceMapping.1.OSSBucket="${BUCKET_NAME}" \ --DiskDeviceMapping.1.OSSObject="${IMAGE_BLOB}" \ --ImageName="${IMAGE_NAME}" \ | jq --raw-output .TaskId)
-
Espere até que imagem seja importada com sucesso
Exemplo esperando um limite de tempo igual a uma horaaliyun ecs DescribeTasks --region="${REGION}" --TaskIds="${TASK_ID}" \ --waiter expr='TaskSet.Task[0].TaskStatus' to=Finished timeout=3600
-
ID determinante da Imagem FCOS importada:
Exemplo determinando ID da imagem FCOS importadaIMAGE_ID=$(aliyun ecs DescribeImages --region="${REGION}" --ImageName="${IMAGE_NAME}" \ | jq --raw-output .Images.Image[0].ImageId)
-
Delete o blob que sofreu upload
Exemplo deletando blob que sofreu uploadaliyun oss rm "${BUCKET_URL}/${IMAGE_BLOB}" --region "${REGION}"
Criando um VSwitch
Não há VPCs ou VSwitches default na Cloud Alibaba. Então, para criar qualquer instância, um VSwitch deve existir. Escolha alguma existente ou crie uma com os seguintes passos.
-
Crie um novo VPC:
Exemplo criando um novo VPCVPC_CIDR="172.16.0.0/12" VPC_NAME="fcos-test" VPC_ID=$(aliyun vpc CreateVpc --region="${REGION}" \ --CidrBlock="${VPC_CIDR}" --VpcName="${VPC_NAME}" \ | jq --raw-output .VpcId)
-
Escolha alguma zona disponível para criar um VSwitch:
Exemplo escolhendo uma zona disponívelZONE_ID=$(aliyun ecs DescribeZones --region="${REGION}" \ | jq --raw-output .Zones.Zone[0].ZoneId)
-
Criando um novo VSwitch:
Exemplo criando um novo VSwitchVSWITCH_CIDR="172.16.0.0/16" VSWITCH_NAME="${VPC_NAME}" VSWITCH_ID=$(aliyun vpc CreateVSwitch \ --region="${REGION}" \ --CidrBlock="${VSWITCH_CIDR}" \ --VpcId="${VPC_ID}" \ --VSwitchName="${VSWITCH_NAME}" \ --ZoneId="${ZONE_ID}" \ | jq --raw-output .VSwitchId)
Lançando uma instância ECS
-
Realizando o upload de uma chave pública SSH para um ECS Cloud Alibaba
Exemplo realizando o upload de uma chave SSHKEY_PAIR_NAME="fcos-key" PUBLIC_KEY_PATH="<Please fill the path to your public key>" PUBLIC_KEY_BODY=$(cat ${PUBLIC_KEY_PATH}) aliyun ecs ImportKeyPair --region="${REGION}" \ --KeyPairName="${KEY_PAIR_NAME}" --PublicKeyBody="${PUBLIC_KEY_BODY}"
-
Criando uma instância ECS
Exemplo criando instância ECSINSTANCE_NAME="my-fcos-vm" INSTANCE_TYPE="ecs.t6-c1m1.large" INSTANCE_ID=$(aliyun ecs CreateInstance \ --region="${REGION}" \ --KeyPairName="${KEY_PAIR_NAME}" \ --ImageId="${IMAGE_ID}" \ --InstanceName="${INSTANCE_NAME}" \ --InstanceType="${INSTANCE_TYPE}" \ --InternetChargeType=PayByTraffic \ --InternetMaxBandwidthIn=5 \ --InternetMaxBandwidthOut=5 \ --VSwitchId="${VSWITCH_ID}" \ | jq --raw-output .InstanceId)
-
Aloque um endereço IPv4 público para a instância criada previamente
Exemplo alocando um endereço de IPPUBLIC_IP=$(aliyun ecs AllocatePublicIpAddress \ --region="${REGION}" --InstanceId="${INSTANCE_ID}" \ | jq --raw-output .IpAddress)
-
Inicie a instância
Exemplo iniciando uma instânciaaliyun ecs StartInstance --region="${REGION}" --InstanceId="${INSTANCE_ID}"
-
Espere até que a instância esteja rodando
Exemplo esperando e determinando o endereço de IP públicoaliyun ecs DescribeInstanceStatus --InstanceId.1="$INSTANCE_ID" --region="${REGION}" \ --waiter expr='InstanceStatuses.InstanceStatus[0].Status' to=Running timeout=600
-
Conecte-se com a nova instância via SSH
Exemplo de conexãossh core@"${PUBLIC_IP}"
You can start a customized instance with your Ignition file by adding the parameter --UserData=$(cat <Path to your Ignition config> | base64 -w0)
to the aliyun ecs CreateInstance
command that creates a new instance.