Rex (software)

(R)?ex or simply Rex is an open source remote execution, configuration management and software deployment tool. It combines Perl and Secure Shell (SSH) for a portable, centralistic approach to its problem domain.

Rex
Developer(s)Jan Gehring, Ferenc Erki
Initial release5 November 2010 (2010-11-05)
Stable release
1.7.1 [1] / 5 December 2019 (2019-12-05)
Repository
Written inPerl
Operating systemLinux, Unix-like, Windows
TypeConfiguration management
LicenseApache
Websiterexify.org

Rex is an acronym for "Remote Execution".

History

Rex originated from the need of a flexible, parallel remote execution application with software deployment and configuration management capabilities. Unsatisfied with available implementations in 2010, the author of Rex, Jan Gehring, decided to implement a Perl-based tool to cope with his requirements.

Design

Rex is executed on the command line. Required parameters are fetched from the local Rexfile. The task logic is executed on the local host. The single commands of the specified task are executed atomically on every server. Rex may connect and execute commands in sequence or in parallel depending on the number of threads used.

Rex is a stand-alone application executing either a single command or so-called tasks. Tasks are specified on the command line and are defined in Rexfiles. A Rexfile takes a similar role for remote execution as a Makefile does for application installation. It is defined via a small DSL, but is essentially a Perl script. Therefore, it can contain arbitrary Perl as well.

For code reuse, configuration instructions are placed in modules which can be included by a Rexfile. A template system for configuration files is available.[2]

For Rex to be able to work, the managed targets must provide a running SSH server and a Perl 5 interpreter.

Rex serves a variety of applications. Examples are user & group, cron, filesystem, kernel module, process and virtual machine management.[3]

Public recognition

Rex is discussed on conferences and in related press releases. [4] [5]

It was voted under the Best Open Source solutions 2013 by Initiative Mittelstand.[6]

gollark: If you have some sort of application which needs constant uptime, RAID 1 SSDs.
gollark: Than RAID 1 SSDs.
gollark: I think in most cases it's probably better to just have a single local SSD, and a big backup drive (or possibly one local one and one offsite one, HDDs are cheap), and periodically do backups.
gollark: Obviously it doubles the cost, though.
gollark: That is done in some cases.

See also

References

  1. "Rex changelog"
  2. "Using Modules and Templates". Retrieved April 25, 2018.
  3. "Rex API documentation". Archived from the original on February 5, 2014. Retrieved February 5, 2014.
  4. "Rex - Deployment and Configuration Management". YAPC::Europe 2013 “Future Perl”. Retrieved February 5, 2014.
  5. "King of Computers: Managing Computers with Rex". Admin Magazine. Retrieved February 5, 2014.
  6. "IT-Bestenliste, Open Source, (R)?ex". Initiative Mittelstand. Archived from the original on December 15, 2013. Retrieved January 28, 2014.
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.