Software:Enterprise Storage OS

From HandWiki
Revision as of 12:27, 9 February 2024 by AnLinks (talk | contribs) (linkage)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Enterprise Storage OS (ESOS)
OS familyLinux (Unix-like)
Initial releaseJanuary 2012; 12 years ago (2012-01)
|Final release|Latest release}}4.1.8 / 13 May 2023; 18 months ago (2023-05-13)[1]
LicenseApache License, Version 2.0
Official websitewww.esos-project.com

Enterprise Storage OS, also known as ESOS, is a Linux distribution that serves as a block-level storage server in a storage area network (SAN).[2] ESOS is composed of open-source software projects that are required for a Linux distribution and several proprietary build and install time options.[3] The SCST project is the core component of ESOS; it provides the back-end storage functionality.[4]

Platform

ESOS is a niche Linux distribution. ESOS is intended to run on a USB flash drive, or some other type of removable media such as Secure Digital, CompactFlash, etc. ESOS is a memory resident operating system: At boot, a tmpfs file system is initialized as the root file system and the USB flash drive image is copied onto this file system.[5] Configuration files and logs are periodically written to a USB flash drive (persistent storage) or by user intervention when configuration changes occur.[6]

Interface

Screenshot of the main TUI screen in ESOS (Enterprise Storage OS).

ESOS utilizes a text-based user interface (TUI) for system management, network configuration, and storage provisioning functions.[7] The TUI used in ESOS is written in C; the ncurses and CDK libraries are used.

Front-end connectivity

ESOS supports connectivity on several different front-end storage area network technologies.[8] These core functions are supported by SCST and third-party target drivers that vendors have developed for SCST:[9]

  • Fibre Channel: QLogic HBAs are natively supported, and Emulex OneConnect FC HBAs can be supported by a build time option (requiring the Emulex OCS SDK)[10]
  • InfiniBand: Mellanox, QLogic, and Chelsio IB HCAs, among others, are supported[11]
  • Fibre Channel over Ethernet (FCoE): A software target implementation supports NICs with DCB/DCBX capabilities, or build time options exist for supporting Emulex OneConnect FCoE CNAs (requires the Emulex OCS SDK) and Chelsio Uwire FCoE CNAs.[12]
  • iSCSI: Will work over any IP communication method supported by ESOS (Ethernet, IPoIB).

Back-end storage

Open-source software projects and commodity computing server hardware are used on the back-end side to provide the underlying storage utilized by the front-end target interfaces:

  • Btrfs, XFS, and ext4 are all supported file systems for virtual disk files used with the "vdisk_fileio" device handler.
  • Popular, modern hardware RAID controllers from LSI, Adaptec, HP, and Areca are also supported in ESOS, including install-time CLI tool integration for these adapters.
  • Clustering and high-availability support is made possible by the Pacemaker and Corosync cluster software stack.
  • DRBD is fully supported to facilitate replication between ESOS storage servers, and/or to create redundant ESOS storage server clusters.
  • Virtual Tape Library (VTL) support by the mhVTL project.
  • Three SSD caching solutions: EnhanceIO, bcache, and dm-cache (lvmcache).
  • Other block storage functions include the automated tiered storage via the BTIER project and Ceph RBD mapping.

Installation

ESOS differs from popular Linux distributions in that there is no bootable ISO image provided. ESOS consists of one archive file that is extracted on a local computer running a supported operating system (Linux, Windows, or Mac OS X).[12] The local computer is only used for installing the ESOS image to a USB flash drive (or other removable media device).[13] Users of ESOS extract the archive and execute the ESOS install script. The ESOS installer script prompts the user for the installation target device, writes the image, and allow users to integrate proprietary CLI RAID controller utilities into the ESOS USB flash drive.

License Change

On January 16, 2019 (commit bfb8c55) the license of the ESOS project was changed from GNU General Public License (GPL) to Apache License, Version 2.0.

References

  1. "ESOS branches from GitHub". http://download.esos-project.com/?prefix=packages/4.x.x/. 
  2. DataON Storage (5 February 2015). "Mott College Slashed Storage Costs with DataON Storage". http://www.dataonstorage.com/news-release/51-dtaon-news/302-mott-college-slashed-storage-costs-with-dataon-storage.html. 
  3. Marc Smith (24 May 2012). "Implementing Enterprise Disk Arrays Using Open Source Software". Archived from the original on 2014-08-01. https://web.archive.org/web/20140801135810/http://www.merit.edu/mmc/pdf/2012_Smith.pdf. 
  4. Marc Smith (16 April 2013). "Building & Using a Highly Available ESOS Disk Array". http://marcitland.blogspot.com/2013/04/building-using-highly-available-esos.html. 
  5. Marc Smith (3 June 2014). "Virtual Desktops - From Pilot to Reality and the Trip We Made". http://labman.unlv.edu/wp-content/uploads/2014/06/LabMan_2014_VDI.ppt. [yes|permanent dead link|dead link}}]
  6. Marc Smith (15 May 2013). "Building and Using Open Source Storage Solutions". Archived from the original on 2014-07-31. https://web.archive.org/web/20140731001912/http://www.merit.edu/mmc/pdf/2013_Smith_Storage.pdf. 
  7. Marc Smith (11 August 2012). "ESOS Update (8/11/2012)". https://groups.google.com/d/msg/esos-users/mnjWY8hURg0/goFdSOO6cWQJ. 
  8. ”HA Guru” (12 February 2013). "Linux as an Open Storage Server". http://www.ha-guru.com/linux_open_storage_serve/. 
  9. Marc Smith (24 July 2014). "ESOS Project Update (July 2014)". https://groups.google.com/d/msg/esos-users/L4iIWUZsfEY/eXwEdugWF7wJ. 
  10. Avago Technologies (15 December 2014). "Mott Community College Increases Storage Performance with High-Availability Solution". http://www.lsi.com/downloads/Public/Syncro%20Shared%20Storage/docs/cs-storage-mott-college.pdf. 
  11. ”Monster Network!” (16 March 2014). "Phase 10 is complete.". http://monsternetwork.wordpress.com/category/storage-area-networking/infiniband/. 
  12. 12.0 12.1 Marc Smith (14 July 2014). "Open Storage: Dual-Controller OSS Disk Array". http://marcitland.blogspot.com/2014/07/open-storage-dual-controller-oss-disk.html. 
  13. Marc Smith (10 March 2013). "ESOS Project Status & Updates (March 2013)". https://groups.google.com/d/msg/esos-users/WFz_nV32NVM/WD5dwV58ygMJ. 

External links