摘要:在本地運行默認使用作為配置文件,而在環(huán)境中我們系統(tǒng)它支持提供外部的配置文件。使用域名或者,啟動之后就可以這個域名或訪問網(wǎng)站了如何在中后臺運行應用推薦使用這個命令。
這篇文章主要講解我在Ubuntu 14.04服務器上如何部署Spring Boot的網(wǎng)站應用的經驗。以下以我的博客項目https://github.com/Raysmond.com/SpringBlog為例子。主要的部署需求如下:
如何在服務器上運行Spring Boot的應用,并使用production環(huán)境的配置文件application-production.yml;
如何通過Gradle構建和發(fā)布Spring Boot的項目;
如何在本地自動化部署網(wǎng)站到production環(huán)境中。
1. 在Ubuntu中安裝Java8以下是一個簡單的安裝方法。
$ sudo add-apt-repository ppa:webupd8team/java $ sudo apt-get update $ sudo apt-get install oracle-java8-installer $ java -version java version "1.8.0_60" Java(TM) SE Runtime Environment (build 1.8.0_60-b27) Java HotSpot(TM) 64-Bit Server VM (build 25.60-b23, mixed mode)2. 本地使用Gradle發(fā)布Spring Boot應用
我這里使用Jetty9作為內置的服務器。
// ... bootRun { systemProperties = System.properties } configurations { compile.exclude module: "spring-boot-starter-tomcat" } dependencies { // spring boot compile "org.springframework.boot:spring-boot-starter-web:1.3.0.M5" compile "org.springframework.boot:spring-boot-starter-jetty" // ... } //...
在本地運行默認使用src/main/resources/application.yml作為配置文件,而在production環(huán)境中我們系統(tǒng)它支持提供外部的配置文件application-production.yml。
./gradlew bootRun # 開發(fā)環(huán)境下默認使用項目里的application.yml # 在本地測試使用外部配置文件 ./gradlew bootRun -Dspring.config.location=/path/to/application-production.yml # 發(fā)布 ./gradlew build # 運行 java -jar build/libs/SpringBlog-0.1.jar # 默認使用jar包里面的application.yml配置文件 # 使用外部配置文件 java -jar build/libs/SpringBlog-0.1.jar --spring.config.location=/path/to/application-production.yml3. 在Ubuntu服務器上部署Spring Boot應用
# 上傳SpringBlog-0.1.jar到服務器 scp build/libs/SpringBlog-0.1.jar root@your_server_ip:/root/spring-blog/current # 在服務器上配置生產環(huán)境的配置文件 scp application-production.yml root@your_server_ip:/root/spring-blog/current
然后SSH登錄服務器,修改配置文件application-production.yml,試運行應用。
ssh root@your_server_ip cd spring-blog/current java -jar SpringBlog-0.1.jar --spring.config.location=application-production.yml
# application-production.yml server: address: raysmond.com # 使用域名或者IP,啟動之后就可以這個域名或IP訪問網(wǎng)站了 port: 80 contextPath: spring: profiles: active: production thymeleaf: cache: true jade4j: caching: true dataSource: driverClassName: com.mysql.jdbc.Driver url: jdbc:mysql://127.0.0.1/spring_blog username: root password: hibernate: dialect: org.hibernate.dialect.MySQLDialect hbm2ddl.auto: update show_sql: false redis: host: localhost port: 63794. 如何在Ubuntu中后臺運行Spring Boot應用?
推薦使用nohup這個命令。
cd /root/spring-blog/current nohup java -jar SpringBlog-0.1.jar --spring.config.location=application-production.yml > ../logs/production.log 2> ../logs/production.err &
在Ubuntu還可以/etc/init.d目錄下新建一個腳本,把SpringBlog作為service來運行,這樣不用每次都打這么繁瑣的命令了。新建一個/etc/init.d/spring_blog文件,內容如下:
#!/bin/sh SERVICE_NAME=spring_blog HOME=/root/spring-blog PATH_TO_JAR=$HOME/current/SpringBlog-0.1.jar PID_PATH_NAME=/tmp/spring_blog.pid LOG=$HOME/logs/production.log ERROR_LOG=$HOME/logs/production.err CONFIG=$HOME/application-production.yml case $1 in start) echo "Starting $SERVICE_NAME ..." if [ ! -f $PID_PATH_NAME ]; then cd $HOME/current nohup java -jar $PATH_TO_JAR --spring.config.location=application-production.yml > $LOG 2> $ERROR_LOG & echo $! > $PID_PATH_NAME echo "$SERVICE_NAME started ..." else echo "$SERVICE_NAME is already running ..." fi ;; stop) if [ -f $PID_PATH_NAME ]; then PID=$(cat $PID_PATH_NAME); echo "$SERVICE_NAME stoping ..." kill $PID; echo "$SERVICE_NAME stopped ..." rm $PID_PATH_NAME else echo "$SERVICE_NAME is not running ..." fi ;; restart) if [ -f $PID_PATH_NAME ]; then PID=$(cat $PID_PATH_NAME); echo "$SERVICE_NAME stopping ..."; kill $PID; echo "$SERVICE_NAME stopped ..."; rm $PID_PATH_NAME echo "$SERVICE_NAME starting ..." cd $HOME/current nohup java -jar $PATH_TO_JAR --spring.config.location=application-production.yml > $LOG 2> $ERROR_LOG & echo $! > $PID_PATH_NAME echo "$SERVICE_NAME started ..." else echo "$SERVICE_NAME is not running ..." fi ;; esac
現(xiàn)在就可以使用service的方式來運行網(wǎng)站了。
sudo service spring_blog start sudo service spring_blog stop sudo service spring_blog restart5. 在本地自動化部署網(wǎng)站到遠程服務器
在本地我用了一個shell腳本和一個python腳本來配合自動化部署。
deploy.sh 使用gradle的命令發(fā)布jar包,使用scp命令吧jar包上傳到服務器上;
deploy.py 使用SSH遠程登錄服務器,并在服務器上執(zhí)行部署命令。
# deploy.sh #!/bin/bash SERVER="your_server_ip" JAR="build/libs/SpringBlog-0.1.jar" echo "Building $JAR..." ./gradlew build echo "Upload $JAR to server $SERVER..." scp $JAR root@$SERVER:/root/spring-blog/ python deploy.py
deploy.py主要使用了一個paramiko庫,用于SSH遠程登錄服務器,并執(zhí)行命令。這個腳本會把服務器上/root/spring-blog/current/SpringBlog-0.1.jar備份到/root/spring-blog/releases中,并把新發(fā)布的jar包放到/root/spring-blog/current中,然后重啟spring_blog服務。
#!/usr/bin/python import paramiko import threading import time ip = "your_server_ip" user = "root" password = "" jar = "SpringBlog-0.1.jar" home="/root/spring-blog" current=home+"/current" releases=home+"/releases" def execute_cmds(ip, user, passwd, cmd): try: ssh = paramiko.SSHClient() ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) ssh.connect(ip,22,user,passwd,timeout=5) for m in cmd: print m stdin, stdout, stderr = ssh.exec_command(m) # stdin.write("Y") out = stdout.readlines() for o in out: print o, print "%s OK "%(ip) ssh.close() except : print "%s Error "%(ip) if __name__=="__main__": print "Start deploying %s to server %s"%(jar, ip) now = time.strftime("%Y%m%d%H%M%S") cmd = [ "echo Stop spring_blog service... && service spring_blog stop", "echo Flush all redis cache data... && redis-cli -r 1 flushall", "echo Stop redis server... && service redis_6379 stop", "echo Use new jar... " + " && mv " + current + "/" + jar + " " + releases + "/" + now + "_" + jar , "mv " + home + "/" + jar + " " + current + "/" + jar, "echo Stop redis... && service redis_6379 start", "echo Start spring_blog service... && service spring_blog start " + " && echo All done." ] a=threading.Thread(target=execute_cmds, args=(ip,user,password,cmd)) a.start()
配置完以后,在本地寫完代碼就可以運行./deploy.sh一鍵部署到遠程服務器了。
以上就是我部署 http://raysmond.com 網(wǎng)站的一些經驗。項目源代碼已開源放在Github上:https://github.com/Raysmond/SpringBlog。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/66178.html
container-as-a-service-0x02 -- 項目構建&部署之道 By 蘇依蜀黍 . 2016.06.08 分析 之前寫了兩篇,算是比較完善的稱述了就目前的業(yè)務,容器服務在我司的應用,但是沒有比較具體的講如何構建以及部署,所以這一篇主要講如何對項目進行容器化以及如何部署,對我司業(yè)務分類以后可以有以下幾種類型: python應用 node.js應用 php應用 nginx服務 ...
摘要:為了不讓別人痛苦,更不想讓自己痛苦,請容器化開發(fā)環(huán)境吧,讓我們享受一鍵部署開發(fā)環(huán)境的痛快吧。接下的例子依賴的環(huán)境和,請移步自行安裝。 有沒有過項目之間各種Java版本開發(fā)環(huán)境切換的場景;有沒有過github上clone回來的代碼庫,由于各種開發(fā)環(huán)境依賴無法運行的問題;有沒有過進入一個新項目時各種配開發(fā)環(huán)境到深夜的經歷...Come On!為什么會這樣,一切都是開發(fā)環(huán)境問題。為了不讓別人...
摘要:本文將介紹如何在一臺的云服務器上快速部署博客站點,如何快速發(fā)布一篇博文并通過云服務器上的私有倉庫部署到服務器目錄下。此外,還要在云服務器上安裝和兩個必備的軟件包。在服務器上部署博客以下為文章正文。 推薦理由:Hexo 是用 Node.js 開發(fā)的一個靜態(tài)站點生成器(Static Site Generator),支持 Markdown 語法寫作,有著強大的插件系統(tǒng),而且性能優(yōu)異。下面我推...
閱讀 652·2021-11-24 09:39
閱讀 3012·2021-11-23 10:06
閱讀 981·2021-10-08 10:05
閱讀 754·2019-08-30 10:49
閱讀 1719·2019-08-29 14:08
閱讀 1325·2019-08-29 12:48
閱讀 3320·2019-08-26 14:04
閱讀 3613·2019-08-26 13:50