Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/RexOps/Rex
Rex, the friendly automation framework
https://github.com/RexOps/Rex
automation configuration-management devops framework infrastructure-as-code infrastructure-automation perl rex rexops
Last synced: 3 months ago
JSON representation
Rex, the friendly automation framework
- Host: GitHub
- URL: https://github.com/RexOps/Rex
- Owner: RexOps
- Created: 2010-11-05T11:52:19.000Z (about 14 years ago)
- Default Branch: master
- Last Pushed: 2024-05-04T22:22:39.000Z (8 months ago)
- Last Synced: 2024-07-02T15:41:04.580Z (6 months ago)
- Topics: automation, configuration-management, devops, framework, infrastructure-as-code, infrastructure-automation, perl, rex, rexops
- Language: Perl
- Homepage: https://www.rexify.org
- Size: 8.34 MB
- Stars: 708
- Watchers: 62
- Forks: 223
- Open Issues: 212
-
Metadata Files:
- Readme: README.md
- Changelog: ChangeLog
- Contributing: CONTRIBUTING.md
Awesome Lists containing this project
- awesome - Rex - A framework for server orchestration and to simplify system administration (Perl)
README
# Rex, the friendly automation framework
The main ideas behind Rex are:
1. Puts _you_ in charge
Rex acknowledges that instead of silver bullets, there is more than one way to manage it.
It's friendly to any combinations of local and remote execution, push and pull style of management, or imperative and declarative approach.
Instead of forcing any specific model on you, it trusts you to be in the best position to decide what to automate and how, allowing you to build the automation tool _your_ situation requires.1. Easy to get on board
Automate what you are doing today, and add more tomorrow.
Rex runs locally, even if managing remotes via SSH. This means it's instantly usable, without big rollout processes or anyone else to convince, making it ideal and friendly for incremental automation.
1. It's just Perl
Perl is a battle-tested, mature language, and Rex code is just Perl code.
This means whenever you reach the limitations of the built-in Rex features, a powerful programming language and module ecosystem is always at your fingertips to seamlessly extend it with modules from [CPAN](https://metacpan.org) or with your own code.
As a bonus, you can also use the usual well-established tools and workflows, like IDE integration for syntax highlighting, linting and formatting, or authoring and publishing [Rex modules on CPAN](https://metacpan.org/search?q=rex).
With the use of [Inline](https://metacpan.org/pod/Inline) and [FFI::Platypus](https://metacpan.org/pod/FFI::Platypus) modules, it's friendly to code written in other languages too. So after all, it's not just Perl.## Getting started
We have a [Getting started guide](https://www.rexify.org/docs/guides/start_using__r__ex.html) on the website that should help you with the first steps.
## Installation
There are several methods to install (R)?ex: use your distro's package manager, download it from CPAN or build it from source. Check out the [Get Rex](https://www.rexify.org/get/index.html) page on the website for the different options, and choose the one that fits you best.
### Build from source
To build (R)?ex from source, you need to install [Dist::Zilla](https://metacpan.org/pod/Dist::Zilla):
cpanm Dist::Zilla
Dist::Zilla provides the *dzil* command, which you can use to install (R)?ex dependencies:
dzil authordeps | cpanm
dzil listdeps | cpanmSome of the optional dependencies might not be available on all platforms, but to install them as well, use this command:
dzil listdeps --suggests | cpanm
Then to install the OS-specific dependencies and (R)?ex itself:
dzil install
If you'd like to build a .tar.gz release file:
dzil build
## Need help?
If a new user has difficulties to get on board, then it's a bug. Let us know via one of our [support channels](https://www.rexify.org/support/index.html)!
## Contributing
All contributions are welcome: documentation, patches, bug reports, ideas, promoting (R)?ex at conferences and meetups, or anything else you can think of.
For more details, see the [Contributing guide](https://github.com/RexOps/Rex/blob/master/CONTRIBUTING.md) in the repo and the [Help (R)?ex](https://www.rexify.org/care/help__r__ex.html) page on the website.