在公司真是学习了一下项目环境在linux下搭建和发布的过程,这是每个程序员都应该掌握的一个技能,将整理下为以后温习用,也乐于和为掌握这些技能的猿分享:

这里主要分为5部分:1、安装jdk,并配置环境变量;2、安装maven配置环境变量;3、安装tomcat服务器;4、安装svn客户端;5安装nodejs(由于我的项目前台开发用的reactjs需要,所以因项目而异)配置node,npm环境变量。6、编译脚本

下面展开详细说明:

1、下载jdk压缩包,网上自己下载然后复制到自己定义的目录下,我这里是/home/appadmin/tools,使用 tar -zxvf jdk-8xxxxx.gz 进行解压 ,之后 更改解压后的文件夹名称为java :mv jdk-8xxxxxx java,

1.1配置环境变量 vim .bash_profile 添加如下

export JAVA_HOME=/home/appadmin/tools/java
export PATH=$JAVA_HOME/bin
export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar

保存后执行 source  .bash_profile 刷新文件  ,测试是否安装成功:java -version。

2、安装maven:也在tools目录下解压,修改解压文件夹为maven,然后配置环境变量,在.bash_profile 文件后面添加如下代码,记得保存后 刷新文件。

MAVEN_HOME=/home/appadmin/tools/maven
export MAVEN_HOME
export PATH=$PATH:$MAVEN_HOME/bin

3、tomcat安装,下载压缩包解压后更名为tomact ,更名只是为了方便在写脚本时容易找到路径好记,先不对tomcat进行任何配置,在项目打包后的路径需要修改tomcat加载项目路径。

4、安装svn:一定要按照顺序解压这两个包

  tar xvfj subversion-1.4.3.tar.bz2
   tar xvfj subversion-deps-1.4.3.tar.bz2

  后者会解压到前者的解压文件夹中,修改解压文件夹为subversion

4.2进行编译和安装
  # cd subversion
  #./configure
  # make #编译,如果提示错误, 则可能需要root权限
  # make install  #安装,此时可能需要root用户权限

  make时可能会出现错误,仔细看看在./configure 后出现的 no ,是否需要 安装 gcc,  需要  则 yum install gcc

  安装好客户端之后, 默认安装目录是/home/appadmin/tools/subversion

4.3 将svn命令链接到/usr/local/bin目录下(需要root权限):若没有root权限 (公司管理员没给开root权限)也可以在   .bash_profile配置环境变量;
  ln –s 
/home/appadmin/tools/subversion/bin/svn /usr/local/bin

  测试是否已经可以在用户目录下使用svn:
  svn help 如果出现命令列表,则表示已经链接成功。

4.4配置maven settings.xml 文件 ,maven中央仓库

cd  /home/appadmin/tools/maven/conf

<?xml version="1.0" encoding="UTF-8"?>
<settings xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 http://maven.apache.org/xsd/settings-1.0.0.xsd" xmlns="http://maven.apache.org/SETTINGS/1.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<servers>
<server>
<username>test</username>
<password>\{DESede\}6z0YCNHERsU=</password>
<id>central</id>
</server>
<server>
<username>test</username>
<password>\{DESede\}6z0YCNHERsU=</password>
<id>snapshots</id>
</server>
<server>
<username>test</username>
<password>\{DESede\}6z0YCNHERsU=</password>
<id>central1</id>
</server>
<server>
<username>test</username>
<password>\{DESede\}6z0YCNHERsU=</password>
<id>snapshots1</id>
</server>
</servers>
<localRepository>/home/appadmin/tools/maven_repo</localRepository>
<profiles>
<profile>
<id>flex</id>
<repositories>
<repository>
<id>central</id>
<url>http://central</url>
<releases><enabled>true</enabled></releases>
<snapshots><enabled>true</enabled></snapshots>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>central</id>
<url>http://central</url>
<releases><enabled>true</enabled></releases>
<snapshots><enabled>true</enabled></snapshots>
</pluginRepository>
</pluginRepositories> </profile> </profiles> <mirrors>
<mirror>
<id>nexus</id>
<mirrorOf>*</mirrorOf>
<url>http://自己的maven仓库服务器地址/</url>
</mirror>
</mirrors>

5、nodejs 解压安装,改名为node。需要软连接到全局变量,但是我没有root权限修改了 .bash_profile

export NPM_HOME=/home/appadmin/tools/node/bin

    export PATH=$JAVA_HOME/bin:$PATH:$NPM_HOME

    所以最后修改后的bash_profile 文件为

# .bash_profile

