Name | Modified | Size | Downloads / Week |
---|---|---|---|
Parent folder | |||
[v0.34.0] Announcing Jobs_ a new way to run compute on Hugging Face! source code.tar.gz | 2025-07-25 | 1.0 MB | |
[v0.34.0] Announcing Jobs_ a new way to run compute on Hugging Face! source code.zip | 2025-07-25 | 1.3 MB | |
README.md | 2025-07-25 | 9.7 kB | |
Totals: 3 Items | 2.4 MB | 0 |
๐ฅ๐ฅ๐ฅ Announcing Jobs: a new way to run compute on Hugging Face!
We're thrilled to introduce a powerful new command-line interface for running and managing compute jobs on Hugging Face infrastructure! With the new hf jobs
command, you can now seamlessly launch, monitor, and manage jobs using a familiar Docker-like experience. Run any command in Docker images (from Docker Hub, Hugging Face Spaces, or your own custom images) on a variety of hardware including CPUs, GPUs, and TPUs - all with simple, intuitive commands.
Key features:
- ๐ณ Docker-like CLI: Familiar commands (run
, ps
, logs
, inspect
, cancel
) to run and manage jobs
- ๐ฅ Any Hardware: Instantly access CPUs, T4/A10G/A100 GPUs, and TPUs with a simple flag
- ๐ฆ Run Anything: Use Docker images, HF Spaces, or custom containers
- ๐ Live Monitoring: Stream logs in real-time, just like running locally
- ๐ฐ Pay-as-you-go: Only pay for the seconds you use
- ๐งฌ UV Runner: Run Python scripts with inline dependencies using uv
(experimental)
All features are available both from Python (run_job
, list_jobs
, etc.) and the CLI (hf jobs
).
Example usage:
:::bash
# Run a Python script on the cloud
hf jobs run python:3.12 python -c "print('Hello from the cloud!')"
# Use a GPU
hf jobs run --flavor=t4-small --namespace=huggingface ubuntu nvidia-smi
# List your jobs
hf jobs ps
# Stream logs from a job
hf jobs logs <job-id>
# Inspect job details
hf jobs inspect <job-id>
# Cancel a running job
hf jobs cancel <job-id>
# Run a UV script (experimental)
hf jobs uv run my_script.py --flavor=a10g-small --with=trl
You can also pass environment variables and secrets, select hardware flavors, run jobs in organizations, and use the experimental uv
runner for Python scripts with inline dependencies.
Check out the Jobs guide for more examples and details.
- [Jobs] Add huggingface-cli jobs commands by @lhoestq [#3211]
- Rename huggingface-cli jobs to hf jobs by @Wauplin [#3250]
- Docs: link to jobs cli docs by @lhoestq [#3253]
- [Jobs] Mention PRO is required by @Wauplin [#3257]
๐ The CLI is now hf
! (formerly huggingface-cli
)
Glad to announce a long awaited quality-of-life improvement: the Hugging Face CLI has been officially renamed from huggingface-cli
to hf
! The legacy huggingface-cli
remains available without any breaking change, but is officially deprecated. We took the opportunity update the syntax to a more modern command format hf <resource> <action> [options]
(e.g. hf auth login
, hf repo create
, hf jobs run
).
Run hf --help
to know more about the CLI options.
:::bash
โ hf --help
usage: hf <command> [<args>]
positional arguments:
{auth,cache,download,jobs,repo,repo-files,upload,upload-large-folder,env,version,lfs-enable-largefiles,lfs-multipart-upload}
hf command helpers
auth Manage authentication (login, logout, etc.).
cache Manage local cache directory.
download Download files from the Hub
jobs Run and manage Jobs on the Hub.
repo Manage repos on the Hub.
repo-files Manage files in a repo on the Hub.
upload Upload a file or a folder to the Hub. Recommended for single-commit uploads.
upload-large-folder
Upload a large folder to the Hub. Recommended for resumable uploads.
env Print information about the environment.
version Print information about the hf version.
options:
-h, --help show this help message and exit
- Rename CLI to 'hf' + reorganize syntax by @Wauplin in [#3229]
- Rename huggingface-cli jobs to hf jobs by @Wauplin in [#3250]
โก Inference
๐ผ๏ธ Image-to-image
Added support for image-to-image
task in the InferenceClient
for Replicate and fal.ai providers, allowing quick image generation using FLUX.1-Kontext-dev:
:::py
from huggingface_hub import InferenceClient
client = InferenceClient(provider="fal-ai")
client = InferenceClient(provider="replicate")
with open("cat.png", "rb") as image_file:
input_image = image_file.read()
# output is a PIL.Image object
image = client.image_to_image(
input_image,
prompt="Turn the cat into a tiger.",
model="black-forest-labs/FLUX.1-Kontext-dev",
)
- [Inference Providers] add
image-to-image
support for Replicate provider by @hanouticelina in [#3188] - [Inference Providers] add
image-to-image
support for fal.ai provider by @hanouticelina in [#3187]
In addition to this, it is now possible to directly pass a PIL.Image
as input to the InferenceClient
.
- Add PIL Image support to InferenceClient by @NielsRogge in [#3199]
๐ค Tiny-Agents
tiny-agents
got a nice update to deal with environment variables and secrets. We've also changed its input format to follow more closely the config format from VSCode. Here is an up to date config to run Github MCP Server with a token:
:::js
{
"model": "Qwen/Qwen2.5-72B-Instruct",
"provider": "nebius",
"inputs": [
{
"type": "promptString",
"id": "github-personal-access-token",
"description": "Github Personal Access Token (read-only)",
"password": true
}
],
"servers": [
{
"type": "stdio",
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"-e",
"GITHUB_PERSONAL_ACCESS_TOKEN",
"-e",
"GITHUB_TOOLSETS=repos,issues,pull_requests",
"ghcr.io/github/github-mcp-server"
],
"env": {
"GITHUB_PERSONAL_ACCESS_TOKEN": "${input:github-personal-access-token}"
}
}
]
}
- [Tiny-Agent] Fix headers handling + secrets management by @Wauplin in [#3166]
- [tiny-agents] Configure inference API key from inputs + keep empty dicts in chat completion payload by @hanouticelina in [#3226]
๐ Bug fixes
InferenceClient
and tiny-agents
got a few quality of life improvements and bug fixes:
- Recursive filter_none in Inference Providers by @Wauplin in [#3178]
- [Inference] Remove default params values for text generation by @hanouticelina in [#3192]
- [Inference] Correctly build chat completion URL with query parameters by @hanouticelina in [#3200]
- Update tiny-agents example by @Wauplin in [#3205]
- Fix "failed to parse tools" due to mcp EXIT_LOOP_TOOLS not following the ChatCompletionInputFunctionDefinition model by @nicoloddo in [#3219]
- [Tiny agents] Add tool call to messages by @NielsRogge in [#3159]
- omit parameters for default tools in tiny-agent by @hanouticelina in [#3214]
๐ค Xet
Integration of Xet is now stable and production-ready. A majority of file transfer are now handled using this protocol on new repos. A few improvements have been shipped to ease developer experience during uploads:
- Improved progress reporting for Xet uploads by @hoytak in [#3096]
- upload large folder operations uses batches of files for preupload-lfs jobs for xet-enabled repositories by @assafvayner in [#3228]
- Override xet refresh route's base URL with HF Endpoint by @hanouticelina in [#3180]
Documentation has already been written to explain better the protocol and its options:
- Updates to Xet upload/download docs by @jsulz in [#3174]
- Updating Xet caching docs by @jsulz in [#3190]
- Suppress xet install WARN if HF_HUB_DISABLE_XET by @rajatarya in [#3206]
๐ ๏ธ Small fixes and maintenance
๐ Bug and typo fixes
- fix: update payload preparation to merge parameters into the output dictionary by @mishig25 in [#3160]
- fix(inference_endpoints): use GET
healthRoute
instead of GET / to check status by @mfuntowicz in [#3165] - Update hf_api.py by @andimarafioti in [#3194]
- [Docs] Remove Inference API references in docs by @hanouticelina in [#3197]
- Align HfFileSystem and HfApi for the
expand
argument when listing files in repos by @lhoestq in [#3195] - Solve encoding issue of repocard.py by @WilliamRabuel in [#3235]
- Fix pagination test by @Wauplin in [#3246]
- Fix Incomplete File Not found on windows systems by @JorgeMIng in [#3247]
- [Internal] Fix docstring param spacing check and
libcst
incompatibility with Python 3.13 by @hanouticelina in [#3251] - [Bot] Update inference types by @HuggingFaceInfra in [#3104]
- Fix snapshot_download when unreliable number of files by @Wauplin in [#3241]
- fix typo by @Wauplin (direct commit on main)
- fix sessions closing warning with AsyncInferenceClient by @hanouticelina in [#3252]
- Deprecate missing_mfa, missing_sso, adding security_restrictions @Kakulukian [#3254]
๐๏ธ internal
- swap gh style bot action token by @hanouticelina in [#3171]
- improve style bot comment (notify earlier and update later) by @ydshieh in [#3179]
- Update tests following server-side changes by @hanouticelina in [#3181]
- [FIX DOCSTRING] Update hf_api.py by @cakiki in [#3182]
- Bump to 0.34.0.dev0 by @Wauplin in [#3222]
- Do not generate Chat Completion types anymore by @Wauplin in [#3231]