9 releases (breaking)

0.8.0 Jul 9, 2020
0.7.0 Nov 30, 2019
0.6.0 Aug 10, 2019
0.5.0 Aug 7, 2019
0.1.1 Apr 20, 2018

#27 in #rpm

Download history 106/week @ 2023-12-23 84/week @ 2023-12-30 153/week @ 2024-01-06 104/week @ 2024-01-13 198/week @ 2024-01-20 148/week @ 2024-01-27 164/week @ 2024-02-03 276/week @ 2024-02-10 231/week @ 2024-02-17 248/week @ 2024-02-24 243/week @ 2024-03-02 231/week @ 2024-03-09 196/week @ 2024-03-16 139/week @ 2024-03-23 126/week @ 2024-03-30 158/week @ 2024-04-06

650 downloads per month


1.5K SLoC


Crate Build Status Safety Dance MSRV Apache 2.0 Licensed Gitter Chat

cargo subcommand for building .rpm releases of Rust projects.


  • Rust 1.41+


Install cargo rpm by running: cargo install cargo-rpm.

Configuring a crate

To configure your crate for RPM releases, run cargo rpm init

This will create a .rpm/YOURCRATENAME.spec file which is passed to the rpmbuild command. Though the generated spec should work out of the box, it may need some customization if the resulting RPM has dependencies or files other than target binaries.

For more information on spec files, see: http://ftp.rpm.org/max-rpm/s1-rpm-build-creating-spec-file.html

Building RPMs

Once your crate has been configured, run cargo rpm build to build release targets for your project and package them into an RPM.

If you encounter errors, you may need to see more information about why rpmbuild failed. Run cargo rpm build -v to enable verbose mode.

Finished .rpm files will be placed in target/release/rpmbuild/RPMs/<arch>


Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at


Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.


~361K SLoC