-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathREADME.txt
252 lines (165 loc) · 6.04 KB
/
README.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
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.