1、開發時,配置服務的配置使用本地路徑,不使用svn和git,由於後者每一個開發人員都會修改配置,致使別人也拿到其餘人修改的配置,本地配置示例以下:html
spring: application: name: simple-config-server cloud: config: server: default-label: trunk native: searchLocations: file:///D:\works\smart\simple-config-repo profiles: active: native
2、對於生產環境部署到阿里雲的,使用不了docker,由於docker文件一般有幾百兆,部署時上傳很慢。不但不能使用docker,打包時也沒有必要包含全部的包,若是去掉依賴包,編譯完後每一個jar只有幾百k,這樣部署起來就方便多了。能夠以下設置pom編譯選項:java
<build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-jar-plugin</artifactId> <configuration> <archive> <manifest> <addClasspath>true</addClasspath> <mainClass>ebtins.smart.proxy.SmartProxyApplication</mainClass> <classpathPrefix>lib/</classpathPrefix> </manifest> </archive> </configuration> </plugin> </plugins> <defaultGoal>compile</defaultGoal> </build>
這樣你生產環境的服務目錄將以下,simple-service.jar只有幾百K。git
simple-service.jar simple-service.sh lib logsspring
3、使用腳本啓動和關閉服務,centos下的腳本啓動和關閉能夠以下: docker
start(){ now=`date "+%Y%m%d%H%M%S"` exec java -Xms64m -Xmx256m -jar ./simple-service-0.0.1.jar --server.port=7085 --config.name=pro > logs/simple-service.log & } #中止方法 stop(){ ps aux|grep simple-service|grep 7085|grep -v grep|awk '{print $2}'|while read pid do kill -9 $pid done } case "$1" in start) start ;; stop) stop ;; restart) stop start ;; *) printf 'Usage: %s {start|stop|restart}\n' "$testg" exit 1 ;; esac
啓動方式:sh simple-service.jar start
固然能夠在腳本里啓動本服務器全部服務,也能夠使用自動部署機制,自動部署自動啓動。
這是生產和開發環境的一點小小經驗。apache