installer.py 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774
  1. import subprocess
  2. import os
  3. import os.path
  4. import time
  5. import traceback
  6. import sys
  7. class Installer:
  8. ############################################################
  9. # install_software
  10. ############################################################
  11. def install_software(self):
  12. if self.benchmarker.install == 'all' or self.benchmarker.install == 'server':
  13. self.__install_server_software()
  14. if self.benchmarker.install == 'all' or self.benchmarker.install == 'database':
  15. self.__install_database_software()
  16. if self.benchmarker.install == 'all' or self.benchmarker.install == 'client':
  17. self.__install_client_software()
  18. ############################################################
  19. # End install_software
  20. ############################################################
  21. ############################################################
  22. # __install_server_software
  23. ############################################################
  24. def __install_server_software(self):
  25. print("\nINSTALL: Installing server software\n")
  26. #######################################
  27. # Prerequisites
  28. #######################################
  29. self.__run_command("sudo apt-get -y update")
  30. self.__run_command("sudo apt-get -y upgrade")
  31. self.__run_command("sudo apt-get -y install build-essential libpcre3 libpcre3-dev libpcrecpp0 libssl-dev zlib1g-dev python-software-properties unzip git-core libcurl4-openssl-dev libbz2-dev libmysqlclient-dev mongodb-clients libreadline6-dev libyaml-dev libsqlite3-dev sqlite3 libxml2-dev libxslt-dev libgdbm-dev ncurses-dev automake libffi-dev htop libtool bison libevent-dev libgstreamer-plugins-base0.10-0 libgstreamer0.10-0 liborc-0.4-0 libwxbase2.8-0 libwxgtk2.8-0 libgnutls-dev libjson0-dev libmcrypt-dev libicu-dev cmake gettext curl libpq-dev mercurial mlton")
  32. self.__run_command("sudo add-apt-repository ppa:ubuntu-toolchain-r/test -y")
  33. self.__run_command("sudo apt-get -y update")
  34. self.__run_command("sudo apt-get install -y gcc-4.8 g++-4.8")
  35. self.__run_command("cp ../config/benchmark_profile ../../.bash_profile")
  36. self.__run_command("cat ../config/benchmark_profile >> ../../.profile")
  37. self.__run_command("cat ../config/benchmark_profile >> ../../.bashrc")
  38. self.__run_command(". ../../.profile")
  39. self.__run_command("sudo sh -c \"echo '* - nofile 65535' >> /etc/security/limits.conf\"")
  40. ##############################################################
  41. # System Tools
  42. ##############################################################
  43. #
  44. # Leiningen
  45. #
  46. if not self.__path_exists("bin/lein"):
  47. self.__run_command("mkdir -p bin")
  48. self.__download("https://raw.github.com/technomancy/leiningen/stable/bin/lein")
  49. self.__run_command("mv lein bin/lein")
  50. self.__run_command("chmod +x bin/lein")
  51. #
  52. # Maven
  53. #
  54. if not self.__path_exists("/usr/bin/mvn"):
  55. self.__run_command("sudo apt-get -y install maven -qq")
  56. self.__run_command("mvn -version")
  57. #######################################
  58. # Languages
  59. #######################################
  60. self._install_python()
  61. #
  62. # Dart
  63. #
  64. if not self.__path_exists("dart-sdk"):
  65. self.__download("http://storage.googleapis.com/dart-archive/channels/stable/release/latest/sdk/dartsdk-linux-x64-release.zip")
  66. self.__run_command("unzip dartsdk-linux-x64-release.zip")
  67. #
  68. # Erlang
  69. #
  70. if not self.__path_exists("/usr/bin/erl"):
  71. self.__run_command("sudo cp ../config/erlang.list /etc/apt/sources.list.d/erlang.list")
  72. self.__download("http://binaries.erlang-solutions.com/debian/erlang_solutions.asc")
  73. self.__run_command("sudo apt-key add erlang_solutions.asc")
  74. self.__run_command("sudo apt-get -y update")
  75. self.__run_command("sudo apt-get install -y esl-erlang")
  76. #
  77. # nodejs
  78. #
  79. if not self.__path_exists("node-v0.10.8-linux-x64"):
  80. self.__download("http://nodejs.org/dist/v0.10.8/node-v0.10.8-linux-x64.tar.gz")
  81. self.__run_command("tar xzf node-v0.10.8-linux-x64.tar.gz")
  82. #
  83. # Java
  84. #
  85. self.__run_command("sudo apt-get install -y openjdk-7-jdk")
  86. self.__run_command("sudo apt-get remove -y --purge openjdk-6-jre openjdk-6-jre-headless")
  87. #
  88. # Elixir
  89. #
  90. ## Should work if you run make clean test manually
  91. #if not self.__path_exists("v0.13.3.tar.gz"):
  92. # self.__run_command("wget https://github.com/elixir-lang/elixir/archive/v0.13.3.tar.gz");
  93. # self.__run_command("sudo tar -zxf v0.13.3.tar.gz");
  94. # self.__run_command("bash -c -i 'sudo make install'", cwd="elixir-0.13.3");
  95. #self.__run_command("sudo make clean", cwd="elixir-0.13.3");
  96. #self.__run_command("sudo make test", cwd="elixir-0.13.3");
  97. #
  98. # Ruby/JRuby
  99. #
  100. self.__run_command("curl -L get.rvm.io | bash -s head --auto-dotfiles")
  101. self.__run_command("echo rvm_auto_reload_flag=2 >> ~/.rvmrc")
  102. if not self.__path_exists("../../.rvm/rubies/ruby-2.0.0-p0/"):
  103. self.__bash_from_string("source ~/.rvm/scripts/'rvm' && rvm install 2.0.0-p0")
  104. self.__bash_from_string("source ~/.rvm/scripts/'rvm' && rvm 2.0.0-p0 do gem install bundler")
  105. if not self.__path_exists("../../.rvm/rubies/jruby-1.7.8/"):
  106. self.__bash_from_string("source ~/.rvm/scripts/'rvm' && rvm install jruby-1.7.8")
  107. self.__bash_from_string("source ~/.rvm/scripts/'rvm' && rvm jruby-1.7.8 do gem install bundler")
  108. #
  109. # go
  110. #
  111. if not self.__path_exists("go"):
  112. self.__download("https://storage.googleapis.com/golang/go1.3.linux-amd64.tar.gz");
  113. self.__run_command("tar xzf go1.3.linux-amd64.tar.gz")
  114. #
  115. # Perl
  116. #
  117. if not self.__path_exists("perl-5.18"):
  118. self.__download("https://raw.githubusercontent.com/tokuhirom/Perl-Build/master/perl-build", "perl-build.pl")
  119. self.__run_command("perl perl-build.pl -DDEBUGGING=-g 5.18.2 ~/FrameworkBenchmarks/installs/perl-5.18", retry=True)
  120. self.__download("http://cpanmin.us", "cpanminus.pl")
  121. self.__run_command("~/FrameworkBenchmarks/installs/perl-5.18/bin/perl cpanminus.pl --notest --no-man-page App::cpanminus", retry=True)
  122. self.__run_command("~/FrameworkBenchmarks/installs/perl-5.18/bin/cpanm -f --notest --no-man-page DBI DBD::mysql Kelp Dancer Mojolicious Kelp::Module::JSON::XS Dancer::Plugin::Database Starman Plack JSON Web::Simple DBD::Pg JSON::XS EV HTTP::Parser::XS Monoceros EV IO::Socket::IP IO::Socket::SSL Memoize", retry=True)
  123. #
  124. # php
  125. #
  126. if not self.__path_exists("/usr/local/bin/php"):
  127. self.__download("http://museum.php.net/php5/php-5.4.13.tar.gz")
  128. self.__run_command("tar xzf php-5.4.13.tar.gz")
  129. self.__run_command("./configure --with-pdo-mysql --with-mysql --with-mcrypt --enable-intl --enable-mbstring --enable-fpm --with-fpm-user=www-data --with-fpm-group=www-data --with-openssl", cwd="php-5.4.13")
  130. self.__run_command("make", cwd="php-5.4.13")
  131. self.__run_command("sudo make install", cwd="php-5.4.13")
  132. if not self.__path_exists("/usr/local/lib/php/extensions/no-debug-non-zts-20100525/apc.so"):
  133. self.__run_command("printf \"\\n\" | sudo pecl install apc-beta", cwd="php-5.4.13", retry=True)
  134. self.__run_command("sudo cp ../config/php.ini /usr/local/lib/php.ini")
  135. self.__run_command("sudo cp ../config/php-fpm.conf /usr/local/lib/php-fpm.conf")
  136. # Composer
  137. if not self.__path_exists("bin/composer.phar"):
  138. self.__download("https://getcomposer.org/installer", "composer-installer.php")
  139. self.__run_command("php composer-installer.php --install-dir=bin")
  140. # Phalcon
  141. if not self.__path_exists("/usr/local/lib/php/extensions/no-debug-non-zts-20100525/phalcon.so"):
  142. self.__run_command("test -d cphalcon || git clone git://github.com/phalcon/cphalcon.git", retry=True)
  143. self.__run_command("sudo ./install", cwd="cphalcon/build")
  144. # YAF
  145. if not self.__path_exists("/usr/local/lib/php/extensions/no-debug-non-zts-20100525/yaf.so"):
  146. self.__run_command("sudo pecl install -f yaf")
  147. #
  148. # Haskell
  149. #
  150. if not self.__path_exists("/usr/bin/haskell-compiler"): ##not sure if right
  151. self.__run_command("sudo apt-get install -y ghc cabal-install")
  152. #
  153. # RingoJs
  154. #
  155. if not self.__path_exists("/usr/share/ringojs"):
  156. self.__download("http://www.ringojs.org/downloads/ringojs_0.10-1_all.deb")
  157. self.__run_command("sudo apt-get install -y jsvc")
  158. self.__run_command("sudo dpkg -i ringojs_0.10-1_all.deb", True)
  159. self.__run_command("rm ringojs_0.10-1_all.deb")
  160. #
  161. # Mono
  162. #
  163. if not self.__path_exists("mono-3.2.8"):
  164. self.__download("http://download.mono-project.com/sources/mono/mono-3.2.8.tar.bz2", "mono-3.2.8.tar.bz2")
  165. self.__run_command("tar xf mono-3.2.8.tar.bz2")
  166. self.__run_command("./configure --disable-nls --prefix=/usr/local", cwd="mono-3.2.8")
  167. self.__run_command("make get-monolite-latest", cwd="mono-3.2.8")
  168. self.__run_command("make -j4 EXTERNAL_MCS=${PWD}/mcs/class/lib/monolite/basic.exe", cwd="mono-3.2.8")
  169. self.__run_command("sudo make install", cwd="mono-3.2.8")
  170. self.__run_command("mv mono-3.2.8 mono");
  171. self.__run_command("mozroots --import --sync", retry=True)
  172. if not self.__path_exists("xsp"):
  173. self.__run_command("git clone --depth 1 git://github.com/mono/xsp", retry=True)
  174. self.__run_command("./autogen.sh --prefix=/usr/local", cwd="xsp")
  175. self.__run_command("make", cwd="xsp")
  176. self.__run_command("sudo make install", cwd="xsp")
  177. #
  178. # Nimrod
  179. #
  180. if not self.__path_exists("nimrod/bin/nimrod"):
  181. self.__run_command("test -d nimrod || git clone git://github.com/Araq/Nimrod.git nimrod", retry=True)
  182. self.__run_command("git checkout 987ac2439a87d74838233a7b188e4db340495ee5", cwd="nimrod")
  183. self.__run_command("test -d csources || git clone git://github.com/nimrod-code/csources.git", cwd="nimrod", retry=True)
  184. self.__run_command("git checkout 704015887981932c78a033dd5ede623b2ad6ae27", cwd="nimrod/csources");
  185. self.__run_command("chmod +x build.sh", cwd="nimrod/csources")
  186. self.__run_command("./build.sh", cwd="nimrod/csources")
  187. if not self.__path_exists("nimrod/koch"):
  188. self.__run_command("bin/nimrod c koch", cwd="nimrod")
  189. self.__run_command("./koch boot -d:release", cwd="nimrod")
  190. #
  191. # Racket
  192. #
  193. if not self.__path_exists("racket-5.3.6/bin/racket") or not self.__path_exists("racket-5.3.6/collects/racket"):
  194. self.__download("https://github.com/plt/racket/archive/v5.3.6.tar.gz", "racket-5.3.6.tar.gz")
  195. self.__run_command("tar xzf racket-5.3.6.tar.gz")
  196. self.__run_command("./configure", cwd="racket-5.3.6/src")
  197. self.__run_command("make", cwd="racket-5.3.6/src")
  198. self.__run_command("sudo make install", cwd="racket-5.3.6/src")
  199. #
  200. # Ur/Web
  201. #
  202. if not self.__path_exists("/usr/local/bin/urweb"):
  203. self.__run_command("hg clone http://hg.impredicative.com/urweb")
  204. self.__run_command("./autogen.sh", cwd="urweb")
  205. self.__run_command("./configure", cwd="urweb")
  206. self.__run_command("make", cwd="urweb")
  207. self.__run_command("sudo make install", cwd="urweb")
  208. #
  209. # HHVM
  210. #
  211. if not self.__path_exists("/usr/bin/hhvm"):
  212. self.__run_command("sudo add-apt-repository -y ppa:mapnik/v2.2.0")
  213. self.__run_command("wget -O - http://dl.hhvm.com/conf/hhvm.gpg.key | sudo apt-key add -")
  214. self.__run_command("echo deb http://dl.hhvm.com/ubuntu trusty main | sudo tee /etc/apt/sources.list.d/hhvm.list")
  215. self.__run_command("sudo apt-get update")
  216. self.__run_command("sudo apt-get install -y hhvm")
  217. #######################################
  218. # Webservers
  219. #######################################
  220. #
  221. # Nginx
  222. #
  223. if not self.__path_exists("/usr/local/nginx/sbin/nginx"):
  224. self.__download("http://nginx.org/download/nginx-1.4.1.tar.gz")
  225. self.__run_command("tar xzf nginx-1.4.1.tar.gz")
  226. self.__run_command("./configure", cwd="nginx-1.4.1")
  227. self.__run_command("make", cwd="nginx-1.4.1")
  228. self.__run_command("sudo make install", cwd="nginx-1.4.1")
  229. #
  230. # Openresty (nginx with lua stuff)
  231. #
  232. if not self.__path_exists("/usr/local/openresty/nginx/sbin/nginx"):
  233. self.__download("http://openresty.org/download/ngx_openresty-1.5.8.1.tar.gz")
  234. self.__run_command("tar xzf ngx_openresty-1.5.8.1.tar.gz")
  235. self.__run_command("./configure --with-luajit --with-http_postgres_module", cwd="ngx_openresty-1.5.8.1")
  236. self.__run_command("make", cwd="ngx_openresty-1.5.8.1")
  237. self.__run_command("sudo make install", cwd="ngx_openresty-1.5.8.1")
  238. #
  239. # Lapis
  240. #
  241. if not self.__path_exists("/usr/local/bin/lapis"):
  242. self.__run_command("sudo apt-get install -y luarocks")
  243. self.__run_command("sudo luarocks install http://github.com/leafo/lapis/raw/master/lapis-dev-1.rockspec")
  244. #
  245. # Resin
  246. #
  247. if not self.__path_exists("resin-4.0.36/conf/resin.xml"):
  248. self.__run_command("sudo cp -r /usr/lib/jvm/java-1.7.0-openjdk-amd64/include /usr/lib/jvm/java-1.7.0-openjdk-amd64/jre/bin/")
  249. self.__download("http://www.caucho.com/download/resin-4.0.36.tar.gz")
  250. self.__run_command("tar xzf resin-4.0.36.tar.gz")
  251. self.__run_command("./configure --prefix=`pwd`", cwd="resin-4.0.36")
  252. self.__run_command("make", cwd="resin-4.0.36")
  253. self.__run_command("make install", cwd="resin-4.0.36")
  254. self.__run_command("mv conf/resin.properties conf/resin.properties.orig", cwd="resin-4.0.36")
  255. self.__run_command("cat ../config/resin.properties > resin-4.0.36/conf/resin.properties")
  256. self.__run_command("mv conf/resin.xml conf/resin.xml.orig", cwd="resin-4.0.36")
  257. self.__run_command("cat ../config/resin.xml > resin-4.0.36/conf/resin.xml")
  258. #
  259. # Mongrel2
  260. #
  261. if not self.__path_exists("/usr/local/lib/libzmq.a"):
  262. self.__download("http://download.zeromq.org/zeromq-4.0.3.tar.gz")
  263. self.__run_command("tar xzf zeromq-4.0.3.tar.gz")
  264. self.__run_command("./configure", cwd="zeromq-4.0.3")
  265. self.__run_command("make", cwd="zeromq-4.0.3")
  266. self.__run_command("sudo make install", cwd="zeromq-4.0.3")
  267. self.__run_command("sudo apt-get install -y sqlite3 libsqlite3-dev uuid uuid-runtime uuid-dev")
  268. self.__run_command("sudo ldconfig -v")
  269. if not self.__path_exists("/usr/local/bin/mongrel2"):
  270. self.__download("https://github.com/zedshaw/mongrel2/tarball/v1.8.1", "mongrel2.tar.gz")
  271. self.__run_command("tar xvf mongrel2.tar.gz")
  272. self.__run_command("mv zedshaw-mongrel2-aa2ecf8 mongrel2")
  273. # for zmq4, we update the following file manually (not in v1.8.1)
  274. self.__download("https://raw.github.com/zedshaw/mongrel2/9b565eeea003783c47502c2d350b99c9684ce97c/src/zmq_compat.h")
  275. self.__run_command("mv -f zmq_compat.h mongrel2/src/")
  276. self.__run_command("make clean all && sudo make install", cwd="mongrel2")
  277. #
  278. # Weber
  279. #
  280. # if not self.__path_exists("weber"):
  281. # self.__run_command("git clone https://github.com/elixir-web/weber.git");
  282. # To get the two make commands working, we need to hard code the path for elixir's "mix"
  283. #self.__run_command("sed -i 's:$(MIX):/home/tfb/FrameworkBenchmarks/installs/elixir-0.13.3/bin/mix:' Makefile", cwd="weber")
  284. #self.__run_command("bash -i -c 'make'", cwd="weber");
  285. # self.__run_command("make", cwd="weber");
  286. #self.__run_command("bash -i -c 'sudo make test'", cwd="weber");
  287. ##############################################################
  288. # Frameworks
  289. ##############################################################
  290. #
  291. # Grails
  292. #
  293. if not self.__path_exists("grails-2.4.2"):
  294. self.__download("http://dist.springframework.org.s3.amazonaws.com/release/GRAILS/grails-2.4.2.zip")
  295. self.__run_command("unzip -o grails-2.4.2.zip")
  296. #
  297. # Play 2
  298. #
  299. if not self.__path_exists("play-2.2.0"):
  300. self.__download("http://downloads.typesafe.com/play/2.2.0/play-2.2.0.zip")
  301. self.__run_command("unzip -o play-2.2.0.zip")
  302. #
  303. # Play 1
  304. #
  305. if not self.__path_exists("play-1.2.5"):
  306. self.__download("http://downloads.typesafe.com/releases/play-1.2.5.zip")
  307. self.__run_command("unzip -o play-1.2.5.zip")
  308. self.__run_command("mv play-1.2.5/play play-1.2.5/play1")
  309. # siena
  310. self.__run_command("yes | play-1.2.5/play1 install siena")
  311. #
  312. # TreeFrog Framework
  313. #
  314. if not self.__path_exists("/usr/bin/treefrog") or not self.__path_exists("/usr/bin/tspawn"):
  315. self.__run_command("sudo apt-get install -y qt4-qmake libqt4-dev libqt4-sql-mysql libqt4-sql-psql g++")
  316. self.__download("http://downloads.sourceforge.net/project/treefrog/src/treefrog-1.7.5.tar.gz")
  317. self.__run_command("tar xzf treefrog-1.7.5.tar.gz")
  318. self.__run_command("rm treefrog-1.7.5.tar.gz")
  319. self.__run_command("./configure", cwd="treefrog-1.7.5")
  320. self.__run_command("make", cwd="treefrog-1.7.5/src")
  321. self.__run_command("sudo make install", cwd="treefrog-1.7.5/src")
  322. self.__run_command("make", cwd="treefrog-1.7.5/tools")
  323. self.__run_command("sudo make install", cwd="treefrog-1.7.5/tools")
  324. #
  325. # Vert.x
  326. #
  327. if not self.__path_exists("vert.x-2.1.1"):
  328. self.__download("http://dl.bintray.com/vertx/downloads/vert.x-2.1.1.tar.gz?direct=true", "vert.x-2.1.1.tar.gz")
  329. self.__run_command("tar xzf vert.x-2.1.1.tar.gz")
  330. #
  331. # Yesod
  332. #
  333. self.__run_command("cabal update", retry=True)
  334. self.__run_command("cabal install yesod persistent-mysql", retry=True)
  335. #
  336. # Jester
  337. #
  338. if not self.__path_exists("jester"):
  339. self.__run_command("git clone git://github.com/dom96/jester.git jester/jester", retry=True)
  340. #
  341. # Onion
  342. #
  343. if not self.__path_exists("onion"):
  344. self.__run_command("git clone https://github.com/davidmoreno/onion.git")
  345. self.__run_command("mkdir build", cwd="onion")
  346. self.__run_command("cmake ..", cwd="onion/build")
  347. self.__run_command("make", cwd="onion/build")
  348. # nawak
  349. #
  350. if not self.__path_exists("nawak"):
  351. self.__run_command("git clone git://github.com/idlewan/nawak.git nawak/nawak", retry=True)
  352. self.__run_command("sudo apt-get -y autoremove || true");
  353. #
  354. # Wt
  355. #
  356. if not self.__path_exists("nawak"):
  357. self.__run_command("sudo apt-get install libboost1.54-all-dev")
  358. self.__download("http://downloads.sourceforge.net/witty/wt-3.3.3.tar.gz", filename="wt.tar.gz")
  359. self.__run_command("tar xf wt.tar.gz")
  360. self.__run_command("rm wt.tar.gz")
  361. self.__run_command("bash -c 'mv wt-* wt'")
  362. self.__run_command("mkdir build", cwd="wt")
  363. self.__run_command("cmake .. -DWT_CPP_11_MODE=-std=c++0x -DCMAKE_BUILD_TYPE=Release", cwd="wt/build")
  364. self.__run_command("make", cwd="wt/build")
  365. self.__run_command("sudo make install", cwd="wt/build")
  366. print("\nINSTALL: Finished installing server software\n")
  367. ############################################################
  368. # End __install_server_software
  369. ############################################################
  370. def _install_python(self):
  371. """Install Python runtime, frameworks and libraries"""
  372. # PyPy 2.3.1
  373. f = "pypy-2.3.1-linux64.tar.bz2"
  374. #if not os.path.exists(f):
  375. if not self.__path_exists("pypy"):
  376. self.__download("https://bitbucket.org/pypy/pypy/downloads/" + f, f)
  377. self.__run_command("tar xf " + f)
  378. self.__run_command('ln -sf pypy-2.3.1-linux64 pypy')
  379. # CPython 2.7.7
  380. f = "Python-2.7.7.tgz"
  381. #if not os.path.exists("py2"):
  382. if not self.__path_exists("py2"):
  383. self.__download("http://www.python.org/ftp/python/2.7.7/" + f, f)
  384. self.__run_command("tar xf " + f)
  385. self.__run_command("./configure --prefix=$HOME/FrameworkBenchmarks/installs/py2 --disable-shared", cwd="Python-2.7.7")
  386. self.__run_command("make -j4", cwd="Python-2.7.7")
  387. self.__run_command("make install", cwd="Python-2.7.7")
  388. # CPython 3.4.1
  389. f = "Python-3.4.1.tar.xz"
  390. if not self.__path_exists("py3"):
  391. #if not os.path.exists("py3"):
  392. self.__download("https://www.python.org/ftp/python/3.4.1/" + f, f)
  393. self.__run_command("tar xf " + f)
  394. self.__run_command("./configure --prefix=$HOME/FrameworkBenchmarks/installs/py3 --disable-shared", cwd="Python-3.4.1")
  395. self.__run_command("make -j4", cwd="Python-3.4.1")
  396. self.__run_command("make install", cwd="Python-3.4.1")
  397. if not self.__path_exists("get-pip.py"):
  398. #if not os.path.exists("get-pip.py"):
  399. self.__download("https://bootstrap.pypa.io/get-pip.py", "get-pip.py")
  400. self.__run_command("py2/bin/python get-pip.py")
  401. self.__run_command("pypy/bin/pypy get-pip.py")
  402. # Python 3.4.1 installs pip by default.
  403. self.__run_command('py2/bin/pip install -r ../config/requirements.txt')
  404. self.__run_command('py3/bin/pip3 install -r ../config/requirements-py3.txt')
  405. self.__run_command('pypy/bin/pip install -r ../config/requirements-pypy.txt')
  406. ############################################################
  407. # __install_error
  408. ############################################################
  409. def __install_error(self, message):
  410. print("\nINSTALL ERROR: %s\n" % message)
  411. if self.benchmarker.install_error_action == 'abort':
  412. sys.exit("Installation aborted.")
  413. ############################################################
  414. # End __install_error
  415. ############################################################
  416. ############################################################
  417. # __install_database_software
  418. ############################################################
  419. def __install_database_software(self):
  420. print("\nINSTALL: Installing database software\n")
  421. self.__run_command("cd .. && " + self.benchmarker.database_sftp_string(batch_file="../config/database_sftp_batch"), True)
  422. remote_script = """
  423. ##############################
  424. # Prerequisites
  425. ##############################
  426. sudo apt-get -y update
  427. sudo apt-get -y install build-essential git libev-dev libpq-dev libreadline6-dev postgresql
  428. sudo sh -c "echo '* - nofile 65535' >> /etc/security/limits.conf"
  429. sudo mkdir -p /ssd
  430. sudo mkdir -p /ssd/log
  431. ##############################
  432. # MySQL
  433. ##############################
  434. sudo sh -c "echo mysql-server mysql-server/root_password_again select secret | debconf-set-selections"
  435. sudo sh -c "echo mysql-server mysql-server/root_password select secret | debconf-set-selections"
  436. sudo apt-get -y install mysql-server-5.6
  437. sudo stop mysql
  438. # disable checking of disk size
  439. sudo cp mysql /etc/init.d/mysql
  440. sudo chmod +x /etc/init.d/mysql
  441. sudo cp mysql.conf /etc/init/mysql.conf
  442. # use the my.cnf file to overwrite /etc/mysql/my.cnf
  443. sudo mv /etc/mysql/my.cnf /etc/mysql/my.cnf.orig
  444. sudo mv my.cnf /etc/mysql/my.cnf
  445. sudo cp -R -p /var/lib/mysql /ssd/
  446. sudo cp -R -p /var/log/mysql /ssd/log
  447. sudo cp usr.sbin.mysqld /etc/apparmor.d/
  448. sudo /etc/init.d/apparmor reload
  449. sudo start mysql
  450. # Insert data
  451. mysql -uroot -psecret < create.sql
  452. ##############################
  453. # Postgres
  454. ##############################
  455. sudo useradd benchmarkdbuser -p benchmarkdbpass
  456. sudo -u postgres psql template1 < create-postgres-database.sql
  457. sudo -u benchmarkdbuser psql hello_world < create-postgres.sql
  458. sudo -u postgres -H /etc/init.d/postgresql stop
  459. sudo mv postgresql.conf /etc/postgresql/9.3/main/postgresql.conf
  460. sudo mv pg_hba.conf /etc/postgresql/9.3/main/pg_hba.conf
  461. sudo cp -R -p /var/lib/postgresql/9.3/main /ssd/postgresql
  462. sudo -u postgres -H /etc/init.d/postgresql start
  463. sudo mv 60-postgresql-shm.conf /etc/sysctl.d/60-postgresql-shm.conf
  464. ##############################
  465. # MongoDB
  466. ##############################
  467. sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 7F0CEB10
  468. sudo cp 10gen.list /etc/apt/sources.list.d/10gen.list
  469. sudo apt-get -y update
  470. sudo apt-get -y remove mongodb-clients
  471. sudo apt-get -y install mongodb-10gen
  472. sudo stop mongodb
  473. sudo mv /etc/mongodb.conf /etc/mongodb.conf.orig
  474. sudo mv mongodb.conf /etc/mongodb.conf
  475. sudo cp -R -p /var/lib/mongodb /ssd/
  476. sudo cp -R -p /var/log/mongodb /ssd/log/
  477. sudo start mongodb
  478. ##############################
  479. # Apache Cassandra
  480. ##############################
  481. export CASS_V=2.0.7
  482. wget http://www.apache.org/dist/cassandra/$CASS_V/apache-cassandra-$CASS_V-bin.tar.gz
  483. tar xzf apache-cassandra-$CASS_V-bin.tar.gz
  484. rm apache-cassandra-*-bin.tar.gz
  485. fuser -k -TERM /ssd/log/cassandra/system.log
  486. sleep 5
  487. rm -rf /ssd/cassandra
  488. rm /ssd/log/cassandra/system.log
  489. cp cassandra/cassandra.yaml apache-cassandra-$CASS_V/conf
  490. cp cassandra/log4j-server.properties apache-cassandra-$CASS_V/conf
  491. pushd apache-cassandra-$CASS_V
  492. ./bin/cassandra
  493. sleep 5
  494. cat ../cassandra/create-keyspace.cql | ./bin/cqlsh tfbdata
  495. python ../cassandra/db-data-gen.py | ./bin/cqlsh tfbdata
  496. popd
  497. """
  498. print("\nINSTALL: %s" % self.benchmarker.database_ssh_string)
  499. p = subprocess.Popen(self.benchmarker.database_ssh_string.split(" "), stdin=subprocess.PIPE)
  500. p.communicate(remote_script)
  501. returncode = p.returncode
  502. if returncode != 0:
  503. self.__install_error("status code %s running subprocess '%s'." % (returncode, self.benchmarker.database_ssh_string))
  504. print("\nINSTALL: Finished installing database software\n")
  505. ############################################################
  506. # End __install_database_software
  507. ############################################################
  508. ############################################################
  509. # __install_client_software
  510. ############################################################
  511. def __install_client_software(self):
  512. print("\nINSTALL: Installing client software\n")
  513. remote_script = """
  514. ##############################
  515. # Prerequisites
  516. ##############################
  517. sudo apt-get -y update
  518. sudo apt-get -y install build-essential git libev-dev libpq-dev libreadline6-dev
  519. sudo sh -c "echo '* - nofile 65535' >> /etc/security/limits.conf"
  520. ##############################
  521. # wrk
  522. ##############################
  523. git clone https://github.com/wg/wrk.git
  524. cd wrk
  525. make
  526. sudo cp wrk /usr/local/bin
  527. cd ~
  528. #############################
  529. # pipeline.lua
  530. #############################
  531. cat << EOF | tee pipeline.lua
  532. init = function(args)
  533. wrk.init(args)
  534. local r = {}
  535. local depth = tonumber(args[1]) or 1
  536. for i=1,depth do
  537. r[i] = wrk.format()
  538. end
  539. req = table.concat(r)
  540. end
  541. request = function()
  542. return req
  543. end
  544. EOF
  545. """
  546. print("\nINSTALL: %s" % self.benchmarker.client_ssh_string)
  547. p = subprocess.Popen(self.benchmarker.client_ssh_string.split(" "), stdin=subprocess.PIPE)
  548. p.communicate(remote_script)
  549. returncode = p.returncode
  550. if returncode != 0:
  551. self.__install_error("status code %s running subprocess '%s'." % (returncode, self.benchmarker.client_ssh_string))
  552. print("\nINSTALL: Finished installing client software\n")
  553. ############################################################
  554. # End __install_client_software
  555. ############################################################
  556. ############################################################
  557. # __path_exists
  558. ############################################################
  559. def __path_exists(self, path, cwd=None):
  560. full_path = os.path.join(cwd or self.install_dir, path)
  561. if os.path.exists(full_path):
  562. print("\nEXISTS: %s " % full_path)
  563. return True
  564. print("\nNOT_EXISTS: %s" % full_path)
  565. return False
  566. ############################################################
  567. # End __path_exists
  568. ############################################################
  569. ############################################################
  570. # __run_command
  571. ############################################################
  572. def __run_command(self, command, send_yes=False, cwd=None, retry=False):
  573. try:
  574. cwd = os.path.join(self.install_dir, cwd)
  575. except AttributeError:
  576. cwd = self.install_dir
  577. if retry:
  578. max_attempts = 5
  579. else:
  580. max_attempts = 1
  581. attempt = 1
  582. delay = 0
  583. if send_yes:
  584. command = "yes yes | " + command
  585. print("\nINSTALL: %s (cwd=%s)" % (command, cwd))
  586. while attempt <= max_attempts:
  587. error_message = ""
  588. try:
  589. ##print "working in " + cwd + " on " + command
  590. # Execute command.
  591. """if command == "make clean":
  592. print "make clean if statment"
  593. time.sleep(5)
  594. subprocess.check_call("make clean", shell=False, cwd=cwd)
  595. break"""
  596. subprocess.check_call(command, shell=True, cwd=cwd)
  597. """if send_yes:
  598. process = subprocess.Popen(["/bin/bash", "-c", command], shell=False, stdin=subprocess.PIPE, cwd=cwd)
  599. process.communicate("yes")
  600. returncode = process.returncode
  601. if returncode:
  602. raise subprocess.CalledProcessError(returncode, command)
  603. else:
  604. subprocess.check_call(["/bin/bash", "-c", command], shell=False, cwd=cwd)"""
  605. break # Exit loop if successful.
  606. except:
  607. exceptionType, exceptionValue, exceptionTraceBack = sys.exc_info()
  608. error_message = "".join(traceback.format_exception_only(exceptionType, exceptionValue))
  609. print error_message
  610. # Exit if there are no more attempts left.
  611. attempt += 1
  612. if attempt > max_attempts:
  613. break
  614. # Delay before next attempt.
  615. if delay == 0:
  616. delay = 5
  617. else:
  618. delay = delay * 2
  619. print("Attempt %s/%s starting in %s seconds." % (attempt, max_attempts, delay))
  620. time.sleep(delay)
  621. if error_message:
  622. self.__install_error(error_message)
  623. ############################################################
  624. # End __run_command
  625. ############################################################
  626. ############################################################
  627. # __bash_from_string
  628. # Runs bash -c "command" in install_dir.
  629. ############################################################
  630. def __bash_from_string(self, command):
  631. self.__run_command('bash -c "%s"' % command)
  632. ############################################################
  633. # End __bash_from_string
  634. ############################################################
  635. ############################################################
  636. # __download
  637. # Downloads a file from a URI.
  638. ############################################################
  639. def __download(self, uri, filename=""):
  640. if filename:
  641. if os.path.exists(filename):
  642. return
  643. filename_option = "-O %s " % filename
  644. else:
  645. filename_option = ""
  646. command = "wget -nv --no-check-certificate --trust-server-names %s%s" % (filename_option, uri)
  647. self.__run_command(command, retry=True)
  648. ############################################################
  649. # End __download
  650. ############################################################
  651. ############################################################
  652. # __init__(benchmarker)
  653. ############################################################
  654. def __init__(self, benchmarker):
  655. self.benchmarker = benchmarker
  656. self.install_dir = "installs"
  657. try:
  658. os.mkdir(self.install_dir)
  659. except OSError:
  660. pass
  661. ############################################################
  662. # End __init__
  663. ############################################################
  664. # vim: sw=2