sosreport is a tool used by many companies to gather the current state of a system into a portable archive primarily for use in troubleshooting. Eucalyptus Customer Success members identified the potentials of sosreport and created a package with plugins that target Eucalyptus support needs. Everything is written in Python and is easy to modify to our needs.
This project contains plugins for sosreport that focus on the collection needs of Eucalyptus Clouds. Once these plugins have been added to a system with sosreport when run sosreport will pick up and execute them if applicable and place the output into the archive.
These plugins focus on these areas:
- Console - if the Eucalyptus Console is installed.
- Cluster - Information specific to the Cluster Controller
- Core - Logs and commands that exist on all eucalpyus installs.
- DB - Output from the database.
- Frontend - Executed on the frontend using the installed euca2ools and eucalyptus-admin-tools
- Node - Information from the Node Controller
eucalyptus-sosreport-plugins was formally a part of doctor-euca.
You will want to make sure that when you execute sosreport that you have already sourced your eucarc file to get all of the correct output.
The original work for the project was done by Tom Ellis. The torch was picked up by Richard Isaacson to drive and improve the project. Currently the project is being maintained by the Eucalyptus Tier 3 group, which is headed by Harold Spencer, Jr..
The plugins package currently targets the version of sosreport that exists in the main CentOS 6.4/6.5 repository.
It is preferred to install eucalyptus-sosreport-plugins via the package but if not once sosreport is installed you are able to manually copy the files into the plugins directory.
Add the Eucalyptus release Repository.
yum install http://downloads.eucalyptus.com/software/eucalyptus/4.2/centos/6/x86_64/eucalyptus-release-4.2-1.el6.noarch.rpm
Install the eucalyptus-sos-tools package which will install the sos package if it is not already installed.
yum install eucalyptus-sos-plugins
To install eucalyptus-sosreport-plugins manually you will need to have the following installed:
- git
- sos 3.x
- python-devel
- libxml2-python
- yum groupinstall -y 'Development Tools'
git clone https://github.com/eucalyptus/eucalyptus-sosreport-plugins.git
cd eucalyptus-sosreport-plugins
python setup.py bdist_rpm
sudo yum install dist/eucalyptus-sos-plugins-<version>.el6.noarch.rpm
Execution of sosreport is simple and straight forward. You will need to make sure that it is executed on each of the hosts that you want to collect data from. You will need to source your eucarc any time that you are executing sosreport with the eucalyptus-sosreport-plugins on a CLC host.
At the very least we want to make sure to use the –batch
option so that interactive questions are no asked.
sosreport --batch --ticket=<ticket-number> --name=<user/customer-name>
Execution could take severl moments. If it seems to be running long and it is not stuck on the databse the system plugin could be stuck. To skip the system plugin execute the following command.
sosreport --batch --skip-plugins=system
After you have executed sosreport you should move the resulting archive out of /tmp as you risk imparing the system if /tmp is too full. If /tmp is limited you can create the archive in an alternate location by executing.
sosreport --batch --tmp-dir SOMEDIRECTORY
Systems evolve and applications are upgraded. Going forward we need to make sure that we keep in sync with the version of sosreport that is in the mainline repositories.
IMPORTANT NOTE: As of eucalyptus-sos-plugins v0.2.0 we only support sosreport 3.x. We will not be supporting sosreport 2.x at this time.
IMPORTANT NOTE: As of eucalyptus-sos-plugins v0.2.0 we only support sosreport 3.x. We will not be supporting sosreport 2.x at this time.
master branch -> sosreport 3.x only
You are invited to point out any problems that might have happened while running the plugins. When submitting an issue please add the following so that we are able to best track down what the issue is.
If you don't know exactly what eucalyptus plugin failed please run the following and attach the output.
sosreport --batch --only-plugins eucacore,eucadb,eucafrontend,eucaconsole,eucacluster,eucanode -vv --debug
If you can identify a single plugin that is having problems run only that plugin and pull the output.
sosreport --batch --only-plugins PLUGIN -vv --debug
It can also be helpful to avoid creating an archive. If you use the '–build' flag to leave the directory structure intact. sosreport will print a message about where the directory structure is located.
sosreport --batch --build
Official Repository: eucalyptus/eucalyptus-sosreport-plugins
Original Repository: risaacson/eucalyptus-sosreport-plugins
We are completely open and transparent with eucalyptus-sosreport-plugins as the source resides in a public repository on github. Any issues or requests for improvement should be placed on the github issues page: eucalyptus-sosreport-plugins/issues
First off, thank you. To submit any code you will need to clone the repository through github. Make any changes to the appropriate branch. Currently you would switch to the b2.2 branch and make your changes. Complete your submission by creating a pull request. It is polite to send Harold Spencer, Jr. a note as a heads-up when work is done.