cow-poke
/'kou,pōk/, IPA: /kɑʊ poʊk/
noun
1. slang. A cowhand (one who tends free-range cattle)
Get it? Rancher ... Cattle ...Cowpoke?
This is a set of instructions and a tutorial designed to help new engineers get started on Rancher.io. So saddle up pardner, let's get goin'. </bad cowboy puns>
DISCLAIMER: This setup guide targets full-stack Rancher engineers/hackers that may need to work on the cattle orchestration server (java) or one of the agents/microservices that interact with it (python, go, node). If you don't fit that profile, consider following these much simpler instructions to get Rancher up and running quickly.
DISCLAIMER #2: This is a very opinionated setup guide. It prescribes certain IDEs and methodologies. The motivation for being so opinionated is two-fold: 1. To offer a level playing field to everyone working on Rancher. 2. To teach-by-example. So that if you have a different way of doing things (ie, prefer a different IDE or operating sytem) you can at least reference this document to find out how things are expected to work.
Rancher.io is an open source project that provides infrastructure...actually, just read this.
We'll assume you have an idea of what Rancher.io is and what it does and just focus on getting your environment up and running. In this guide, we'll do the following:
- Setup the necessary tech on your development machine
- Clone the Rancher source code repo and configure its projects in our IDEs
- Launch Rancher and play around with it a bit
- Run integration tests and verify everything is working
Assuming that you're woking on a Mac, install Xcode from the app store (some pieces of software require it). Open it after it installs so that you can accept the Terms.
Here's the list of the core libraries/technologies/software that you'll need:
- docker Mac/Linux
- mysql server and client
- JDK 7
- Python 2.7 and some python tools: pip, virtualenv, tox
- Homebrew coreutils for things like greadlink
If you're on a Mac and use Homebrew, you can follow these steps:
touch ~/.profile # If you don't have it
ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
brew doctor
brew tap caskroom/homebrew-cask
brew install brew-cask
brew cask install virtualbox
brew install coreutils
brew install maven
brew install liquibase
echo "export LIQUIBASE_HOME=$(find /usr/local/Cellar/liquibase -name libexec)" >> ~/.profile
brew install gnu-sed --with-default-names
brew install caskroom/cask/brew-cask
brew cask install dockertoolbox #Install docker toolbox.
docker-machine create --driver virtualbox dockerbox
eval `docker-machine env dockerbox`
docker run busybox # Prove it works!
echo 'eval "$(docker-machine env dockerbox)"' >> ~/.profile
brew install mysql
mysql.server start
mysql -uroot # Prove it works!
sudo easy_install pip
sudo pip install tox # This gets your virtualenv too
Install JDK 7 manually since the Homebrew install seems flaky. Just get the latest from Oracle.
Make your JAVA_HOME point to 1.7:
echo "export JAVA_HOME=$(/usr/libexec/java_home -v 1.7)" >> ~/.profile
Clone cattle to your workspace directory:
cd <your workspace directory>
git clone https://github.com/rancher/cattle.git
That's it. All the code is in the cattle repo. The rancher project actually just packages up the code in the cattle repo.
Note: From now on, the path to where you cloned cattle will be referred to as $CATTLE_ROOT. Go ahead and export that environment variable if you just want to copy and paste commands:
export CATTLE_ROOT=<your working directory>
Before we move on to setting up the management server in Eclipse, let's initialize our database server with the proper database and users:
cd $CATTLE_ROOT
mysql -uroot < resources/content/db/mysql/create_db_and_user_dev.sql
Note: If you aren't working on the cattle orchestration server which is written in java, you don't need to install, configure, and run in Eclipse. Instead, you can just run the rancher server as a container. Instructions are in the Rancher repo README.md
For Java, we'll assume the latest version of Eclipse (flavor: Eclipse IDE for Java Developers).
Note: We'll assume PyCharm for the python components. For golang, vim + vim-go is the best we've found. For Node.js and the rest of the front end, we're using vim as well.
Install eclipse now and then do the following:
- In Eclipse, open the marketplace and install these plugins:
- Spring IDE. It has a ton of optional modules. You only need the "core" module; deselect the rest.
- M2E (maven2eclipse). It should already be installed, but make sure it is.
- Make the "Plugin execution not covered by lifecycle..." error go away:
- Preferences > Maven > Errors/Warnings > Plugin execution not covered...: Ignore
Now we can move on to configuring the project in Eclipse. But first, copy the Cattle Eclipse launch config to a different location:
cp $CATTLE_ROOT/tools/eclipse/Cattle.launch $CATTLE_ROOT/code/packaging/app/
That’s so that in Eclipse we can eventually close the top level cattle project. We need to do that to avoid duplicate code issues in Eclipse.
TODO Move Cattle.launch to the app directory and rename Cattle.launch.example and then update this documentation
The cattle repo contains a lot of sub-projects. All the java sub-projects are maven based, so it's easy to get them all setup in eclipse:
- File > Import... > Maven > Existing Maven Projects
- Root Directory: $CATTLE_ROOT
- Leave all the projects selected.
- ...Wait for Maven to build...
- Close the top-level "cattle" project so that you don't get any duplicate code issues.
Much projects. Such Maven. Wow.
Remember that Cattle.launch we copied? That's how we launch the management server:
- Click the Run Dropdown
- Debug Configurations...
- Java Applications: Cattle (click it)
- The config is already there, we just need to change some arguments...Click the Arguments tab
- To configure Rancher for mysql, add something like the following to VM arguments (depending on your setup)(DO NOT PUT IT IN THE PROGRAM ARGUMENTS):
-Ddb.cattle.database=mysql
-Ddb.cattle.mysql.port=3306
-Dtask.config.item.source.version.sync.schedule=5
-Dtask.config.item.migration.schedule=5
-Didempotent.checks=false
- Apply. Debug. Rancher is running.
- Go to http://localhost:8080 to prove it.
- We need to add a compute node so that rancher has a place to drop containers. Go to http://localhost:8080. Click on "Add Host" and get the command from the UI under the Custom/Bare Metal option.
That's taken from the rancher repo's documentation. We skipped the step of starting the management server container because we're running that out of eclipse. The IP address is the default gateway that is setup by virtualbox.
Cattle Integration tests can be run either from Command Line or from an IDE, PyCharm.
Instructions for running the tests in IDE:
Please install the latest PyCharm Community Edition and launch it.
From the IDE options, select "Open" and point to $CATTLE_ROOT/tests/integration
.
Or
From the Menu: Select File
> Open
[[images/integration-tests/010.png]]
[[images/integration-tests/011.png]]
Set the python interpreter as a virtual environment:
From the Menu: Select PyCharm Community Edition
> Preferences
[[images/integration-tests/020.png]]
- On the left hand side, select
Project:${project_name}
>Project Interpreter
. - Click the gear box next to the Project Interpreter drop down on the right.
- Select "Create VirtualEnv".
[[images/integration-tests/021.png]]
Use the following information to fill out the needed information:
* Name: .venv
* Location: $CATTLE_ROOT/tests/integration/.venv
* Base Interpreter: Choose the Default OS X Python.
[[images/integration-tests/022.png]]
[[images/integration-tests/023.png]]
Note: You can setup the .venv from the command line if you prefer. PyCharm will automatically pick it up.
Create your project with the virtual environment.
- On the left hand side, select
Python Integrated Tools
- For
Package requirements file:
, select:$CATTLE_ROOT/tests/integration/requirements.txt
- For
Default test runner:
, selectpy.test
- If you get an error: "No py.test runner found ...", you can just click Fix to install it.
- Click "OK"
[[images/integration-tests/030.png]]
[[images/integration-tests/031.png]]
- Now to install the packages, there is no direct menu option since PyCharm tries to be intelligent and install on demand. So open any test file, for example:
$CATTLE_ROOT/tests/integration/cattletest/core/__init__.py
- Now a dynamic option/button "Install requirements" shows up at the top.
[[images/integration-tests/032.png]]
- Click on that and select all the requirements to install them.
[[images/integration-tests/033.png]]
Note: Another way to set up and activate the requirements file, open the terminal and run these commands.
cd $CATTLE_ROOT/tests/integration
. .venv/bin/activate
pip install -r requirements.txt
We're ready to run the integration tests.
- There's a run configuration drop down in the tool bar. It's just an empty arrow on the top right hand side. Click the Run dropdown. Click 'Edit Configurations...'
[[images/integration-tests/040.png]]
- Click on "+" >
Python tests
>py.test
and use the following information.- Name: integration-tests
- Target: $CATTLE_ROOT/tests/integration/cattletest
[[images/integration-tests/041.png]]
[[images/integration-tests/042.png]]
- Run it! It's in the drop down now. Select it and hit the green arrow.
[[images/integration-tests/043.png]]
Note: If you didn't activate the requirements file through the commands, the tests may not run immediately. If you get an error, open a specific test case by expanding cattletest > core and click on a test case. Try to run the test case and PyCharm should pop up a note to install requirements. Install the requirements and try to run the tests again.
Hopefully, you got the green bar.
You could also run the test suite via tox:
cd $CATTLE_ROOT/tests/integration
tox
YEE-HAW PARDNER! You're an official cowpoke. Now go russle up some bugs and corral 'em.
[[Cowpoke 2: Halp! (Debugging, troubleshooting, starting over)]]
[[Cowpoke-3.0:-Tutorial-introduction-and-the-Rancher-API]]