Qwen 2 VL 7B Instruct
Deploy Qwen 2 VL 7B Instruct with vLLM on Koyeb GPU for high-performance, low-latency, and efficient inference.
Deploy Qwen 2 VL 7B Instruct vision-language model on Koyeb’s high-performance cloud infrastructure.
With one click, get a dedicated GPU-powered inference endpoint ready to handle requests with built-in autoscaling and scale-to-zero.
Overview of Qwen 2 VL 7B Instruct
Part of the Qwen 2 VL family, Qwen 2 VL 7B Instruct is an advanced open-source vision-language model. With 7 billion parameters, it is purpose-built for tasks that involve both visual and textual understanding, including image captioning, visual question answering, and content generation.
Qwen 2 VL 7B Instruct will be served using vLLM inference engine, optimized for high-throughput and low-latency model serving.
The default GPU for running this model is the Nvidia A100 instance type. You are free to adjust the GPU instance type to fit your workload requirements.
Quickstart
The Qwen 2 VL 7B Instruct one-click model is powered by the vLLM engine. vLLM is an advanced inference engine designed for high-throughput and low-latency model serving. Optimized for large language models, it provides efficient performance and compatibility with the OpenAI API.
After you deploy the model, copy the Koyeb App public URL similar to https://<YOUR_DOMAIN_PREFIX>.koyeb.app
and create a simple Python file with the following content to start interacting with the model.
import os
from openai import OpenAI
client = OpenAI(
api_key=os.environ.get("OPENAI_API_KEY", "fake"),
base_url="https://<YOUR_DOMAIN_PREFIX>.koyeb.app/v1",
)
chat_completion = client.chat.completions.create(
messages=[
{
"role": "user",
"content": [
{
"type": "image_url",
"image_url": {
"url": "https://images.unsplash.com/photo-1506744038136-46273834b3fb"
},
},
{"type": "text", "text": "Describe the image."},
],
},
],
model="Qwen/Qwen2-VL-7B-Instruct",
max_tokens=50,
)
print(chat_completion.to_json(indent=4))
The snippet above is using the OpenAI SDK to interact with the Qwen 2 VL 7B Instruct model thanks to vLLM's OpenAI compatibility.
Take care to replace the base_url
value in the snippet with your Koyeb App public URL.
Executing the Python script will return the model's response to the input message.
python main.py
{
"id": "chatcmpl-1fd06c88-1c42-92ae-ae2b-b4ebfa01b471",
"choices": [
{
"finish_reason": "length",
"index": 0,
"logprobs": null,
"message": {
"content": "The image depicts a serene mountain landscape at sunset. The sky is tinged with a soft orange and pink hue, indicating the sun is either rising or setting. In the foreground, there is a small, shallow river flowing gently. The river is lined",
"role": "assistant",
"tool_calls": []
},
"stop_reason": null
}
],
"created": 1736951431,
"model": "Qwen/Qwen2-VL-7B-Instruct",
"object": "chat.completion",
"usage": {
"completion_tokens": 50,
"prompt_tokens": 16249,
"total_tokens": 16299,
"prompt_tokens_details": null
},
"prompt_logprobs": null
}
Securing the Inference Endpoint
To ensure that only authenticated requests are processed, we recommend setting up an API key to secure your inference endpoint. Follow these steps to configure the API key:
- Generate a strong, unique API key to use for authentication.
- Navigate to your Koyeb Service settings.
- Add a new environment variable named
VLLM_API_KEY
and set its value to your secret API key. - Save the changes and redeploy to update the service.
Once the service is updated, all requests to the inference endpoint will require the API key.
When making requests, ensure the API key is included in the headers. If you are using the OpenAI SDK, you can provide the API key through the api_key
parameter when instantiating the OpenAI client. Alternatively, you can set the API key using the OPENAI_API_KEY
environment variable. For example:
OPENAI_API_KEY=<YOUR_API_KEY> python main.py