installer.py 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495
  1. import subprocess
  2. import os
  3. import time
  4. class Installer:
  5. ############################################################
  6. # install_software
  7. ############################################################
  8. def install_software(self):
  9. if self.benchmarker.install == 'all' or self.benchmarker.install == 'server':
  10. self.__install_server_software()
  11. if self.benchmarker.install == 'all' or self.benchmarker.install == 'client':
  12. self.__install_client_software()
  13. ############################################################
  14. # End install_software
  15. ############################################################
  16. ############################################################
  17. # __install_server_software
  18. ############################################################
  19. def __install_server_software(self):
  20. #######################################
  21. # Prerequisites
  22. #######################################
  23. self.__run_command("sudo apt-get update", True)
  24. self.__run_command("sudo apt-get upgrade", True)
  25. self.__run_command("sudo apt-get 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", True)
  26. self.__run_command("sudo add-apt-repository ppa:ubuntu-toolchain-r/test", True)
  27. self.__run_command("sudo apt-get update", True)
  28. self.__run_command("sudo apt-get install gcc-4.8 g++-4.8", True)
  29. self.__run_command("cp ../config/benchmark_profile ../../.bash_profile")
  30. self.__run_command("sudo sh -c \"echo '* - nofile 8192' >> /etc/security/limits.conf\"")
  31. #######################################
  32. # Languages
  33. #######################################
  34. #
  35. # Erlang
  36. #
  37. self.__run_command("sudo cp ../config/erlang.list /etc/apt/sources.list.d/erlang.list")
  38. self.__run_command("wget -O - http://binaries.erlang-solutions.com/debian/erlang_solutions.asc | sudo apt-key add -")
  39. self.__run_command("sudo apt-get update")
  40. self.__run_command("sudo apt-get install esl-erlang", True)
  41. #
  42. # Python
  43. #
  44. self.__run_command("curl -L http://bitbucket.org/pypy/pypy/downloads/pypy-2.0-linux64.tar.bz2 | tar xvj")
  45. self.__run_command("curl http://www.python.org/ftp/python/2.7.4/Python-2.7.4.tgz | tar xvz")
  46. self.__run_command("./configure", cwd="Python-2.7.4")
  47. self.__run_command("make -j", cwd="Python-2.7.4")
  48. self.__run_command("sudo make install", cwd="Python-2.7.4")
  49. self.__run_command("curl https://pypi.python.org/packages/source/d/distribute/distribute-0.6.38.tar.gz | tar xvz")
  50. # run pypy before python. (`setup.py install` fails after `sudo setup.py install`)
  51. self.__run_command("../pypy-2.0/bin/pypy setup.py install", cwd="distribute-0.6.38")
  52. self.__run_command("sudo python setup.py install", cwd="distribute-0.6.38")
  53. self.__run_command("curl https://pypi.python.org/packages/source/p/pip/pip-1.3.1.tar.gz | tar xvz")
  54. self.__run_command("../pypy-2.0/bin/pypy setup.py install", cwd="pip-1.3.1")
  55. self.__run_command("sudo python setup.py install", cwd="pip-1.3.1")
  56. self.__run_command("sudo pip install MySQL-python==1.2.4")
  57. self.__run_command("sudo pip install simplejson==3.0.7")
  58. self.__run_command("curl http://initd.org/psycopg/tarballs/PSYCOPG-2-5/psycopg2-2.5.tar.gz | tar xvz")
  59. self.__run_command("sudo python setup.py install", cwd="psycopg2-2.5")
  60. self.__run_command("git clone https://github.com/iiilx/django-psycopg2-pool.git")
  61. self.__run_command("sudo python setup.py install", cwd="django-psycopg2-pool")
  62. self.__run_command("sudo pip install --upgrade numpy==1.7.1")
  63. self.__run_command("pypy-2.0/bin/pip install PyMySQL==0.5")
  64. #
  65. # nodejs
  66. #
  67. self.__run_command("curl http://nodejs.org/dist/v0.10.2/node-v0.10.2-linux-x64.tar.gz | tar xvz")
  68. #
  69. # Java
  70. #
  71. self.__run_command("sudo apt-get install openjdk-7-jdk", True)
  72. self.__run_command("sudo apt-get remove --purge openjdk-6-jre openjdk-6-jre-headless", True)
  73. #
  74. # Ruby/JRuby
  75. #
  76. self.__run_command("curl -L get.rvm.io | bash -s head")
  77. self.__run_command("echo rvm_auto_reload_flag=2 >> ~/.rvmrc")
  78. subprocess.call(["bash", "-c", "source ~/.rvm/scripts/'rvm' && rvm install 2.0.0-p0"])
  79. subprocess.call(["bash", "-c", "source ~/.rvm/scripts/'rvm' && rvm 2.0.0-p0 do gem install bundler"])
  80. subprocess.call(["bash", "-c", "source ~/.rvm/scripts/'rvm' && rvm install jruby-1.7.3"])
  81. subprocess.call(["bash", "-c", "source ~/.rvm/scripts/'rvm' && rvm jruby-1.7.3 do gem install bundler"])
  82. # We need a newer version of jruby-rack
  83. self.__run_command("git clone git://github.com/jruby/jruby-rack.git")
  84. subprocess.call(["bash", "-c", "cd installs/jruby-rack && source ~/.rvm/scripts/'rvm' && rvm jruby-1.7.3 do bundle install"])
  85. subprocess.call(["bash", "-c", "cd installs/jruby-rack && source ~/.rvm/scripts/'rvm' && rvm jruby-1.7.3 do jruby -S bundle exec rake clean gem SKIP_SPECS=true"])
  86. subprocess.call(["bash", "-c", "cd installs/jruby-rack/target && source ~/.rvm/scripts/'rvm' && rvm jruby-1.7.3 do gem install jruby-rack-1.2.0.SNAPSHOT.gem"])
  87. #
  88. # go
  89. #
  90. self.__run_command("curl http://go.googlecode.com/files/go1.1.linux-amd64.tar.gz | tar xvz")
  91. #
  92. # Perl
  93. #
  94. # Sometimes this HTTP server returns 404, so retry a few times until it works, but don't retry forever
  95. tries = 0
  96. while True:
  97. self.__run_command("curl http://downloads.activestate.com/ActivePerl/releases/5.16.3.1603/ActivePerl-5.16.3.1603-x86_64-linux-glibc-2.3.5-296746.tar.gz | tar xvz");
  98. if os.path.exists(os.path.join('installs', 'ActivePerl-5.16.3.1603-x86_64-linux-glibc-2.3.5-296746')):
  99. break
  100. tries += 1
  101. if tries >= 30:
  102. raise Exception('Could not download ActivePerl after many retries')
  103. time.sleep(5)
  104. self.__run_command("sudo ./install.sh --license-accepted --prefix /opt/ActivePerl-5.16 --no-install-html", cwd="ActivePerl-5.16.3.1603-x86_64-linux-glibc-2.3.5-296746", send_yes=True)
  105. self.__run_command("curl -L http://cpanmin.us | perl - --sudo App::cpanminus")
  106. self.__run_command("cpanm -f -S 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")
  107. #
  108. # php
  109. #
  110. self.__run_command("wget --trust-server-names http://www.php.net/get/php-5.4.13.tar.gz/from/us1.php.net/mirror")
  111. self.__run_command("tar xvf php-5.4.13.tar.gz")
  112. 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", cwd="php-5.4.13")
  113. self.__run_command("make", cwd="php-5.4.13")
  114. self.__run_command("sudo make install", cwd="php-5.4.13")
  115. self.__run_command("printf \"\\n\" | sudo pecl install apc-beta", cwd="php-5.4.13")
  116. self.__run_command("sudo cp ../config/php.ini /usr/local/lib/php.ini")
  117. self.__run_command("sudo cp ../config/php-fpm.conf /usr/local/lib/php-fpm.conf")
  118. self.__run_command("rm php-5.4.13.tar.gz")
  119. # Composer
  120. self.__run_command("curl -sS https://getcomposer.org/installer | php -- --install-dir=bin")
  121. # Phalcon
  122. self.__run_command("git clone git://github.com/phalcon/cphalcon.git")
  123. self.__run_command("sudo ./install", cwd="cphalcon/build")
  124. #
  125. # Haskell
  126. #
  127. self.__run_command("sudo apt-get install ghc cabal-install", True)
  128. #
  129. # RingoJs
  130. #
  131. self.__run_command("wget http://www.ringojs.org/downloads/ringojs_0.9-1_all.deb")
  132. self.__run_command("sudo apt-get install jsvc", True)
  133. self.__run_command("sudo dpkg -i ringojs_0.9-1_all.deb", True)
  134. self.__run_command("rm ringojs_0.9-1_all.deb")
  135. self.__run_command("sudo ringo-admin install oberhamsi/sql-ringojs-client")
  136. self.__run_command("sudo ringo-admin install ringo/stick")
  137. self.__run_command("sudo ringo-admin install oberhamsi/reinhardt")
  138. self.__run_command("sudo ringo-admin install grob/ringo-sqlstore")
  139. self.__run_command("sudo ringo-admin install amigrave/ringo-mongodb")
  140. #
  141. # Mono
  142. #
  143. self.__run_command("git clone git://github.com/mono/mono")
  144. self.__run_command("git checkout mono-3.10", cwd="mono")
  145. self.__run_command("./autogen.sh --prefix=/usr/local", cwd="mono")
  146. self.__run_command("make get-monolite-latest", cwd="mono")
  147. self.__run_command("make EXTERNAL_MCS=${PWD}/mcs/class/lib/monolite/gmcs.exe", cwd="mono")
  148. self.__run_command("sudo make install", cwd="mono")
  149. self.__run_command("git clone git://github.com/mono/xsp")
  150. self.__run_command("git checkout 3.0", cwd="xsp")
  151. self.__run_command("./autogen.sh --prefix=/usr/local", cwd="xsp")
  152. self.__run_command("make", cwd="xsp")
  153. self.__run_command("sudo make install", cwd="xsp")
  154. #######################################
  155. # Webservers
  156. #######################################
  157. #
  158. # Apache
  159. #
  160. self.__run_command("sudo apt-get install apache2 libapache2-mod-php5", True)
  161. self.__run_command("sudo mv /etc/apache2/apache2.conf /etc/apache2/apache2.conf.orig")
  162. self.__run_command("sudo sh -c \"cat ../config/apache2.conf > /etc/apache2/apache2.conf\"")
  163. self.__run_command("sudo mv /etc/apache2/ports.conf /etc/apache2/ports.conf.orig")
  164. self.__run_command("sudo sh -c \"cat ../config/ports.conf > /etc/apache2/ports.conf\"")
  165. self.__run_command("sudo /etc/init.d/apache2 stop")
  166. self.__run_command("sudo update-rc.d apache2 disable")
  167. #
  168. # Nginx
  169. #
  170. self.__run_command("curl http://nginx.org/download/nginx-1.4.0.tar.gz | tar xvz")
  171. self.__run_command("./configure", cwd="nginx-1.4.0")
  172. self.__run_command("make", cwd="nginx-1.4.0")
  173. self.__run_command("sudo make install", cwd="nginx-1.4.0")
  174. #
  175. # Openresty (nginx with openresty stuff)
  176. #
  177. self.__run_command("curl http://openresty.org/download/ngx_openresty-1.2.7.5.tar.gz | tar xvz")
  178. self.__run_command("./configure --with-luajit", cwd="ngx_openresty-1.2.7.5")
  179. self.__run_command("make", cwd="ngx_openresty-1.2.7.5")
  180. self.__run_command("sudo make install", cwd="ngx_openresty-1.2.7.5")
  181. #
  182. # Gunicorn
  183. #
  184. self.__run_command("sudo easy_install -U 'gunicorn==0.17.2'")
  185. self.__run_command("sudo pip install --upgrade meinheld")
  186. self.__run_command("sudo easy_install -U 'eventlet==0.12.1'")
  187. self.__run_command("sudo pip install --upgrade 'gevent==0.13.8'")
  188. #
  189. # Resin
  190. #
  191. 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/")
  192. self.__run_command("curl http://www.caucho.com/download/resin-4.0.34.tar.gz | tar xvz")
  193. self.__run_command("./configure --prefix=`pwd`", cwd="resin-4.0.34")
  194. self.__run_command("make", cwd="resin-4.0.34")
  195. self.__run_command("make install", cwd="resin-4.0.34")
  196. self.__run_command("mv conf/resin.properties conf/resin.properties.orig", cwd="resin-4.0.34")
  197. self.__run_command("cat ../config/resin.properties > resin-4.0.34/conf/resin.properties")
  198. #
  199. # Passenger
  200. #
  201. self.__run_command("git clone https://github.com/FooBarWidget/passenger.git")
  202. self.__run_command("git checkout 65d36dbbadd399f65d81f5febadce9b0c6c1a430", cwd="passenger")
  203. subprocess.call(["bash", "-c", "cd installs/passenger && source ~/.rvm/scripts/'rvm' && rvm 2.0.0-p0 do gem build passenger.gemspec"])
  204. subprocess.call(["bash", "-c", "cd installs/passenger && source ~/.rvm/scripts/'rvm' && rvm 2.0.0-p0 do gem install passenger-3.9.5.rc3.gem"])
  205. ##############################
  206. # Tomcat
  207. # We don't use tomcat in our tests yet, but this is here to remind us of how we
  208. # installed the apr connector
  209. ##############################
  210. self.__run_command("curl http://apache.cs.utah.edu/tomcat/tomcat-7/v7.0.35/bin/apache-tomcat-7.0.35.tar.gz | tar xvz")
  211. #wget http://apache.cs.utah.edu/tomcat/tomcat-7/v7.0.35/bin/apache-tomcat-7.0.35.tar.gz
  212. #tar -xvzf apache-tomcat-7.0.35.tar.gz
  213. #rm apache-tomcat-7.0.35.tar.gz
  214. # use the native APR
  215. # http://evgeny-goldin.com/blog/ubuntu-installing-apr-tomcat/
  216. #wget http://apache.claz.org/apr/apr-1.4.6.tar.gz
  217. #tar xvf apr-1.4.6.tar.gz
  218. #cd apr-1.4.6
  219. #./configure
  220. #make
  221. #sudo make install
  222. #cd ..
  223. #rm apr-1.4.6.tar.gz
  224. #wget http://apache.tradebit.com/pub/tomcat/tomcat-connectors/native/1.1.24/source/tomcat-native-1.1.24-src.tar.gz
  225. #tar xvf tomcat-native-1.1.24-src.tar.gz
  226. #cd tomcat-native-1.1.24-src/jni/native
  227. #./configure --with-apr=/usr/local/apr
  228. #make
  229. #sudo make install
  230. #cd ../../..
  231. #rm tomcat-native-1.1.24-src.tar.gz
  232. ##############################################################
  233. #
  234. # Frameworks
  235. #
  236. ##############################################################
  237. ##############################
  238. # Tornado
  239. ##############################
  240. packages = "tornado==3.0.1 motor==0.1 pymongo==2.5"
  241. self.__run_command("sudo pip install " + packages)
  242. self.__run_command("pypy-2.0/bin/pip install " + packages)
  243. ##############################
  244. # Django
  245. ##############################
  246. self.__run_command("curl http://www.djangoproject.com/m/releases/1.4/Django-1.4.tar.gz | tar xvz")
  247. self.__run_command("sudo rm -rf /usr/local/lib/python2.7/site-packages/django")
  248. self.__run_command("sudo python setup.py install", cwd="Django-1.4")
  249. self.__run_command("sudo easy_install -U 'ujson==1.30'")
  250. ##############################
  251. # Grails
  252. ##############################
  253. self.__run_command("wget http://dist.springframework.org.s3.amazonaws.com/release/GRAILS/grails-2.1.1.zip")
  254. self.__run_command("unzip -o grails-2.1.1.zip")
  255. self.__run_command("rm grails-2.1.1.zip")
  256. ##############################
  257. # Flask
  258. ##############################
  259. packages = "flask==0.9 flask-sqlalchemy==0.16 sqlalchemy==0.8.1 jinja2==2.6 werkzeug==0.8.3"
  260. self.__run_command("sudo pip install " + packages)
  261. self.__run_command("pypy-2.0/bin/pip install " + packages)
  262. ##############################
  263. # Bottle
  264. ##############################
  265. self.__run_command("sudo pip install bottle bottle-sqlalchemy")
  266. ##############################
  267. # Play 2
  268. ##############################
  269. self.__run_command("wget http://downloads.typesafe.com/play/2.1.2-RC1/play-2.1.2-RC1.zip")
  270. self.__run_command("unzip -o play-2.1.2-RC1.zip")
  271. self.__run_command("rm play-2.1.2-RC1.zip")
  272. ##############################
  273. # Play 1
  274. ##############################
  275. self.__run_command("wget http://downloads.typesafe.com/releases/play-1.2.5.zip")
  276. self.__run_command("unzip -o play-1.2.5.zip")
  277. self.__run_command("rm play-1.2.5.zip")
  278. self.__run_command("mv play-1.2.5/play play-1.2.5/play1")
  279. # siena
  280. self.__run_command("play-1.2.5/play1 install siena", send_yes=True)
  281. ##############################
  282. # Vert.x
  283. ##############################
  284. self.__run_command("curl http://vert-x.github.io/vertx-downloads/downloads/vert.x-1.3.1.final.tar.gz | tar xvz")
  285. ##############################
  286. # Yesod
  287. ##############################
  288. self.__run_command("cabal update")
  289. self.__run_command("cabal install yesod persistent-mysql")
  290. ##############################################################
  291. #
  292. # System Tools
  293. #
  294. ##############################################################
  295. ##############################
  296. # Maven
  297. ##############################
  298. # self.__run_command("sudo apt-get install maven2", send_yes=True)
  299. self.__run_command("curl www.us.apache.org/dist/maven/maven-3/3.0.5/binaries/apache-maven-3.0.5-bin.tar.gz | tar xvz")
  300. ##############################
  301. # Leiningen
  302. ##############################
  303. self.__run_command("mkdir -p bin")
  304. self.__run_command("wget https://raw.github.com/technomancy/leiningen/stable/bin/lein")
  305. self.__run_command("mv lein bin/lein")
  306. self.__run_command("chmod +x bin/lein")
  307. ############################################################
  308. # End __install_server_software
  309. ############################################################
  310. ############################################################
  311. # __install_client_software
  312. ############################################################
  313. def __install_client_software(self):
  314. subprocess.call(self.benchmarker.sftp_string(batch_file="config/client_sftp_batch"), shell=True)
  315. remote_script = """
  316. ##############################
  317. # Prerequisites
  318. ##############################
  319. yes | sudo apt-get update
  320. yes | sudo apt-get install build-essential git libev-dev libpq-dev libreadline6-dev postgresql
  321. sudo sh -c "echo '* - nofile 8192' >> /etc/security/limits.conf"
  322. sudo mkdir -p /ssd
  323. sudo mkdir -p /ssd/log
  324. ##############################
  325. # MySQL
  326. ##############################
  327. sudo sh -c "echo mysql-server mysql-server/root_password_again select secret | debconf-set-selections"
  328. sudo sh -c "echo mysql-server mysql-server/root_password select secret | debconf-set-selections"
  329. yes | sudo apt-get install mysql-server
  330. sudo stop mysql
  331. # use the my.cnf file to overwrite /etc/mysql/my.cnf
  332. sudo mv /etc/mysql/my.cnf /etc/mysql/my.cnf.orig
  333. sudo mv my.cnf /etc/mysql/my.cnf
  334. sudo cp -R -p /var/lib/mysql /ssd/
  335. sudo cp -R -p /var/log/mysql /ssd/log
  336. sudo cp usr.sbin.mysqld /etc/apparmor.d/
  337. sudo /etc/init.d/apparmor reload
  338. sudo start mysql
  339. # Insert data
  340. mysql -uroot -psecret < create.sql
  341. ##############################
  342. # Postgres
  343. ##############################
  344. sudo useradd benchmarkdbuser -p benchmarkdbpass
  345. sudo -u postgres psql template1 < create-postgres-database.sql
  346. sudo -u benchmarkdbuser psql hello_world < create-postgres.sql
  347. sudo -u postgres -H /etc/init.d/postgresql stop
  348. sudo mv postgresql.conf /etc/postgresql/9.1/main/postgresql.conf
  349. sudo mv pg_hba.conf /etc/postgresql/9.1/main/pg_hba.conf
  350. sudo cp -R -p /var/lib/postgresql/9.1/main /ssd/postgresql
  351. sudo -u postgres -H /etc/init.d/postgresql start
  352. ##############################
  353. # Weighttp
  354. ##############################
  355. git clone git://git.lighttpd.net/weighttp
  356. cd weighttp
  357. ./waf configure
  358. ./waf build
  359. sudo ./waf install
  360. cd ~
  361. ##############################
  362. # wrk
  363. ##############################
  364. git clone https://github.com/wg/wrk.git
  365. cd wrk
  366. make
  367. sudo cp wrk /usr/local/bin
  368. cd ~
  369. ##############################
  370. # MongoDB
  371. ##############################
  372. sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 7F0CEB10
  373. sudo cp 10gen.list /etc/apt/sources.list.d/10gen.list
  374. sudo apt-get update
  375. yes | sudo apt-get install mongodb-10gen
  376. sudo stop mongodb
  377. sudo mv /etc/mongodb.conf /etc/mongodb.conf.orig
  378. sudo mv mongodb.conf /etc/mongodb.conf
  379. sudo cp -R -p /var/lib/mongodb /ssd/
  380. sudo cp -R -p /var/log/mongodb /ssd/log/
  381. sudo start mongodb
  382. """
  383. p = subprocess.Popen(self.benchmarker.ssh_string.split(" "), stdin=subprocess.PIPE)
  384. p.communicate(remote_script)
  385. ############################################################
  386. # End __parse_results
  387. ############################################################
  388. ############################################################
  389. # __run_command
  390. ############################################################
  391. def __run_command(self, command, send_yes=False, cwd=None):
  392. try:
  393. cwd = os.path.join(self.install_dir, cwd)
  394. except AttributeError:
  395. cwd = self.install_dir
  396. if send_yes:
  397. subprocess.Popen(command, shell=True, stdin=subprocess.PIPE, cwd=cwd).communicate("yes")
  398. else:
  399. subprocess.call(command, shell=True, cwd=cwd)
  400. ############################################################
  401. # End __run_command
  402. ############################################################
  403. ############################################################
  404. # __init__(benchmarker)
  405. ############################################################
  406. def __init__(self, benchmarker):
  407. self.benchmarker = benchmarker
  408. self.install_dir = "installs"
  409. try:
  410. os.mkdir(self.install_dir)
  411. except OSError:
  412. pass
  413. ############################################################
  414. # End __init__
  415. ############################################################