# Get the aliases and functions
if [ -f ~/.bashrc ]; then
. ~/.bashrc
fi # User specific environment and startup programs PATH=$PATH:$HOME/bin export PATH export NPM_HOME=/home/appadmin/tools/node/bin export PATH
export JAVA_HOME=/home/appadmin/tools/java
export PATH=$JAVA_HOME/bin:$PATH:$NPM_HOME
export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar MAVEN_HOME=/home/appadmin/tools/maven
export MAVEN_HOME
export PATH=$PATH:$MAVEN_HOME/bin

最后刷新.bash_profile 若不能执行该文件 chmod a+x .bash_profile

6、写编译脚本 ,其中有些因项目不同可能不需要。

#!/bin/bash

# prepare
svn_base="http://svn.rd.800best.com/svn/wyvern/wyvern-resource/trunk" checkout_home="/home/appadmin/source_code/wyvern-resource/wyvern-res" checkout_version="trunk" deploy_home="/home/appadmin/deploy/wyvern-res" war_name="wyvern-res-war.war" # which version
if [ $# == ]; then
checkout_version="trunk"
svn_src="${svn_base}"
echo "build trunk!"
else
branch=$
checkout_version="${branch}"
svn_src="${svn_base}/branches/${branch}"
checkout_home=${checkout_home}/branches
echo "build branch! ${branch}"
fi # check out
echo "# start check out"
echo "------------------------------------"
cd ${checkout_home}
svn co ${svn_src}
svn up ${checkout_home}/${checkout_version}
cd ${checkout_home}/${checkout_version}
echo "------------------------------------"
echo # build react
echo "# start building js"
echo "------------------------------------"
cd ${checkout_home}/${checkout_version}/wyvern-res-war/
npm install
npm run release
echo "------------------------------------"
echo # build
echo "# start building"
echo "------------------------------------"
cd ${checkout_home}/${checkout_version}
mvn clean install package -U -Dmaven.test.skip=true -P test-env
echo "------------------------------------"
echo echo "# list build result"
echo "------------------------------------"
#ls -l ${deploy_home}/main
#ls -l ${deploy_home}/external
echo "------------------------------------"
echo # stop tomcat
echo "# stop tomcat"
echo "------------------------------------"
pkill - java
echo "------------------------------------"
ps aux|grep java
#sudo service stop
echo "------------------------------------"
echo # clean tomcat
echo "# clean tomcat"
echo "------------------------------------"
cd ${deploy_home}
rm -rf ./main/*
#rm -rf ./external/*
echo "## list deploy"
ls -l ${deploy_home}/main
#ls -l ${deploy_home}/external
echo "------------------------------------"
echo # deploy
echo "# cp deploy"
echo "------------------------------------" cp /home/appadmin/source_code/wyvern-resource/wyvern-res/trunk/wyvern-res-war/target/${war_name} ./main/ cd main
jar -xvf ${war_name}
rm ${war_name}
echo "# list main"
ls -l
cd .. #cd external
#jar -xvf ${war_ext_name}
#rm ${war_ext_name}
echo "# list external"
ls -l
cd ..
echo "------------------------------------"
echo # start tomcat
echo "# start tomcat"
echo "------------------------------------"
#JAVA_OPTS="-Xms4096m -Xmx4096m -XX:PermSize=256m -XX:MaxPermSize=256m -XX:+DisableExplicitGC
# -XX:+PrintGCDateStamps -XX:+PrintGC -XX:+PrintGCDetails
# -XX:ParallelGCThreads=8 -XX:+UseConcMarkSweepGC -Xloggc:/home/appadmin/logs/gc/gc$NAME.log"
nohup /home/appadmin/tools/tomcat/bin/catalina.sh start >/dev/null 2>&1 &
#cd /home/appadmin/service/crm_tomcat/crm
#/home/appadmin/service/crm_tomcat/crm/start-crm.sh &
#sudo service wyvern start
echo "------------------------------------"
echo # tomcat log
echo "# tail tomcat log"
echo "------------------------------------"
tail -f /home/appadmin/logs/wyvern-res.log
echo "------------------------------------"
echo echo "# release to tomcat finish"

修改tomcat conf/server.xml文件  添加最后的war包路径

<Context path="" docBase="/home/appadmin/deploy/wyvern-res/main" debug="0" reloadable="true" />

最后  ./编译脚本   即可启动项目

linux环境下搭建环境发布web项目的更多相关文章

  1. Mac下Intellij IDea发布Web项目详解一

    Mac下Intellij IDea发布Web项目详解一 Mac下Intellij IDea发布Java Web项目(适合第一次配置Tomcat的家伙们)详解二 Mac下Intellij IDea发布J ...

  2. linux系统下搭建自己的web服务器

    之前在windows 2008 server上搭建了一个用于测试的web服务器,但是在打开网站的时候特别的慢,尤其是图片的加载都会失败,当时以为是路径的问题,但是在服务器上自己打开都特别慢,自己实在找 ...

  3. react-native学习(RN)--之Window环境下搭建环境配置,以及初始化建立react-native项目,(真机和模拟器运行的相关错误解决办法,android打包报错)

    react-native以后会更火的 一.安装java 二.安装Android Studio 三.安装react-native需要的Android studio额外部分 四.安装nodeJS  五.安 ...

  4. Node.js环境下通过Express创建Web项目

    通过Express命令创建项目 Express 是一个简洁而灵活的 node.js Web应用框架, 提供了一系列强大特性帮助你创建各种 Web 应用,和丰富的 HTTP 工具. 使用 Express ...

  5. react-native学习(RN)--之Window环境下搭建环境配置

    react-native以后会更火的,自从2015年facebook开源了Android 一.安装java 二.安装Android Studio 三.安装react-native需要的Android ...

  6. 在Linux(Ubuntu)下搭建ASP.NET Core环境并运行 继续跨平台

    最新教程:http://www.cnblogs.com/linezero/p/aspnetcoreubuntu.html 无需安装mono,在Linux(Ubuntu)下搭建ASP.NET Core环 ...

  7. Ruby on Rails入门——macOS 下搭建Ruby Rails Web开发环境

    这里只介绍具体的过程及遇到的问题和解决方案,有关概念性的知识请参考另一篇:Ruby Rails入门--windows下搭建Ruby Rails Web开发环境 macOS (我的版本是:10.12.3 ...

  8. Tomcat8内置jdk8运行环境发布web项目

    简单说明:之前部署项目都是没有改变之前的环境变量,最近由于公司的数据源换了,jdk由1.7改成了1.8,tomcat7也改为了1.8,现在需要部署采用新数据源的这个项目, 为了不改变之前的环境变量,使 ...

  9. linux环境下测试环境搭建

    一.linux环境下测试环境搭建过程简述: 1.前端后台代码未分离情况下: 主要步骤为:安装jdk,安装mysql,安装tomcat,将项目代码部署到tomcat/webapps/下. 2.前端后台代 ...

随机推荐

  1. ASP.NET MVC应用程序实现下载功能

    ASP.NET MVC应用程序实现下载功能 上次Insus.NET有在MVC应用程序实现了上传文件的功能<MVC应用程序显示上传的图片> http://www.cnblogs.com/in ...

  2. 一个ASP.NET Web API 2.0应用

    在一个空ASP.NET Web项目上创建一个ASP.NET Web API 2.0应用 由于ASP.NET Web API具有与ASP.NET MVC类似的编程方式,再加上目前市面上专门介绍ASP.N ...

  3. Windows服务小技巧

    Windows服务小技巧 阅读目录 开始 将Windows服务转变为控制台程序 注册服务为自动启动服务 注册服务时设置服务的依赖关系 添加自定义命令行参数 自定义命令行参数演示 系列链接 伴随着研究W ...

  4. Code First 启用迁移时出错 "No context type was found in the assembly"

    问题:Code First 启用迁移时找不到上下文DbContext所在的项目. PM> Enable-Migrations No context type was found in the a ...

  5. [转]How WebKit Loads a Web Page

    ref:https://www.webkit.org/blog/1188/how-webkit-loads-a-web-page/ Before WebKit can render a web pag ...

  6. SSL协议的握手过程

    SSL握手的目的 第一,客户端与服务器需要就一组用于保护数据的算法达成一致. 第二,它们需要确立一组由那些算法所使用的加密密钥. 第三,握手还可以选择对客户端进行认证. SSL 握手概述 SSL 握手 ...

  7. DOS头分析

    DOS头分析 PE文件结构综览: 首先上图片: 看到上面的图片可以清晰的看到PE结构复杂结构式什么样子的.有DOS首部,PE头部,PE节表,很多的表块,最后就是一些调试信息. DOS头由DOS 'MZ ...

  8. IOS基础开发二(iphone计算器)

    今天做了个iphone的小例子计算器:才用mvc设计模式 项目目录: 代码如下: CalculatorViewController:(MVC的控制器) // CalculatorViewControl ...

  9. Android Widget(窗口小部件)

    Android Widget简介 应用程序窗口小部件(Widget)是微型的应用程序视图,它可以被嵌入到其它应用程序中(比如桌面)并接收周期性的更新.你可以通过一个App Widget Provide ...

  10. iOS7 Sprite Kit 学习

    iOS7 Sprite Kit 学习 iOS 7有一个新功能 Sprite Kit 这个有点类似cocos2d 感觉用法都差不多.下面简单来介绍下Sprite Kit About Sprite Kit ...