Comments (14)
I'm not familiar with how ceph is implemented, is there an obvious reason why it'd be initializing modules multiple times per process? Does it use subinterpreters?
from bcrypt.
From my point of view, case should as similar as pyca/cryptography#9016 (comment).
BTW now I could combine both Ceph 18.2.1 + python3-cryptography 41.0.7 + python3-bcrypt 4.0.1 without error; the error only happen when running with bcrypt >= 4.1.0.
Therefore I guess bcrypt should reference some handling from cryptography between 41.0.1..41.0.7 for preventing multiple initialization?
from bcrypt.
from bcrypt.
The case with Ceph 18.2.1 are:
- OK: cryptography 40.0.2 + bcrypt 4.0.1
- OK: cryptography 41.0.7 + bcrypt 4.0.1
- FAILED: cryptography 40.0.2 + bcrypt 4.1.1
- FAILED: cryptography 41.0.7 + bcrypt 4.1.1
Original report for Ceph 18.2.1 + cryptography 41.0.x could be found from:
- https://tracker.ceph.com/issues/63529
- bazaah/aur-ceph#20
- https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=1055212
BTW as above cross check shown, now cryptography no longer become the root cause, but coming from bcrypt ;-(
from bcrypt.
Is it straightforward for me to reproduce this locally, or do I need a full ceph installation?
from bcrypt.
I have a Vagrant Box for Ceph 18.2: https://app.vagrantup.com/alvistack/boxes/ceph-18.2
It is now rebuilding with my latest functional combination (i.e. cryptography 41.0.7 + bcrypt 4.0.1): https://gitlab.com/alvistack/vagrant-ceph/-/pipelines/1103864469
If you are using VirtualBox (see https://github.com/alvistack/vagrant-ceph#quick-start):
# Initialize Vagrant
cat > Vagrantfile <<-EOF
Vagrant.configure('2') do |config|
config.vm.hostname = 'ceph-18.2'
config.vm.box = 'alvistack/ceph-18.2'
config.vm.provider :virtualbox do |virtualbox|
config.vm.disk :disk, name: 'sdb', size: '10GB'
virtualbox.cpus = 2
virtualbox.customize ['modifyvm', :id, '--cpu-profile', 'host']
virtualbox.customize ['modifyvm', :id, '--nested-hw-virt', 'on']
virtualbox.memory = 8192
end
end
EOF
# Start the virtual machine
export VAGRANT_EXPERIMENTAL='1'
vagrant up
# SSH into this machine
vagrant ssh
Once the box is up and running:
vagrant ssh
thensudo su -
as root- Check with
ceph -s
, now should showingHEALTH_OK
- Manually upgrade the preinstalled bcrypt 4.0.1 under
/usr/lib/python3/dist-packages/bcrypt
into 4.1.1 - Reboot the box
- Once login as root again and check with
ceph -s
, now it should showHEALTH_WARN 9 mgr modules have failed dependencies
- With
journalctl -xef -u ceph-mgr@*
you should able to get the error log as show above
from bcrypt.
If I built a custom wheel, would you be able to test that out and see if you can reproduce?
from bcrypt.
If I built a custom wheel, would you be able to test that out and see if you can reproduce?
Or you may provide your forked GitHub branch, so I could keep rebuilding and testing with it in my local dev env?
from bcrypt.
#695 -- you can either download a wheel from the wheel-builder job, or you can build yourself from that branch.
from bcrypt.
@alex my quick check and report:
- OK: cryptography 40.0.2 + bcrypt 4.0.1
- OK: cryptography 41.0.7 + bcrypt 4.0.1
- OK: cryptography 41.0.7 (patched with py_limited_api="auto" and pyo3 = { version = "0.20", features = ["abi3"] }) + bcrypt 4.0.1
- FAILED: cryptography 40.0.2 + bcrypt 4.1.1
- FAILED: cryptography 41.0.7 + bcrypt 4.1.1
- FAILED: cryptography 41.0.7 (patched with py_limited_api="auto" and pyo3 = { version = "0.20", features = ["abi3"] }) + bcrypt 4.0.1 (patched with py_limited_api="auto" and pyo3 = { version = "0.20.0", features = ["abi3"] })
For the last case, the new error message is now:
Dec 13 06:41:15 node12 ceph-mgr[17264]: 2023-12-13T06:41:15.339+0000 7f3d7e793280 -1 mgr[py] Module status has missing NOTIFY_TYPES member
Dec 13 06:41:15 node12 ceph-mgr[17264]: 2023-12-13T06:41:15.479+0000 7f3d7e793280 -1 mgr[py] Module not found: 'mgr_module'
Dec 13 06:41:15 node12 ceph-mgr[17264]: 2023-12-13T06:41:15.479+0000 7f3d7e793280 -1 mgr[py] Traceback (most recent call last):
Dec 13 06:41:15 node12 ceph-mgr[17264]: File "/usr/share/ceph/mgr/mgr_module.py", line 28, in <module>
Dec 13 06:41:15 node12 ceph-mgr[17264]: from mgr_util import profile_method
Dec 13 06:41:15 node12 ceph-mgr[17264]: File "/usr/share/ceph/mgr/mgr_util.py", line 6, in <module>
Dec 13 06:41:15 node12 ceph-mgr[17264]: import bcrypt
Dec 13 06:41:15 node12 ceph-mgr[17264]: File "/lib/python3/dist-packages/bcrypt/__init__.py", line 13, in <module>
Dec 13 06:41:15 node12 ceph-mgr[17264]: from ._bcrypt import (
Dec 13 06:41:15 node12 ceph-mgr[17264]: ImportError: PyO3 modules do not yet support subinterpreters, see https://github.com/PyO3/pyo3/issues/576
See PyO3/pyo3#576
from bcrypt.
Hmm, on the one hand, if ceph really is using subinterpreters, there's nothing we can do.
On the other hand, the fact that this error is showing up only with certain version combinations suggestions there's a deeper bug here. I'm afraid I don't have a suggestion other than that we really need a minimal reproducer here, something smaller than all of ceph.
from bcrypt.
Related Issues (20)
- No version of bcrypt for Python 3.10 HOT 1
- Error when using bcrypt to salt and hash password HOT 1
- checkpw issue, I need some guide. HOT 4
- Python2.7 ImportError: cannot import name _bcrypt HOT 3
- Document packages bundled inside wheels HOT 2
- python 3.7.3 HOT 4
- "Illegal instruction" on Raspberry Pi Zero HOT 10
- new release needed for python 3.12 compatibility at build time HOT 9
- New release results in bcrypt break HOT 22
- I use `bcrypt` with `passlib` HOT 2
- Install [email protected]. 400 bad request HOT 1
- AttributeError: module 'bcrypt' has no attribute '__about__' with new 4.1.1 version HOT 16
- install 4.1.1 on M2 chip failed HOT 1
- Why is the macOS 11/12 wheel dropped? HOT 3
- The bcrypt.hashpw(val1, val2) function always produces the same output even if the values are different. HOT 4
- new version on mipsel 32 bit Atomic error HOT 4
- Is BSD license applicable?
- RFE: is it possible to start making github releases?🤔 HOT 2
- TypeError in checkpw HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from bcrypt.