Processes BilboMD jobs and run CHARMM, FoXS, and MultiFoXS
bilbomd-worker
is a simple Typescript NodeJS "worker" app that watches a BullMQ queue for incoming jobs. When a new job appears in the queue it will launch a sequence of processing tasks using CHARMM, FoXS, and MultiFoXS. The results will then be bundled up as a results.tar.gz
file. The job progress will be updated in the main MongoDB database as well as in the BullMQ system (which uses Redis behind the scenes to store queue data).
In order to build the docker images you will need to obtain the source codes for CHARMM, BioXTAS, and OpenMPI and place them in the appropriate folders prior to running any docker build
commands.
To build the Docker image from the command line.
git clone git@github.com:bl1231/bilbomd-worker.git
cd bilbomd-worker
docker build --build-arg USER_ID=$UID -t bl1231/bilbomd-worker -f bilbomd-worker.dockerfile .
At the moment there are two versions of the bilbomd-worker
needed for deploying BilboMD at NERSC. One version for doing the work on a perlmutter compute node and a second version that does no real "work", but is deployed to SPIN where it monitors for jobs and uses the Superfacility API to prepare and launch jobs via slurm batch scripts.
In general, all of the build steps are performed as part of the Continuous Integration steps coordinated by GitHub Actions. If you need to buidl the Docker images manually you will need to build two images. To build bilbomd-perlmutter-worker
which is the podman-hpc runtime for performing the Molecular Dynamics steps on Perlmutter compute nodes:
cd bilbomd-worker
podman-hpc build --build-arg USER_ID=$UID -t bilbomd/bilbomd-perlmutter-worker -f bilbomd-perlmutter-worker.dockerfile .
To build bilbomd-spin-worker
for running on the SPIN Kubernetes cluster. The $GITHUB_TOKEN
comes from GitHub... ask me if you need to know about this.
cd bilbomd-worker
podman-hpc build --build-arg GITHUB_TOKEN=$GITHUB_TOKEN -t bilbomd/bilbomd-spin-worker -f bilbomd-spin-worker.dockerfile .
- Scott Classen sclassen at lbl dot gov
- Michal Hammel mhammel at lbl dot gov
- 1.12.6 (1/9/2025)
- Calculate model molecular weight (MW) from initial PDB model.
- 1.12.5 (1/7/2025)
- Update dependencies
- 1.12.4 (12/11/2024)
- Refactor
prepareResults
for BilboMD SANS - Improve README for BilboMD SANS
- Update dependencies
- Refactor
- 1.12.3 (12/06/2024)
- Bump dockerfile from node20 to node22
- Syncronize changes to
pae_ratios.py
frombilbomd-backend
- 1.12.2 (12/04/2024)
- Update dependencies
- Run
npm audit fix
- 1.12.1 (11/22/2024)
- Refactor src/workers/bilboMdNerscJobMonitor.ts to prevent multiple emails sent.
- 1.12.0 (11/21/2024)
- Add BilboMD Multi pipeline
- 1.11.2 (11/20/2024)
- Fix PAE Jiffy bug preventing it from working as expected.
- 1.11.1 (11/19/2024)
- Return
minimization_output_$datfileprefix.dat
in results.tar.gz file - Update several dependencies
- Return
- 1.11.0 (11/15/2024)
- Add a PDB remediation step to non-NERSC pipelines
- 1.10.1 (11/13/2024)
- Update job progress in Mongo Job entry for all non-NERSC jobs
- 1.10.0 (11/08/2024)
- Decouple job submission from job monitoring on NERSC
- Add the step to calculate Rgyr vs. Dmax consolodated json file
- 1.9.4 (11/04/2024)
- Simplify package name from
bilbomd-worker/bilbomd-worker
tobilbomd-worker
- Simplify package name from
- 1.9.3 (11/04/2024)
- Changes required to migrate from CJS to ESM
- 1.9.2
- Update dependencies
- 1.9.1
- Add feedback analysis sub-step for BilboMD Classic PDB (others will be added later)
- 1.9.0
- Add BilboMD SANS capabilities
- Refactor BullMQ worker code to make it more modular
- 1.8.1
- Increase monitorJobAtNERSC polling to 24 hours at 1 min intervals
- 1.8.0
- Add worker functions to process BilboMD AF (AlphaFold) jobs
- 1.7.0
- Remove
bilbomd-spin-worker
- Add an API endpoint to deliver config info
- Improvements to CI/CD workflow
- Remove
- 1.6.7
- Unified Docker image for both beamline and NERSC SPIN deployment
- 1.6.6
- Add BioXTAS RAW & IMP to docker image.
- Additional changes so we can eventually have a single Docker image for SPIN and beamline deployment
- Fix & refactor the
pae_ratios.py
script to deal with adjacent Rigid Domains.
- 1.6.5
- Fix bug with PAE Jiffy when replacing DNA residues
- Install Python and CHARMM into
bilbomd-spin-worker
Docker image
- 1.6.4
- Dependency updates
- Implement GitHub Actions CI workflows
- Better job-handling logic for NERSC Jobs
- 1.6.3
- Add steps object to mongodb entry
- Some improvements to logging
- 1.6.2
- Use @bl1231/bilbomd-mongodb-schema
- Update dependencies
- Update README
- 1.6.1
- A fair number of changes for NERSC deployment.
- 1.6.0
- Extensive changes to
pdb2crd.py
in order to preserve incoming residue numbering. - Refactor for the changes in
pdb2crd.py
- Create one
CRD
file per chain then combine before running the rest of the BilboMD pipeline. - Make sure original files are included in
results.tar.gz
file - Create
results.tar.gz
files with unique names (e.g.results-2ff9f312.tar.gz
)
- Extensive changes to
- 1.5.5
- Fix bug in
pdb2crd.py
script for substituting CHARMM residues names in DNA. - Update dependencies
- Fix bug in
- 1.5.4
- Sync
pae_ratios.py
script withbilbomd-backend
.
- Sync
- 1.5.2
- Changes to allow PDB files for BilboMD Classic
- 1.5.1
- Changes to allow PDB files for BilboMD Auto
- 1.5.0
- Mainly changes to allow building and deploying on local laptop and NERSC SPIN.
- 1.4.0
- Add new functions for converting PDB to CRD and PSF.
- Enforce Python style guidelines with Black.
- Add
pdb2crd.py
script for creating the CHARMM input file for PDB to CRD.
- 1.3.1
- Close fs streams properly so we don't have dangling NFS lock files.
- 1.3.0
- Add new functions to run
FoXS
analysis on initial PDB for BilboMD classic/auto
- Add new functions to run
- 1.2.9
- Add a README file to all
results.tar.gz
files explaining the contents.
- Add a README file to all
- 1.2.8
- Fix bug when
rg_min
andrg_max
are too close.
- Fix bug when
- 1.2.7
- Update dependencies
- 1.2.6
- Synchronize
mongoose
schema files with other BilboMD codes
- Synchronize
- 1.2.5
- Change all CHARMM bomlev values to `-2``
- 1.2.4
- Upgrade mongoose from 7.6.3 to 8.0.2
- 1.2.3
- add the hidden
-o
option for allmulti_foxs
runs
- add the hidden
- 1.2.2
- update
pae_ratios.py
script
- update
- 1.2.1
- Small change to logging messages
- 1.2.0
- Refactor bilbomd function code
- Add single
handleError
function - improve error handling logic
- 1.1.0
- Rewrite gatherResults
- Return single PDB file for each MultiFoXS ensemble
- 1.0.0
- Start using Ubuntu for Docker build
- IMP 2.19.0
- 0.0.12
- Add BilboMDAuto job type (experimental and untested!)
- 0.0.11
- bump nodejs to 18.18.0
- 0.0.10
- Remove the
-r
option from FoXS inspawnFoXS
function.
- Remove the
- 0.0.9
- add job title to emails