四、项目部署
4.1客户端部署
4.1.1客户端程序结构
- /home/fxg/client
- classes(程序ClassPath目录)
- com/on/entry/Main.class
- config(配置文件夹)
- log4j.properties
- lib(程序所需的jar包)
- logs(日志文件夹)
startup.sh(Linux中启动Java程序的bash脚本文件)
- classes(程序ClassPath目录)
4.1.2文件清单
Main.java
package com.oh.entry; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class Main { private static Logger logger = LoggerFactory.getLogger(Main.class); public static void main(String[] args) { logger.info("在Linux环境下运行程序"); Thread t1=new Thread(new Runnable(){ @Override public void run() { // TODO Auto-generated method stub while(true){ logger.info("模拟客户端运行程序。。。"); try { Thread.sleep(3000); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } }); t1.start(); try { t1.join(); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }
log4j.properties
log4j.rootLogger=INFO,R log4j.appender.R=org.apache.log4j.DailyRollingFileAppender log4j.appender.R.file=${LOG_PATH}/logs/dataButt.log log4j.appender.R.DatePattern='.'yyyyMMdd'.log' log4j.appender.R.layout=org.apache.log4j.PatternLayout log4j.appender.R.layout.ConversionPattern=[%p]%d{[yyyy-MM-dd HH:mm:ss]}(%c:%L) - %m%n
startup.sh(最重要)
#!/bin/sh #该脚本为Linux下启动java程序的通用脚本。即可以作为开机自启动service脚本被调用, #也可以作为启动java程序的独立脚本来使用。 # #警告!!!:该脚本stop部分使用系统kill命令来强制终止指定的java程序进程。 #在杀死进程前,未作任何条件检查。在某些情况下,如程序正在进行文件或数据库写操作, #可能会造成数据丢失或数据不完整。如果必须要考虑到这类情况,则需要改写此脚本, #增加在执行kill命令前的一系列检查。 # ################################### #环境变量及程序执行参数 #需要根据实际环境以及Java程序名称来修改这些参数 ################################### #JDK所在路径 JAVA_HOME="/usr/java/jdk1.6.0_45" #执行程序启动所使用的系统用户,考虑到安全,推荐不使用root帐号 RUNNING_USER=fxg #Java程序所在的目录(classes的上一级目录) APP_HOME=/home/fxg/桌面/client #Log文件的位置 LOG_PATH=/home/fxg/桌面/client #需要启动的Java主程序(main方法类) APP_MAINCLASS=com.oh.entry.Main #拼凑完整的classpath参数,包括指定lib目录下所有的jar CLASSPATH=$APP_HOME/classes:$APP_HOME/config for i in "$APP_HOME"/lib/*.jar; do CLASSPATH="$CLASSPATH":"$i" done #java虚拟机启动参数 JAVA_OPTS="-ms512m -mx512m -Xmn256m -Djava.awt.headless=true -XX:MaxPermSize=128m" ################################### #(函数)判断程序是否已启动 # #说明: #使用JDK自带的JPS命令及grep命令组合,准确查找pid #jps 加 l 参数,表示显示java的完整包路径 #使用awk,分割出pid ($1部分),及Java程序名称($2部分) ################################### #初始化psid变量(全局) psid=0 checkpid() { javaps=`$JAVA_HOME/bin/jps -l | grep $APP_MAINCLASS` if [ -n "$javaps" ]; then psid=`echo $javaps | awk '{print $1}'` else psid=0 fi } ################################### #(函数)启动程序 # #说明: #1. 首先调用checkpid函数,刷新$psid全局变量 #2. 如果程序已经启动($psid不等于0),则提示程序已启动 #3. 如果程序没有被启动,则执行启动命令行 #4. 启动命令执行后,再次调用checkpid函数 #5. 如果步骤4的结果能够确认程序的pid,则打印[OK],否则打印[Failed] #注意:echo -n 表示打印字符后,不换行 #注意: "nohup 某命令 >/dev/null 2>&1 &" 的用法 ################################### start() { checkpid if [ $psid -ne 0 ]; then echo "================================" echo "warn: $APP_MAINCLASS already started! (pid=$psid)" echo "================================" else echo -n "Starting $APP_MAINCLASS ..." #在后台运行,什么都不输出,关闭终端进程仍然运行 JAVA_CMD="nohup $JAVA_HOME/bin/java $JAVA_OPTS -DLOG_PATH=$LOG_PATH -classpath $CLASSPATH $APP_MAINCLASS >/dev/null 2>&1 &" #在前台执行,输出信息到终端,关闭终端进程结束(实际结果并没有结束进程?!!),需要定时清理/root/nohup.out文件 #JAVA_CMD="$JAVA_HOME/bin/java $JAVA_OPTS -DLOG_PATH=$LOG_PATH -classpath $CLASSPATH $APP_MAINCLASS" su - $RUNNING_USER -c "$JAVA_CMD" checkpid if [ $psid -ne 0 ]; then echo "(pid=$psid) [OK]" #显示控制台信息(实际上日志信息),按Ctrl_C退出显示 tail -f $LOG_PATH/logs/dataButt.log else echo "[Failed]" fi fi } ################################### #(函数)停止程序 # #说明: #1. 首先调用checkpid函数,刷新$psid全局变量 #2. 如果程序已经启动($psid不等于0),则开始执行停止,否则,提示程序未运行 #3. 使用kill -9 pid命令进行强制杀死进程 #4. 执行kill命令行紧接其后,马上查看上一句命令的返回值: $? #5. 如果步骤4的结果$?等于0,则打印[OK],否则打印[Failed] #6. 为了防止java程序被启动多次,这里增加反复检查进程,反复杀死的处理(递归调用stop)。 #注意:echo -n 表示打印字符后,不换行 #注意: 在shell编程中,"$?" 表示上一句命令或者一个函数的返回值 ################################### stop() { checkpid if [ $psid -ne 0 ]; then echo -n "Stopping $APP_MAINCLASS ...(pid=$psid) " su - $RUNNING_USER -c "kill -9 $psid" if [ $? -eq 0 ]; then echo "[OK]" else echo "[Failed]" fi checkpid if [ $psid -ne 0 ]; then stop fi else echo "================================" echo "warn: $APP_MAINCLASS is not running" echo "================================" fi } ################################### #(函数)检查程序运行状态 # #说明: #1. 首先调用checkpid函数,刷新$psid全局变量 #2. 如果程序已经启动($psid不等于0),则提示正在运行并表示出pid #3. 否则,提示程序未运行 ################################### status() { checkpid if [ $psid -ne 0 ]; then echo "$APP_MAINCLASS is running! (pid=$psid)" else echo "$APP_MAINCLASS is not running" fi } ################################### #(函数)打印系统环境参数 ################################### info() { echo "System Information:" echo "****************************" echo `head -n 1 /etc/issue` echo `uname -a` echo echo "JAVA_HOME=$JAVA_HOME" echo `$JAVA_HOME/bin/java -version` echo echo "APP_HOME=$APP_HOME" echo "APP_MAINCLASS=$APP_MAINCLASS" echo "****************************" } ################################### #读取脚本的第一个参数($1),进行判断 #参数取值范围:{start|stop|restart|status|info} #如参数不在指定范围之内,则打印帮助信息 ################################### case "$1" in 'start') start ;; 'stop') stop ;; 'restart') stop start ;; 'status') status ;; 'info') info ;; *) echo "Usage: $0 {start|stop|restart|status|info}" exit 1 esac exit 0
4.1.3运行程序
将client文件夹放置到Linux系统中(SFTP或者SecureCRT的rz命令)
启动startup.sh脚本
cd 桌面/client
bash startup.sh start
此时会报如下错误
这是因为Linux的文件格式和Windows不同,无法识别回车,所以需要改变startup.sh文件的格式
vi startup.sh
:set fileformat=unix
:wq
之后启动就正常了
4.1.4其他有关命令
bash startup.sh stop --终止程序
bash startup.sh restart --重启程序
bash startup.sh status --查看程序情况(运行中、已停止等待)
bash startup.sh info --查看程序相关的配置信息
tail -f /logs/dataButt.log --查看当前程序的输出,事实上这个命令是不断追踪日志文件,这里用来模拟Java控制台输出
Ctrl_C --用来退出查看Java控制台
4.2服务端部署
4.2.1将项目拷贝到Linux上
4.2.2配置tomcat的server.xml文件
将端口号8080改为80;
Host节点中添加以下一行
<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true">
<Context reloadable="true" debug="0" docBase="/home/fxg/桌面/linux_web" path=""/>
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="localhost_access_log" suffix=".txt" pattern="%h %l %u %t "%r" %s %b" />
</Host>
4.2.3重启tomcat服务
/usr/local/tomcat/bin/shutdown.sh
/usr/local/tomcat/bin/startup.sh
4.2.4防火墙开放80端口
firewall-cmd --zone=public --add-port=80/tcp --permanent
firewall-cmd –reload