目錄html
(一)搭建單機storm集羣java
1、下載所須要的資源python
2、資源解壓git
3、安裝JDKgithub
4、安裝依賴的庫文件apache
5、安裝ZMQbootstrap
6、安裝jzmqvim
7、啓動zookeeperbash
8、啓動storm服務器
9、在UI端訪問
10、編譯storm-start jar包
11、storm-starter源碼導出
12、提交Topology
(二)搭建多機storm集羣
1、基本設置
2、修改配置文件
3、啓動集羣
4、在UI端口訪問
5、提交Topology
附一
Storm:
http://storm-project.net/downloads.html
(0.9.3)apache-storm-0.9.3.tar.gz
Zookeeper:
http://www.apache.org/dyn/closer.cgi/zookeeper/
(3.4.6)zookeeper-3.4.6.tar.gz
ZMQ:
http://download.zeromq.org/
(2.1.7)zeromq-2.1.7.tar.gz
jzmq:
http://github.com/nathanmarz/jzmq/archive/master.zip
jzmq-master.zip
下載完成後將資源放在本身指定的目錄下
解壓
tar -xvf zookeeper-3.4.6.tar.gz tar -xvf apache-storm-0.9.3.tar.gz tar -xvf zeromq-2.1.7.tar.gz unzip jzmq-master.zip
安裝openjdk
安裝命令:
sudo apt-get install openjdk-7-jdk
安裝完成後修改環境變量,修改文件etc/profile
vim /etc/profile
修改如下內容:
export JAVA_HOME=/usr/lib/jvm/java-7-openjdk-i386 export CLASSPATH=$JAVA_HOME/lib export PATH=$JAVA_HOME/bin:$PATH
修改完成後,使配置文件生效
source /etc/profile
4、安裝依賴的庫文件
運行如下命令對所須要的庫文件進行安裝,也可以使用yum進行安裝
sudo apt-get install libtool sudo apt-get install autoconf sudo apt-get install automake sudo apt-get install g++ sudo apt-get install uuid-dev sudo apt-get install uuid sudo apt-get install e2fsprogs sudo apt-get install python
5、安裝ZMQ
進入zero相應目錄下,運行如下命令進行安裝
cd zeromq-2.1.7
./configure
若出現以下錯誤
configure: error: cannot link with -luuid, install uuid-dev.
解決方案以下:
yum install uuid-dev 提示找不到該依賴包 (需從網上下載安裝yum)
yum install uuid* 直接用* ok
./configure 再次運行configure仍是報錯
configure: error: cannot link with -luuid, install uuid-dev.
上網搜索多是還缺另一個包
yum install e2fsprogs* ok
make
sudo make install
sudo ldconfig
進入jzmq相應目錄下,運行如下命令進行安裝
cd jzmq-master
./autogen.sh
./configure
make
sudo make install
若make過程出現以下錯誤
***No rule to make target ‘classdist_noinst.stamp’,needed by ‘org、zeromq/ZMQ.class’. Stop
解決方法,運行以下命令解決
touch src/classdist_noinst.stamp
cd src/org/zeromq
javac *.java
cd –
make
sudo make install
進入zookeeper相應目錄
cd zookeeper-3.4.6/
重命名./conf/zoo_sample.cfg爲./conf/zoo.cfg
mv ./conf/zoo_sample.cfg ./conf/zoo.cfg
運行命令啓動zookeeper
bin/zkServer.sh start
檢查zookeeper是否啓動成功zkServer.sh status
bin/zkCli.sh –server 127.0.0.1:2181
在出現的交互式窗口中運行
ls /
進入storm相應目錄,啓動storm相應服務
cd apache-storm-0.9.3/bin
./storm nimbus& ./storm supervisor& ./storm ui&
9、在UI端訪問
在桌面打開鏈接http://localhost:8080,此時可以看見Storm UI界面
在運行起來的集羣上提交一個Topology,使用storm-starter作示範
安裝git工具
sudo apt-get install git
安裝leiningen工具(2.0.0以上版本),按照https://github.com/technomancy/leiningen的步驟安裝
確保java版本在6以上
下載lein腳本(我下載的lein腳本附在最後,附一),命名爲lein:
cd ~/wfm-storm/apache-storm-0.9.3/bin
vim lein
將附一的腳本粘貼到lein文件中並保存
chmod 755 ~/bin/lein
運行lein
./lein
運行lein報以下錯誤
「Failed to download
https://github.com/technomancy/leiningen/releases/download/2.5.0/leiningen-2.5.0-standalone.jar (exit code 7) It's possible your HTTP client's certificate store does not have the correct certificate authority needed. This is often caused by an out-of-date version of libssl. It's also possible that you're behind a firewall and haven't set HTTP_PROXY and HTTPS_PROXY.「
解決方法:
export HTTP_CLIENT="wget --no-check-certificate -O"
./lein
export PATH=" ~/wfm-storm/apache-storm-0.9.3/bin/:$PATH"(在配置文件中加入這句)
下載storm-start源碼保存在~/wfm-storm/storm-starter中
cd ~/wfm-storm/
git clone git://github.com/nathanmarz/storm-starter.git
依次執行如下命令建立項目jar包
cd storm-starter/
lein deps //下載相應的依賴包
lein compile //編譯
lein install //安裝打包
報backtype.storm.LocalCluster和backtype.storm.LocalDRPC類找不到:
Compiling backtype.storm.testing4j
Exception in thread "main" java.lang.ClassNotFoundException: backtype.storm.LocalCluster, compiling:(testing4j.clj:1)
at clojure.lang.Compiler$InvokeExpr.eval(Compiler.java:3387)
at clojure.lang.Compiler.compile1(Compiler.java:7035)
at clojure.lang.Compiler.compile1(Compiler.java:7025)
at clojure.lang.Compiler.compile(Compiler.java:7097)
at clojure.lang.RT.compile(RT.java:387)
at clojure.lang.RT.load(RT.java:427)
at clojure.lang.RT.load(RT.java:400)
at clojure.core$load$fn__4890.invoke(core.clj:5415)
at clojure.core$load.doInvoke(core.clj:5414)
解決方法:
修改storm-core/src/clj/backtype/storm/testing4j.clj
和storm-core/src/clj/storm/trident/testing.clj,分別引用這兩個類:
testing4j.clj:
1 (ns backtype.storm.testing4j
2 (:import [java.util Map List Collection ArrayList])
3 (:require [backtype.storm.LocalCluster :as LocalCluster])
testing.clj:
1 (ns storm.trident.testing)
2 (:require [backtype.storm.LocalDRPC :as LocalDRPC])
安裝時出現jdk版本問題
sudo apt-get install openjdk-7-jdk
執行以後會將JDK安裝到/usr/lib/jvm/java-7-openjdk-i386/
經過update-alternatives選擇系統中使用的java
sudo update-alternatives --config java
有 3 個候選項可用於替換 java (提供 /usr/bin/java)。
選擇 路徑 優先級 狀態
------------------------------------------------------------
* 0 /usr/lib/jvm/java-6-openjdk-i386/jre/bin/java 1061 自動模式
1 /usr/lib/jvm/java-6-openjdk-i386/jre/bin/java 1061 手動模式
2 /usr/lib/jvm/java-6-sun/jre/bin/java 63 手動模式
3 /usr/lib/jvm/java-7-openjdk-i386/jre/bin/java 1051 手動模式
要維持當前值[*]請按回車鍵,或者鍵入選擇的編號:3
update-alternatives: 使用 /usr/lib/jvm/java-7-openjdk-i386/jre/bin/java 來提供 /usr/bin/java (java),於 手動模式 中。
實際是將/usr/bin/java連接到JDK7上,保證執行java命令後,實際運行的是咱們的目標版本
java -version
除了java外,還有javac、jar、javah、javap、jps、jconsole等
sudo update-alternatives --config javac
sudo update-alternatives --config jar
sudo update-alternatives --config javah
sudo update-alternatives --config javap
sudo update-alternatives --config jps
sudo update-alternatives --config jconsole
補充:jps -lv 用於查看java程序的啓動參數,如java版本
修改各個環境變量
sudo vim /etc/profile
export JAVA_HOME=/usr/lib/jvm/java-7-openjdk-amd64/
export CLASSPATH=$JAVA_HOME/lib
export PATH=$JAVA_HOME/bin:$PATH
source /etc/profile
sudo vim /etc/environment
CLASSPATH=.:/usr/lib/jvm/java-7-openjdk-amd64/lib#
JAVA_HOME=/usr/lib/jvm/java-7-openjdk-amd64/source /etc/environment
sudo vim ~/.bashrc
export JAVA_HOME=/usr/lib/jvm/java-7-openjdk-amd64/
export CLASSPATH=$JAVA_HOME/lib
export PATH=$JAVA_HOME/bin:$PATH
source ~/.bashrc
建立好的jar包storm-starter-0.0.1-SNAPSHOT.jar位於target目錄下
獲取storm-starter源碼
cd ~/wfm-storm
git clone git://github.com/apache/storm.git
cd storm/examples/storm-starter
storm-starter簡介
storm-starter包含不少使用storm的例子。若是是第一次使用storm,建議從如下三個例子(topologies)入手:
- ExclamationTopology: 基礎的topology,所有都是使用java寫的
- WordCountTopology: 基礎的topology ,利用multilang使用Python實現的
- ReachTopology: storm之上的複雜的DRPC例子
熟悉這幾個例子以後,可看看其餘的一些topologies(src/jvm/storm/starter/),其中有更多advanced的實現例子
在maven上使用storm-starter,安裝maven(3.x)
下載相應maven版本(http://maven.apache.org/download.cgi),例如apache-maven-3.2.5-bin.tar.gz
解壓下載的包
tar -zxf apache-maven-3.2.5-bin.tar.gz
修改環境變量M2_HOME
sudo vim /etc/profile
添加以下代碼:
export M2_HOME=/home/wamdm/wfm-storm/apache-maven-3.2.5 export M2=$M2_HOME/bin export MAVEN_OPTS="-Xms256m -Xmx512m" export PATH=$M2:$PATH
source /etc/profile
運行mvn –version查看安裝是否成功.
在maven上運行topologies
storm-starter topologies可使用maven-exec-plugin執行
例如:在本地模式下編譯而且運行 WordCountTopology
$ mvn compile exec:java -Dstorm.topology=storm.starter.WordCountTopology
也可使用Maven運行clojure topologies
$ mvn compile exec:java -Dstorm.topology=storm.starter.clj.word_count
打包strom-starter用於storm集羣
mvn package
運行例子:
# Example 1: Run the RollingTopWords in local mode (LocalCluster)
$ storm jar storm-starter-*-jar-with-dependencies.jar storm.starter.RollingTopWords
# Example 2: Run the RollingTopWords in remote/cluster mode,
# under the name "production-topology"
$ storm jar storm-starter-*-jar-with-dependencies.jar storm.starter.RollingTopWords production-topology remote
進入storm文件夾的bin目錄中,運行如下命令提交Topology
./storm jar ~/project/storm-starter/target/storm-starter-0.0.1-SNAPSHOT.jar storm.starter.WordCount Topology wordcount
等待提交結束,刷新ui頁面,能夠看到提交的「Wordcount」Topology,點擊Wordcount能夠看到其詳細的運行狀況
中止storm Topology
storm kill :{toponame}
首先在每臺機器上都搭建單機集羣
wamdm1做爲Nimbus(192.168.0.11)
wamdm2做爲Zookeeper(192.168.0.12)
wamdm3做爲Supervisor(192.168.0.13)
wamdm4做爲Supervisor(192.168.0.14)
修改wamdm一、wamdm三、wamdm4上的storm.yaml
(~/wfm-storm/apache-storm-0.9.3/conf)
進入conf目錄
cd ~/wfm-storm/apache-storm-0.9.3/conf
修改配置文件
vim storm.yaml
將文件中添加以下代碼
storm.zookeeper.servers:
- "192.168.0.12"
# - "192.168.0.13"
nimbus.host: "192.168.0.11"
#ui.port: 83
supervisor.slots.ports:
- 6700
- 6701
- 6702
- 6703
可用參數解釋:
java.library.path:該配置項配置啓動storm所需lib包的路徑(默承認不用配置)
storm.zookeeper.servers:該配置項配置了當前集羣中全部ZooKeeper機器的IP地址(這裏咱們只使用wamdm1做爲Zookeeper服務器)
nimbus.host:該配置項指明瞭Nimbus機器的IP地址
ui.port:該配置項配置了Storm UI使用的端口。(默認使用8080端口)
supervisor.slots.ports:該配置項指明瞭一臺Supervisor機器上全部可使用的slot信息,也就是端口號。代表該機器上最多能夠啓動4個worker
Storm還提供了不少其餘的配置項,須要時可查相應的document
在wamdm2上啓動zookeeper
bin/zkServer.sh start
檢查zookeeper是否啓動成功zkServer.sh status
bin/zkCli.sh –server 127.0.0.1:2181
在出現的交互式窗口中運行
ls /
在wamdm1上啓動nimbus和ui
cd apache-storm-0.9.3/bin
./storm nimbus
./storm ui
在wamdm3上啓動supervisor
cd apache-storm-0.9.3/bin
./storm supervisor
在wamdm4上啓動supervisor
cd apache-storm-0.9.3/bin
./storm supervisor
在桌面打開鏈接http://192.168.0.11:8080,此時可以看見Storm集羣
在wamdm1(Nimbus所在機器)上提交WordCountTopology到集羣中,刷新ui頁面,就可以看到提交的Topology了。
lein
1 #!/usr/bin/env bash 2 3 # Ensure this file is executable via `chmod a+x lein`, then place it 4 5 # somewhere on your $PATH, like ~/bin. The rest of Leiningen will be 6 7 # installed upon first run into the ~/.lein/self-installs directory. 8 9 export LEIN_VERSION="2.5.0" 10 11 case $LEIN_VERSION in 12 13 *SNAPSHOT) SNAPSHOT="YES" ;; 14 15 *) SNAPSHOT="NO" ;; 16 17 esac 18 19 if [[ "$OSTYPE" == "cygwin" ]] || [[ "$OSTYPE" == "msys" ]]; then 20 21 delimiter=";" 22 23 else 24 25 delimiter=":" 26 27 fi 28 29 if [[ "$OSTYPE" == "cygwin" ]]; then 30 31 cygwin=true 32 33 else 34 35 cygwin=false 36 37 fi 38 39 function make_native_path { 40 41 # ensure we have native paths 42 43 if $cygwin && [[ "$1" == /* ]]; then 44 45 echo -n "$(cygpath -wp "$1")" 46 47 elif [[ "$OSTYPE" == "msys" && "$1" == /?/* ]]; then 48 49 echo -n "$(sh -c "(cd $1 2</dev/null && pwd -W) || echo $1 | sed 's/^\\/\([a-z]\)/\\1:/g'")" 50 51 else 52 53 echo -n "$1" 54 55 fi 56 57 } 58 59 # usage : add_path PATH_VAR [PATH]... 60 61 function add_path { 62 63 local path_var="$1" 64 65 shift 66 67 while [ -n "$1" ];do 68 69 # http://bashify.com/?Useful_Techniques:Indirect_Variables:Indirect_Assignment 70 71 if [[ -z ${!path_var} ]]; then 72 73 export ${path_var}="$(make_native_path "$1")" 74 75 else 76 77 export ${path_var}="${!path_var}${delimiter}$(make_native_path "$1")" 78 79 fi 80 81 shift 82 83 done 84 85 } 86 87 function download_failed_message { 88 89 echo "Failed to download $1 (exit code $2)" 90 91 echo "It's possible your HTTP client's certificate store does not have the" 92 93 echo "correct certificate authority needed. This is often caused by an" 94 95 echo "out-of-date version of libssl. It's also possible that you're behind a" 96 97 echo "firewall and haven't set HTTP_PROXY and HTTPS_PROXY." 98 99 } 100 101 function self_install { 102 103 if [ -r "$LEIN_JAR" ]; then 104 105 echo "The self-install jar already exists at $LEIN_JAR." 106 107 echo "If you wish to re-download, delete it and rerun \"$0 self-install\"." 108 109 exit 1 110 111 fi 112 113 echo "Downloading Leiningen to $LEIN_JAR now..." 114 115 mkdir -p "$(dirname "$LEIN_JAR")" 116 117 LEIN_URL="https://github.com/technomancy/leiningen/releases/download/$LEIN_VERSION/leiningen-$LEIN_VERSION-standalone.jar" 118 119 $HTTP_CLIENT "$LEIN_JAR.pending" "$LEIN_URL" 120 121 local exit_code=$? 122 123 if [ $exit_code == 0 ]; then 124 125 # TODO: checksum 126 127 mv -f "$LEIN_JAR.pending" "$LEIN_JAR" 128 129 else 130 131 rm "$LEIN_JAR.pending" 2> /dev/null 132 133 download_failed_message "$LEIN_URL" "$exit_code" 134 135 exit 1 136 137 fi 138 139 } 140 141 if [ `id -u` -eq 0 ] && [ "$LEIN_ROOT" = "" ]; then 142 143 echo "WARNING: You're currently running as root; probably by accident." 144 145 echo "Press control-C to abort or Enter to continue as root." 146 147 echo "Set LEIN_ROOT to disable this warning." 148 149 read _ 150 151 fi 152 153 NOT_FOUND=1 154 155 ORIGINAL_PWD="$PWD" 156 157 while [ ! -r "$PWD/project.clj" ] && [ "$PWD" != "/" ] && [ $NOT_FOUND -ne 0 ] 158 159 do 160 161 cd .. 162 163 if [ "$(dirname "$PWD")" = "/" ]; then 164 165 NOT_FOUND=0 166 167 cd "$ORIGINAL_PWD" 168 169 fi 170 171 done 172 173 export LEIN_HOME="${LEIN_HOME:-"$HOME/.lein"}" 174 175 for f in "$LEIN_HOME/leinrc" ".leinrc"; do 176 177 if [ -e "$f" ]; then 178 179 source "$f" 180 181 fi 182 183 done 184 185 if $cygwin; then 186 187 export LEIN_HOME=`cygpath -w "$LEIN_HOME"` 188 189 fi 190 191 LEIN_JAR="$LEIN_HOME/self-installs/leiningen-$LEIN_VERSION-standalone.jar" 192 193 # normalize $0 on certain BSDs 194 195 if [ "$(dirname "$0")" = "." ]; then 196 197 SCRIPT="$(which $(basename "$0"))" 198 199 else 200 201 SCRIPT="$0" 202 203 fi 204 205 # resolve symlinks to the script itself portably 206 207 while [ -h "$SCRIPT" ] ; do 208 209 ls=`ls -ld "$SCRIPT"` 210 211 link=`expr "$ls" : '.*-> \(.*\)$'` 212 213 if expr "$link" : '/.*' > /dev/null; then 214 215 SCRIPT="$link" 216 217 else 218 219 SCRIPT="$(dirname "$SCRIPT"$)/$link" 220 221 fi 222 223 done 224 225 BIN_DIR="$(dirname "$SCRIPT")" 226 227 export LEIN_JVM_OPTS="${LEIN_JVM_OPTS-"-XX:+TieredCompilation -XX:TieredStopAtLevel=1"}" 228 229 # This needs to be defined before we call HTTP_CLIENT below 230 231 if [ "$HTTP_CLIENT" = "" ]; then 232 233 if type -p curl >/dev/null 2>&1; then 234 235 if [ "$https_proxy" != "" ]; then 236 237 CURL_PROXY="-x $https_proxy" 238 239 fi 240 241 HTTP_CLIENT="curl $CURL_PROXY -f -L -o" 242 243 else 244 245 HTTP_CLIENT="wget -O" 246 247 fi 248 249 fi 250 251 # When :eval-in :classloader we need more memory 252 253 grep -E -q '^\s*:eval-in\s+:classloader\s*$' project.clj 2> /dev/null && \ 254 255 export LEIN_JVM_OPTS="$LEIN_JVM_OPTS -Xms64m -Xmx512m" 256 257 if [ -r "$BIN_DIR/../src/leiningen/version.clj" ]; then 258 259 # Running from source checkout 260 261 LEIN_DIR="$(dirname "$BIN_DIR")" 262 263 # Need to use lein release to bootstrap the leiningen-core library (for aether) 264 265 if [ ! -r "$LEIN_DIR/leiningen-core/.lein-bootstrap" ]; then 266 267 echo "Leiningen is missing its dependencies." 268 269 echo "Please run \"lein bootstrap\" in the leiningen-core/ directory" 270 271 echo "with a stable release of Leiningen. See CONTRIBUTING.md for details." 272 273 exit 1 274 275 fi 276 277 # If project.clj for lein or leiningen-core changes, we must recalculate 278 279 LAST_PROJECT_CHECKSUM=$(cat "$LEIN_DIR/.lein-project-checksum" 2> /dev/null) 280 281 PROJECT_CHECKSUM=$(sum "$LEIN_DIR/project.clj" "$LEIN_DIR/leiningen-core/project.clj") 282 283 if [ "$PROJECT_CHECKSUM" != "$LAST_PROJECT_CHECKSUM" ]; then 284 285 if [ -r "$LEIN_DIR/.lein-classpath" ]; then 286 287 rm "$LEIN_DIR/.lein-classpath" 288 289 fi 290 291 fi 292 293 # Use bin/lein to calculate its own classpath. 294 295 if [ ! -r "$LEIN_DIR/.lein-classpath" ] && [ "$1" != "classpath" ]; then 296 297 echo "Recalculating Leiningen's classpath." 298 299 ORIG_PWD="$PWD" 300 301 cd "$LEIN_DIR" 302 303 LEIN_NO_USER_PROFILES=1 $0 classpath .lein-classpath 304 305 sum "$LEIN_DIR/project.clj" "$LEIN_DIR/leiningen-core/project.clj" > \ 306 307 .lein-project-checksum 308 309 cd "$ORIG_PWD" 310 311 fi 312 313 mkdir -p "$LEIN_DIR/target/classes" 314 315 export LEIN_JVM_OPTS="$LEIN_JVM_OPTS -Dclojure.compile.path=$LEIN_DIR/target/classes" 316 317 add_path CLASSPATH "$LEIN_DIR/leiningen-core/src/" "$LEIN_DIR/leiningen-core/resources/" \ 318 319 "$LEIN_DIR/test:$LEIN_DIR/target/classes" "$LEIN_DIR/src" ":$LEIN_DIR/resources" 320 321 if [ -r "$LEIN_DIR/.lein-classpath" ]; then 322 323 add_path CLASSPATH "$(cat "$LEIN_DIR/.lein-classpath" 2> /dev/null)" 324 325 else 326 327 add_path CLASSPATH "$(cat "$LEIN_DIR/leiningen-core/.lein-bootstrap" 2> /dev/null)" 328 329 fi 330 331 else # Not running from a checkout 332 333 add_path CLASSPATH "$LEIN_JAR" 334 335 BOOTCLASSPATH="-Xbootclasspath/a:$LEIN_JAR" 336 337 if [ ! -r "$LEIN_JAR" -a "$1" != "self-install" ]; then 338 339 self_install 340 341 fi 342 343 fi 344 345 # TODO: explain what to do when Java is missing 346 347 export JAVA_CMD="${JAVA_CMD:-"java"}" 348 349 export LEIN_JAVA_CMD="${LEIN_JAVA_CMD:-$JAVA_CMD}" 350 351 if [[ -z "${DRIP_INIT+x}" && "$(basename "$LEIN_JAVA_CMD")" == *drip* ]]; then 352 353 export DRIP_INIT="$(printf -- '-e\n(require (quote leiningen.repl))')" 354 355 export DRIP_INIT_CLASS="clojure.main" 356 357 fi 358 359 # Support $JAVA_OPTS for backwards-compatibility. 360 361 export JVM_OPTS="${JVM_OPTS:-"$JAVA_OPTS"}" 362 363 # Handle jline issue with cygwin not propagating OSTYPE through java subprocesses: https://github.com/jline/jline2/issues/62 364 365 cygterm=false 366 367 if $cygwin; then 368 369 case "$TERM" in 370 371 rxvt* | xterm* | vt*) cygterm=true ;; 372 373 esac 374 375 fi 376 377 if $cygterm; then 378 379 LEIN_JVM_OPTS="$LEIN_JVM_OPTS -Djline.terminal=jline.UnixTerminal" 380 381 stty -icanon min 1 -echo > /dev/null 2>&1 382 383 fi 384 385 # TODO: investigate http://skife.org/java/unix/2011/06/20/really_executable_jars.html 386 387 # If you're packaging this for a package manager (.deb, homebrew, etc) 388 389 # you need to remove the self-install and upgrade functionality or see lein-pkg. 390 391 if [ "$1" = "self-install" ]; then 392 393 if [ -r "$BIN_DIR/../src/leiningen/version.clj" ]; then 394 395 echo "Running self-install from a checkout is not supported." 396 397 echo "See CONTRIBUTING.md for SNAPSHOT-specific build instructions." 398 399 exit 1 400 401 fi 402 403 echo "Manual self-install is deprecated; it will run automatically when necessary." 404 405 self_install 406 407 elif [ "$1" = "upgrade" ] || [ "$1" = "downgrade" ]; then 408 409 if [ "$LEIN_DIR" != "" ]; then 410 411 echo "The upgrade task is not meant to be run from a checkout." 412 413 exit 1 414 415 fi 416 417 if [ $SNAPSHOT = "YES" ]; then 418 419 echo "The upgrade task is only meant for stable releases." 420 421 echo "See the \"Hacking\" section of the README." 422 423 exit 1 424 425 fi 426 427 if [ ! -w "$SCRIPT" ]; then 428 429 echo "You do not have permission to upgrade the installation in $SCRIPT" 430 431 exit 1 432 433 else 434 435 TARGET_VERSION="${2:-stable}" 436 437 echo "The script at $SCRIPT will be upgraded to the latest $TARGET_VERSION version." 438 439 echo -n "Do you want to continue [Y/n]? " 440 441 read RESP 442 443 case "$RESP" in 444 445 y|Y|"") 446 447 echo 448 449 echo "Upgrading..." 450 451 TARGET="/tmp/lein-$$-upgrade" 452 453 if $cygwin; then 454 455 TARGET=`cygpath -w $TARGET` 456 457 fi 458 459 LEIN_SCRIPT_URL="https://github.com/technomancy/leiningen/raw/$TARGET_VERSION/bin/lein" 460 461 $HTTP_CLIENT "$TARGET" "$LEIN_SCRIPT_URL" 462 463 if [ $? == 0 ]; then 464 465 cmp -s "$TARGET" "$SCRIPT" 466 467 if [ $? == 0 ]; then 468 469 echo "Leiningen is already up-to-date." 470 471 fi 472 473 mv "$TARGET" "$SCRIPT" && chmod +x "$SCRIPT" 474 475 exec "$SCRIPT" version 476 477 else 478 479 download_failed_message "$LEIN_SCRIPT_URL" 480 481 fi;; 482 483 *) 484 485 echo "Aborted." 486 487 exit 1;; 488 489 esac 490 491 fi 492 493 else 494 495 if $cygwin; then 496 497 # When running on Cygwin, use Windows-style paths for java 498 499 ORIGINAL_PWD=`cygpath -w "$ORIGINAL_PWD"` 500 501 fi 502 503 # apply context specific CLASSPATH entries 504 505 if [ -f .lein-classpath ]; then 506 507 add_path CLASSPATH "$(cat .lein-classpath)" 508 509 fi 510 511 if [ $DEBUG ]; then 512 513 echo "Leiningen's classpath: $CLASSPATH" 514 515 fi 516 517 if [ -r .lein-fast-trampoline ]; then 518 519 export LEIN_FAST_TRAMPOLINE='y' 520 521 fi 522 523 if [ "$LEIN_FAST_TRAMPOLINE" != "" ] && [ -r project.clj ]; then 524 525 INPUTS="$@ $(cat project.clj) $LEIN_VERSION $(test -f "$LEIN_HOME/profiles.clj" && cat "$LEIN_HOME/profiles.clj")" 526 527 export INPUT_CHECKSUM=$(echo $INPUTS | shasum - | cut -f 1 -d " ") 528 529 # Just don't change :target-path in project.clj, mkay? 530 531 TRAMPOLINE_FILE="target/trampolines/$INPUT_CHECKSUM" 532 533 else 534 535 if hash mktemp 2>/dev/null; then 536 537 # Check if mktemp is available before using it 538 539 TRAMPOLINE_FILE="$(mktemp /tmp/lein-trampoline-XXXXXXXXXXXXX)" 540 541 else 542 543 TRAMPOLINE_FILE="/tmp/lein-trampoline-$$" 544 545 fi 546 547 trap "rm -f $TRAMPOLINE_FILE" EXIT 548 549 fi 550 551 if $cygwin; then 552 553 TRAMPOLINE_FILE=`cygpath -w $TRAMPOLINE_FILE` 554 555 fi 556 557 if [ "$INPUT_CHECKSUM" != "" ] && [ -r "$TRAMPOLINE_FILE" ]; then 558 559 if [ $DEBUG ]; then 560 561 echo "Fast trampoline with $TRAMPOLINE_FILE." 562 563 fi 564 565 exec sh -c "exec $(cat $TRAMPOLINE_FILE)" 566 567 else 568 569 export TRAMPOLINE_FILE 570 571 "$LEIN_JAVA_CMD" \ 572 573 "${BOOTCLASSPATH[@]}" \ 574 575 -Dfile.encoding=UTF-8 \ 576 577 -Dmaven.wagon.http.ssl.easy=false \ 578 579 -Dmaven.wagon.rto=10000 \ 580 581 $LEIN_JVM_OPTS \ 582 583 -Dleiningen.original.pwd="$ORIGINAL_PWD" \ 584 585 -Dleiningen.script="$SCRIPT" \ 586 587 -classpath "$CLASSPATH" \ 588 589 clojure.main -m leiningen.core.main "$@" 590 591 EXIT_CODE=$? 592 593 if $cygterm ; then 594 595 stty icanon echo > /dev/null 2>&1 596 597 fi 598 599 ## TODO: [ -r "$TRAMPOLINE_FILE" ] may be redundant? A trampoline file 600 601 ## is always generated these days. 602 603 if [ -r "$TRAMPOLINE_FILE" ] && [ "$LEIN_TRAMPOLINE_WARMUP" = "" ]; then 604 605 TRAMPOLINE="$(cat $TRAMPOLINE_FILE)" 606 607 if [ "$INPUT_CHECKSUM" = "" ]; then 608 609 rm $TRAMPOLINE_FILE 610 611 fi 612 613 if [ "$TRAMPOLINE" = "" ]; then 614 615 exit $EXIT_CODE 616 617 else 618 619 exec sh -c "exec $TRAMPOLINE" 620 621 fi 622 623 else 624 625 exit $EXIT_CODE 626 627 fi 628 629 fi 630 631 fi