abetlen / llama-cpp-python

Python bindings for llama.cpp
https://llama-cpp-python.readthedocs.io
MIT License
8.16k stars 970 forks source link

Error when building wheels on Linux FileNotFoundError: [Errno 2] No such file or directory: 'ninja'` #1839

Open sabaimran opened 3 hours ago

sabaimran commented 3 hours ago

Prerequisites

Please answer the following questions for yourself before submitting an issue.

Expected Behavior

Please provide a detailed written description of what you were trying to do, and what you expected llama-cpp-python to do.

Current Behavior

Building wheels results in error logs (see below).

Environment and Context

Failure Information (for bugs)

I'm unable to build wheels for llama-cpp-python in an ubuntu:jammy base Docker image. I get the error: FileNotFoundError: [Errno 2] No such file or directory: 'ninja'.

Please help provide information about the failure if this is a bug. If it is not a bug, please remove the rest of this template.

Steps to Reproduce

Please provide detailed steps for reproducing the issue. We are not sitting in front of your screen, so the more detail the better.

  1. git clone git@github.com:khoj-ai/khoj.git
  2. cd khoj && docker build .

You should see the same error reproduced

Failure Logs

0 54.02
#0 54.02   × Building wheel for llama-cpp-python (pyproject.toml) did not run successfully.
#0 54.02   │ exit code: 1
#0 54.02   ╰─> [34 lines of output]
#0 54.02       *** scikit-build-core 0.10.7 using CMake 3.31.1 (wheel)
#0 54.02       *** Configuring CMake...
#0 54.02       Traceback (most recent call last):
#0 54.02         File "/usr/lib/python3/dist-packages/pip/_vendor/pep517/in_process/_in_process.py", line 363, in <module>
#0 54.02           main()
#0 54.02         File "/usr/lib/python3/dist-packages/pip/_vendor/pep517/in_process/_in_process.py", line 345, in main
#0 54.02           json_out['return_val'] = hook(**hook_input['kwargs'])
#0 54.02         File "/usr/lib/python3/dist-packages/pip/_vendor/pep517/in_process/_in_process.py", line 261, in build_wheel
#0 54.02           return _build_backend().build_wheel(wheel_directory, config_settings,
#0 54.02         File "/tmp/pip-build-env-gvxo9xjm/overlay/local/lib/python3.10/dist-packages/scikit_build_core/build/__init__.py", line 33, in build_wheel
#0 54.02           return _build_wheel_impl(
#0 54.02         File "/tmp/pip-build-env-gvxo9xjm/overlay/local/lib/python3.10/dist-packages/scikit_build_core/build/wheel.py", line 175, in _build_wheel_impl
#0 54.02           return _build_wheel_impl_impl(
#0 54.02         File "/tmp/pip-build-env-gvxo9xjm/overlay/local/lib/python3.10/dist-packages/scikit_build_core/build/wheel.py", line 402, in _build_wheel_impl_impl
#0 54.02           builder.configure(
#0 54.02         File "/tmp/pip-build-env-gvxo9xjm/overlay/local/lib/python3.10/dist-packages/scikit_build_core/builder/builder.py", line 166, in configure
#0 54.02           local_def = set_environment_for_gen(
#0 54.02         File "/tmp/pip-build-env-gvxo9xjm/overlay/local/lib/python3.10/dist-packages/scikit_build_core/builder/generator.py", line 121, in set_environment_for_gen
#0 54.02           ninja = best_program(get_ninja_programs(), version=ninja_settings.version)
#0 54.02         File "/tmp/pip-build-env-gvxo9xjm/overlay/local/lib/python3.10/dist-packages/scikit_build_core/program_search.py", line 169, in best_program
#0 54.02           for program in programs:
#0 54.02         File "/tmp/pip-build-env-gvxo9xjm/overlay/local/lib/python3.10/dist-packages/scikit_build_core/program_search.py", line 136, in get_ninja_programs
#0 54.02           result = Run().capture(ninja_path, "--version")
#0 54.02         File "/tmp/pip-build-env-gvxo9xjm/overlay/local/lib/python3.10/dist-packages/scikit_build_core/_shutil.py", line 43, in capture
#0 54.02           return self._run(args, capture=True)
#0 54.02         File "/tmp/pip-build-env-gvxo9xjm/overlay/local/lib/python3.10/dist-packages/scikit_build_core/_shutil.py", line 71, in _run
#0 54.02           return subprocess.run(
#0 54.02         File "/usr/lib/python3.10/subprocess.py", line 503, in run
#0 54.02           with Popen(*popenargs, **kwargs) as process:
#0 54.02         File "/usr/lib/python3.10/subprocess.py", line 971, in __init__
#0 54.02           self._execute_child(args, executable, preexec_fn, close_fds,
#0 54.02         File "/usr/lib/python3.10/subprocess.py", line 1863, in _execute_child
#0 54.02           raise child_exception_type(errno_num, err_msg, err_filename)
#0 54.02       FileNotFoundError: [Errno 2] No such file or directory: 'ninja'
#0 54.02       [end of output]
#0 54.02
#0 54.02   note: This error originates from a subprocess, and is likely not a problem with pip.
#0 54.02   ERROR: Failed building wheel for llama-cpp-python
#0 54.02   Building wheel for openai-whisper (pyproject.toml): started
#0 54.25   Building wheel for openai-whisper (pyproject.toml): finished with status 'done'
#0 54.25   Created wheel for openai-whisper: filename=openai_whisper-20240930-py3-none-any.whl size=803338 sha256=3fe6a790d061e0fd0fb7f67fab76b6662233ee67d68b41f45ba25df64f21df59
#0 54.25   Stored in directory: /tmp/pip-ephem-wheel-cache-y4xjqtu_/wheels/dd/4a/1f/d1c4bf3b9133c8168fe617ed979cab7b14fe381d059ffb9d83
#0 54.25 Successfully built khoj docx2txt openai-whisper
#0 54.26 ERROR: Could not build wheels for llama-cpp-python, which is required to install pyproject.toml-based projects
#0 54.26 Failed to build llama-cpp-python
------

Here's the pyproject.toml it's using to build: link.

You can see the full error logs in the GitHub Action workflow.

I noticed the ninja project had a release recently, but the error is still consistent if I downgrade ninja to 1.11.1.1.

Our workflow has been running smoothly, and this is the first time we encountered the error (about two hours ago, ~1:00 PM PST). Any help is much appreciated 🙏🏾.

sabaimran commented 2 hours ago

We've potentially figured out a mitigation by building from a pre-built wheel. See solution here.