Esta guía proporciona instrucciones paso a paso para implementar los modelos Llama 4 de Meta (Scout y Maverick) en tres plataformas principales: AWS, Azure y Hugging Face. Estos modelos ofrecen capacidades avanzadas que incluyen procesamiento multimodal, ventanas de contexto masivas y rendimiento de última generación.

Requisitos previos y requisitos de hardware para la implementación de Llama 4
- Acceso a los modelos Llama 4 a través del acuerdo de licencia de Meta
- Cuenta de Hugging Face con token de acceso READ
- Cuenta AWS, Azure o Hugging Face Pro según sea necesario para tu objetivo de implementación
- Comprensión básica de la contenedorización y los servicios en la nube
AWS (a través de TensorFuse)
- Scout: 8 GPU H100 para contexto de 1 millón de tokens
- Maverick: 8 GPU H100 para contexto de 430K tokens
- Alternativa: 8 GPU A100 (ventana de contexto reducida)
Azure
(Esto se alinea con la guía general de Azure ML para modelos de lenguaje grandes, pero no se encontró documentación específica de Llama 4 para confirmar los requisitos exactos).
- Recomendado: ND A100 v4-series (8 GPU NVIDIA A100)
- Mínimo: Standard_ND40rs_v2 o superior
Hugging Face
- Recomendado: hardware A10G-Large Space
- Alternativa: A100-Large (opción de hardware premium)
- El hardware de nivel gratuito es insuficiente para modelos completos
1. Implementación de Llama 4 en AWS usando TensorFuse
1.1 Configurar AWS y TensorFuse
Instala TensorFuse CLI:
pip install tensorfuse
Configura las credenciales de AWS:
aws configure
Inicializa TensorFuse con tu cuenta de AWS:
tensorkube init
1.2 Crear secretos requeridos
Guarda tu token de Hugging Face:
tensorkube secret create hugging-face-secret YOUR_HF_TOKEN --env default HUGGING_FACE_HUB_TOKEN=
Crea un token de autenticación de API:
tensorkube secret create vllm-token vllm-key --env default VLLM_API_KEY=
1.3 Crear Dockerfile para Llama 4
Para el modelo Scout:
FROM vllm/vllm-openai:v0.8.3
ENV HF_HUB_ENABLE_HF_TRANSFER=1
EXPOSE 80
ENTRYPOINT ["python3", "-m", "vllm.entrypoints.openai.api_server", \\\\
"--model", "meta-llama/Llama-4-Scout-17B-16E-Instruct", \\\\
"--dtype", "bfloat16", \\\\
"--trust-remote-code", \\\\
"--tensor-parallel-size", "8", \\\\
"--max-model-len", "1000000", \\\\
"--port", "80", \\\\
"--override-generation-config", "{\\\\"attn_temperature_tuning\\\\": true}", \\\\
"--limit-mm-per-prompt", "image=10", \\\\
"--kv-cache-dtype", "fp8", \\\\
"--api-key", "${VLLM_API_KEY}"]
Para el modelo Maverick:
FROM vllm/vllm-openai:v0.8.3
ENV HF_HUB_ENABLE_HF_TRANSFER=1
EXPOSE 80
ENTRYPOINT ["python3", "-m", "vllm.entrypoints.openai.api_server", \\\\
"--model", "meta-llama/Llama-4-Maverick-17B-128E-Instruct", \\\\
"--dtype", "bfloat16", \\\\
"--trust-remote-code", \\\\
"--tensor-parallel-size", "8", \\\\
"--max-model-len", "430000", \\\\
"--port", "80", \\\\
"--override-generation-config", "{\\\\"attn_temperature_tuning\\\\": true}", \\\\
"--limit-mm-per-prompt", "image=10", \\\\
"--kv-cache-dtype", "fp8", \\\\
"--api-key", "${VLLM_API_KEY}"]
1.4 Crear configuración de implementación
Crea deployment.yaml
:
gpus: 8
gpu_type: h100
secret:
- huggingfacesecret
- vllmtoken
min-scale: 1
readiness:
httpGet:
path: /health
port: 80
1.5 Implementar en AWS
Implementa tu servicio:
tensorkube deploy --config-file ./deployment.yaml
1.6 Accede a tu servicio implementado
Enumera las implementaciones para obtener la URL de tu punto final:
tensorkube deployment list
Prueba tu implementación:
curl --request POST \\\\
--url YOUR_APP_URL/v1/completions \\\\
--header 'Content-Type: application/json' \\\\
--header 'Authorization: Bearer vllm-key' \\\\
--data '{
"model": "meta-llama/Llama-4-Scout-17B-16E-Instruct",
"prompt": "Earth to Llama 4. What can you do?",
"max_tokens": 1000
}'
2. Implementación de Llama 4 en Azure
2.1 Configurar el espacio de trabajo de Azure ML
Instala Azure CLI y las extensiones de ML:
pip install azure-cli azure-ml
az login
Crea un espacio de trabajo de Azure ML:
az ml workspace create --name llama4-workspace --resource-group your-resource-group
2.2 Crear clúster de cálculo
az ml compute create --name llama4-cluster --type amlcompute --min-instances 0 \\\\
--max-instances 1 --size Standard_ND40rs_v2 --vnet-name your-vnet-name \\\\
--subnet your-subnet --resource-group your-resource-group --workspace-name llama4-workspace
2.3 Registrar el modelo Llama 4 en Azure ML
Crea model.yml
:
$schema: <https://azuremlschemas.azureedge.net/latest/model.schema.json>
name: llama-4-scout
version: 1
path: .
properties:
model_name: "meta-llama/Llama-4-Scout-17B-16E-Instruct"
Registra el modelo:
az ml model create --file model.yml --resource-group your-resource-group --workspace-name llama4-workspace
2.4 Crear configuración de implementación
Crea deployment.yml
:
$schema: <https://azuremlschemas.azureedge.net/latest/managedOnlineDeployment.schema.json>
name: llama4-deployment
endpoint_name: llama4-endpoint
model: azureml:llama-4-scout@latest
instance_type: Standard_ND40rs_v2
instance_count: 1
environment_variables:
HUGGING_FACE_HUB_TOKEN: ${{secrets.HF_TOKEN}}
VLLM_API_KEY: ${{secrets.VLLM_KEY}}
environment:
image: vllm/vllm-openai:v0.8.3
conda_file: conda.yml
Crea conda.yml
:
channels:
- conda-forge
dependencies:
- python=3.10
- pip
- pip:
- vllm==0.8.3
- transformers
- accelerate
2.5 Crear punto final e implementar
az ml online-endpoint create --name llama4-endpoint \\\\
--resource-group your-resource-group --workspace-name llama4-workspace
az ml online-deployment create --file deployment.yml \\\\
--resource-group your-resource-group --workspace-name llama4-workspace
2.6 Probar la implementación
az ml online-endpoint invoke --name llama4-endpoint --request-file request.json \\\\
--resource-group your-resource-group --workspace-name llama4-workspace
Donde request.json
contiene:
{
"model": "meta-llama/Llama-4-Scout-17B-16E-Instruct",
"prompt": "Earth to Llama 4. What can you do?",
"max_tokens": 1000
}
3. Implementación de Llama 4 en Hugging Face
3.1 Configurar la cuenta de Hugging Face
- Crea una cuenta de Hugging Face en https://huggingface.co/
- Acepta el acuerdo de licencia para los modelos Llama 4 en https://huggingface.co/meta-llama
3.2 Implementar usando Hugging Face Spaces
Navega a https://huggingface.co/spaces y haz clic en "Create new Space"
Configura tu Space:
- Name: llama4-deployment
- License: Selecciona la licencia apropiada
- SDK: Elige Gradio
- Space Hardware: A10G-Large (para el mejor rendimiento)
- Visibility: Privado o Público según tus necesidades
Clona el repositorio de Space:
git clone <https://huggingface.co/spaces/YOUR_USERNAME/llama4-deployment>
cd llama4-deployment
3.3 Crear archivos de aplicación
Crea app.py
:
import gradio as gr
import torch
from transformers import pipeline, AutoModelForCausalLM, AutoTokenizer
import os
# Add your HF token to environment or Secrets
os.environ["HUGGING_FACE_HUB_TOKEN"] = "YOUR_HF_TOKEN"
# Load model and tokenizer with appropriate configuration
model_id = "meta-llama/Llama-4-Scout-17B-16E-Instruct"
tokenizer = AutoTokenizer.from_pretrained(model_id)
model = AutoModelForCausalLM.from_pretrained(
model_id,
torch_dtype=torch.bfloat16,
device_map="auto",
trust_remote_code=True
)
# Create pipeline
pipe = pipeline(
"text-generation",
model=model,
tokenizer=tokenizer,
max_length=2048
)
def generate_text(prompt, max_length=1000, temperature=0.7):
# Format prompt according to Llama 4 format
formatted_prompt = f"<|begin_of_text|><|user|>\\\\n{prompt}<|end_of_text|>\\\\n<|assistant|>"
outputs = pipe(
formatted_prompt,
max_length=len(tokenizer.encode(formatted_prompt)) + max_length,
temperature=temperature,
do_sample=True,
)
return outputs[0]['generated_text'].replace(formatted_prompt, "")
# Create Gradio interface
demo = gr.Interface(
fn=generate_text,
inputs=[
gr.Textbox(lines=4, placeholder="Enter your prompt here...", label="Prompt"),
gr.Slider(minimum=100, maximum=2000, value=1000, step=100, label="Max Length"),
gr.Slider(minimum=0.1, maximum=1.0, value=0.7, step=0.1, label="Temperature")
],
outputs="text",
title="Llama 4 Demo",
description="Generate text using Meta's Llama 4 model",
)
demo.launch()
Crea requirements.txt
:
accelerate>=0.20.3
bitsandbytes>=0.41.1
gradio>=3.50.0
torch>=2.0.1
transformers>=4.34.0
3.4 Implementar en Hugging Face
Sube a tu Hugging Face Space:
git add app.py requirements.txt
git commit -m "Add Llama 4 deployment"
git push
3.5 Supervisar la implementación
- Visita la URL de tu Space: https://huggingface.co/spaces/YOUR_USERNAME/llama4-deployment
- La primera compilación tardará un tiempo, ya que necesita descargar y configurar el modelo
- Una vez implementado, verás una interfaz de Gradio donde puedes interactuar con el modelo
4. Pruebas e interacción con tus implementaciones
4.1 Uso del cliente de Python para el acceso a la API (AWS y Azure)
import openai
# For AWS
client = openai.OpenAI(
base_url="YOUR_AWS_URL/v1", # From tensorkube deployment list
api_key="vllm-key" # Your configured API key
)
# For Azure
client = openai.AzureOpenAI(
azure_endpoint="YOUR_AZURE_ENDPOINT",
api_key="YOUR_API_KEY",
api_version="2023-05-15"
)
# Make a text completion request
response = client.completions.create(
model="meta-llama/Llama-4-Scout-17B-16E-Instruct",
prompt="Write a short poem about artificial intelligence.",
max_tokens=200
)
print(response.choices[0].text)
# For multimodal capabilities (if supported)
import base64
# Load image as base64
with open("image.jpg", "rb") as image_file:
image_base64 = base64.b64encode(image_file.read()).decode('utf-8')
# Create chat completion with the image
response = client.chat.completions.create(
model="meta-llama/Llama-4-Scout-17B-16E-Instruct",
messages=[
{
"role": "user",
"content": [
{"type": "text", "text": "Describe this image:"},
{"type": "image_url", "image_url": {"url": f"data:image/jpeg;base64,{image_base64}"}}
]
}
],
max_tokens=300
)
print(response.choices[0].message.content)
Conclusión
Ahora tienes instrucciones paso a paso para implementar los modelos Llama 4 en AWS, Azure y Hugging Face. Cada plataforma ofrece diferentes ventajas:
- AWS con TensorFuse: control total, alta escalabilidad, mejor rendimiento
- Azure: integración con el ecosistema de Microsoft, servicios de ML gestionados
- Hugging Face: configuración más sencilla, ideal para prototipos y demostraciones
Elige la plataforma que mejor se adapte a tus requisitos específicos de coste, escala, rendimiento y facilidad de gestión.