/etm-core

Main logic of the controller.

Primary LanguageJavaApache License 2.0Apache-2.0

EEEEE     TTTTT     M   M
E           T       MM MM
EEEEE       T       M M M
E           T       M   M
EEEEE       T       M   M
---------------------------
Edmunds  Traffic   Manager


Alpha Release (1.0.1)
===
This is an alpha release, the code itself is fairly high quality (it is used to power the Edmunds production website).
However the conversion from internal tool to an open source product is Alpha.

We have simply exposed the internal details of how we run ETM internally.

There are three primary implications of this, you will need to:
1.> Either modify the source or deploy the components to the same file locations as we use.
2.> Use a lot of property files or create DNS text records to reconfigure ETM.
3.> Implement the load balancer module yourself to control your load-balancer **

** - We have not released the load balancer module as it would only be useful to others who use the identical load balancer.
     And there are some licensing restrictions.


Technology Support.
===
We build ETM on Mac (tm) and Deploy on Linux (tm) we do not expect it to work on Windows (tm).

We use a very specific set of technologies:

Apache Httpd     - We depend upon the RegEx based (mod_rewrite) support in order to route URL's.
Apache Tomcat    - Our port detection code for the etm-client library only works on tomcat.
Apache ZooKeeper - Is required for all interprocess communication.
Apache Thrift    - Used to serialized beans into Zookeeper.
Apache Maven     - We identify artifacts by their maven co-ordinates.
Hotspot JVM      - Not tested on any other JVM's.

We have made no effort to support other technologies as a result you are likely to experience a lot of pain if you try to use alternatives.



Edmunds Hacks
===

By default ETM uses the following directories:

sudo mkdir -p /apps/apache-httpd/bin
sudo mkdir -p /deployments/edmunds/properties/common
sudo mkdir -p /logs
sudo mkdir -p /var/lib/etm-agent

The quickest way to get ETM up and running is simply to create these directories and set them world writable (chmod 777)
However ensuring they are writable to the user you are going to use for ETM should work too.

You will also need to create two files:


/apps/apache-httpd/bin/apachectl   (Make sure this file is executable chmod +x)

--Start--
#!/bin/bash

exit 0
--End--


/deployments/edmunds/properties/common/test-app-etm.properties


--Start--
etmClientSettings.enabled=true
--End--


Finally ETM will execute the command:

sudo service httpd restart

Make sure that this command will succeed when executed as the ETM user.



Downloading Supporting Software
===
wget http://download.oracle.com/otn-pub/java/jdk/6u27-b07/jdk-6u27-linux-x64-rpm.bin
wget http://mirrors.200p-sf.sonic.net/apache/tomcat/tomcat-6/v6.0.33/bin/apache-tomcat-6.0.33.tar.gz
wget http://apache.cs.utah.edu/zookeeper/zookeeper-3.3.3/zookeeper-3.3.3.tar.gz
wget http://www.eng.lsu.edu/mirrors/apache//maven/binaries/apache-maven-3.0.3-bin.tar.gz

Note: We test with Sun (tm) JDK version 1.6, if you have problems with any other version please re-test with this version before logging any bugs. 


The version of thrift we use is really old (0.2.0), hence it is only available in source form:
svn co http://svn.apache.org/repos/asf/thrift/tags/thrift-0.2.0

We also need old versions of the thrift support jar and and maven plugins:
wget http://maven.twttr.com/thrift/libthrift/0.2.0/libthrift-0.2.0.jar
wget https://github.com/dtrott/maven-thrift-plugin/zipball/maven-thrift-plugin-0.1.9 -O maven-thrift-plugin-0.1.9-src.zip



Cloning the ETM source repositories
===

git clone git://github.com/edmunds/automated-test.git
git clone git://github.com/edmunds/edmunds-configuration.git
git clone git://github.com/edmunds/zookeeper-common.git
git clone git://github.com/edmunds/etm-api.git
git clone git://github.com/edmunds/etm-client.git
git clone git://github.com/edmunds/etm-core.git
git clone git://github.com/edmunds/etm-agent.git


Setting up your Build environment
===
Install the Hotspot JDK and add it to your Path.

Unpack maven we assume to: /usr/local/share/maven
Add the maven environment variables to your environment:

--Start--
M2_HOME=/usr/local/share/maven
export M2_HOME

PATH=$PATH:$HOME/bin:$M2_HOME/bin
export PATH
--End--


Install Thrift components
===

Compile old thrift code generator:

--Start--
cd thrift-0.2.0
./bootstrap.sh
./configure
cd compiler/cpp
make
sudo cp thrift /usr/bin
--End--

Install Lib Thrift into maven repository

--Start--
mvn install:install-file -DgroupId=org.apache.thrift -DartifactId=libthrift -Dversion=0.2.0 -Dpackaging=jar -Dfile=libthrift-0.2.0.jar
--End--


Build and install maven thrift plugin version 0.9.0

--Start--
unzip maven-thrift-plugin-0.1.9-src.zip
cd dtrott-maven-thrift-plugin-eb9d203
mvn install
--End--





Compile ETM
===

--Start--
cd  automated-test
mvn install

cd  edmunds-configuration
mvn install

cd  zookeeper-common
mvn install

cd  etm-api
mvn install

cd  etm-client
mvn install

cd  etm-core
mvn install

cd  etm-agent
mvn install
--End--



Setup Deployment Environment
==

Unpack Zookeeper and Tomcat:
--Start--
tar -zvxf zookeeper-3.3.3.tar.gz
tar -zvxf apache-tomcat-6.0.33.tar.gz
--End--

Create file:  zookeeper-3.3.3/conf/zoo.cfg

--Start--
clientPort=2181
dataDir=/tmp/zoo
tickTime=2000
--End--

Start ZooKeeper and Tomcat

--Start--
cd zookeeper-3.3.3/bin
./zkServer.sh start
cd ../apache-tomcat-6.0.33/bin
./startup.sh
--End--





Install ETM Controller
==
--Start--
cp etm-core/etm-controller/target/etm-controller.war apache-tomcat-6.0.33/webapps
--End--


To test open a browser to:
http://localhost:8080/etm-controller/applications.htm


Install Test Application
==
--Start--
cp etm-client/test-app/target/test-app.war apache-tomcat-6.0.33/webapps
--Start--

Refresh the browser (http://localhost:8080/etm-controller/applications.htm) to verify the test application has registered.


Unpack and start the ETM agent.
==
--Start--
mkdir etm-agent/target/etm-agent
cd etm-agent/target/etm-agent
unzip ../etm-agent.zip
chmod 755 *.sh
./start.sh -fg
--End--

Go to the agents tab (http://localhost:8080/etm-controller/agents.htm) to verify if the agent is operating normally.