-
Notifications
You must be signed in to change notification settings - Fork 277
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Bug: stt complains libbz2.so.1.0 not found #2341
Comments
The stt Python package looks for bzip2 libs as libbz2.so.1, which fails on CentOS Stream 8 (and probably all Red Hat-based distros). We fix this for now using a symlink to the location of the library. See: coqui-ai/STT#2341
I guess it works too. The ci pipeline uses a debian base (ubuntu) but it works on a lots of distos including arch. I guess your distro has its own way of packaging libs.
I don't know the details of the implement. but I think it is reasonable to fallback to For what its worth, I think it's KenLM that uses this lib so it probably means that you have not built and installed kenlm properly in your |
Hi @wasertech I installed $ python3.9 -V
Python 3.9.14
$ python -m venv /tmp/venv-test
$ source /tmp/venv-test/bin/activate
$ pip install --upgrade pip setuptools wheel
$ pip install stt I don't fully understand the Python packaging ecosystem, but stt seems to bring its own KenLM via a wheel? I have this in my virtual env: $ ldd /tmp/venv-test/lib64/python3.9/site-packages/stt/lib/libkenlm.so
linux-vdso.so.1 (0x00007ffd5551d000)
libstdc++.so.6 => /lib64/libstdc++.so.6 (0x00007f8427170000)
libm.so.6 => /lib64/libm.so.6 (0x00007f8426dee000)
libgcc_s.so.1 => /lib64/libgcc_s.so.1 (0x00007f8426bd6000)
libc.so.6 => /lib64/libc.so.6 (0x00007f8426811000)
/lib64/ld-linux-x86-64.so.2 (0x00007f8427505000) Perhaps this issue belongs on the KenLM issue tracker then, and we can close this one. |
it is not a issue. Your are installing a package (STT) that is built using Debian based distro. But you are not using a debian based system, you should probably build your binaries according to your distribution. In other words you should be able to install STT on the system with rpm not using pip. For example, on arch, I wrote a package to build STT the way arch wants it. https://aur.archlinux.org/cgit/aur.git/tree/PKGBUILD?h=stt It should be the same for CentOS but according to RedHad packaging guidelines. So when you build KenLM, you can pass the correct links to libs and it should work. |
To be clear, when you install STT from pip, you are just grabbing the pre-built python bindings. These are built on Ubuntu from |
@wasertech I use Arch too BTW (and I also maintain packages on the AUR... but that's irrelevant here). Anyway, what is the point of providing a pip installable STT if it is only expected to work on Debian-based distros? If there's a notice to this effect in the README and I missed it, then my apologies. Otherwise, in scientific computing many institutes use RHEL / CentOS. |
Coqui uses a GitHub ci pipeline to build all prebuilt binaries. Including python bindings. For Linux, it uses a stable release of Ubuntu which is based on stable Debian. It also a pretty standard Linux distribution. i didn’t choose it, it don’t use Ubuntu and I don’t even work at coqui. I’m just telling you that your distribution has not followed the same rules as Debian when providing libs. On arch we use aliases like you did to loosely follow Debian’s way of sharing libs. On arch you can pip install stt and it works like a charm. In your case, since your distro doesn’t make the effort to make thoses aliases you should make them yourself, or follow their way of shipping software thru rpm and tell KenLM where to finds its libs when you build it. |
Describe the bug
Python stt 1.4.0 from pip crashes due to missing libbz2.so.1.0 on CentOS Stream 8 and probably all RPM-based distros:
But bzip2 libs are installed:
And libbz2.so is available, albeit as
libbz2.so.1
:To Reproduce
Steps to reproduce the behavior:
pip install stt
in a virtual environmentstt
Expected behavior
stt
to not crash.Environment (please complete the following information):
Additional context
I can make a symlink to fix this, but it feels dirty. I'm wondering which systems does this work on? Could
stt
check forlibbz2.so.1
instead, or after checking forlibbz2.so.1.0
?The text was updated successfully, but these errors were encountered: