文件里面有该文档的压缩包,可下载下来查看

一、 概要说明

我们的Java程序一般在Windows进行编写,但是真正运行一般是运行于Linux服务器(虽然Java是跨平台的)。JavaEE一般运行于Tomcat下面,而对于我们写的控制台应用程序或是服务就需要单独运行了。

我们可以通过Eclipse导出一个jar文件包,在Windows还是Linux都可以通过命令java –jar xxx.jar直接运行,能够看到运行效果。

二、 Eclipse导出jar文件

1、编写代码

首先创建一个Java Project

如果要导出可执行的jar文件,那么我们的Java程序必须要有一个主方法,格式如下:

  

有了主方法,程序的相关逻辑代码都放置于主方法之内即可。

 

2、导出jar(传统方式)

选中需要导出的项目,右键→Export→Runnable JAR file

 

点击“Next”

 

按标识选择后点击“Finish”即可。

3、导出jar(Maven方式)

通过传统方式导出的jar包和第三方包是独立存在的,统一放到指定目录即可。我们也可以通过Maven方式导出jar包,导出的jar包和第三方包都统一在一个jar包里面。

1、修改pom.xml

如果我们不修改pom.xml而直接打包,那么打的包里面就没有第三方jar包,这时候执行就会出错,如下:

 

 为了避免这个问题,我们需要修改pom.xml如下

<build>
    <finalName>ser_json</finalName>
    <plugins>
        <!-- 这个插件是解决jdk1.8的问题,和该问题没直接关系-->
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <configuration>
                <source>1.8</source>
                <target>1.8</target>
            </configuration>
        </plugin>

        <!-- 这个插件才是我们需要配置的重点-->
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-shade-plugin</artifactId><!-- 注意插件名-->
            <version>1.2.1</version>
            <executions>
                <execution>
                    <phase>package</phase>
                    <goals>
                        <goal>shade</goal>
                    </goals>
                    <configuration>
                        <transformers>
                            <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                                <mainClass>cn.zdsoft.App</mainClass><!-- 这里配置主方法的类全路径-->
                            </transformer>
                        </transformers>
                    </configuration>
                </execution>
            </executions>
        </plugin>
    </plugins>
</build>

 

如果项目报错,请选择项目并单击鼠标右键→Maven→Update Project…

2、执行打包命令

找到需要打包的项目并单击鼠标右键→Run As→Maven Build…,出现如下界面:

 

输入打包命令“pakage”之后点击”run”。然后看控制台打印出如下内容:

 

表示打包成功,那么我们就可以将项目目录下target目录下的jar包拷贝执行了,此时执行正常

 

4、运行jar文件

 导出成功之后目录结构如下:

 

请不要破环目录结构,直接通过命令 java –jar write_file.jar即可执行该程序

三、  以服务的形式运行

对于C#来说,我们可以创建Windows服务,而Java中可以通过创建控制台应用程序,然后通过nohup的方式在后台运行,也相当于是一个服务。下面对该内容进行说明。

1、程序停止事件

我们以服务的方式运行时,当程序停止时往往会处理很多的业务,因此我们需要注册监听程序停止事件,这样才能保证程序的正确运行而不丢失数据等。首先需要对Java代码的主方法进行修改。修改后的代码如下:

 

2、以nohup方式运行

然后我们将导出的jar包和第三方jar包复制到Linux系统中,存放于/usr/local/write_file。首先以普通方式运行,结果如下:

 

通过ctrl+c可以结束程序,同时结束事件也能正常捕获到停止事件

 

以nohup方式运行,程序将不会在控制台输出,同时将会在jar包统计目录创建一个文件“nohup.out”,输出的内容全部自动存放于该文件中。

命令:nohup java -jar write_file.jar &

3、结束服务

通过普通方式运行可以用ctrl+c的方式结束运行,而通过nohup方式运行则需要两步,第一步查找当前服务的进程编码,第二步结束进程编码。

查找进程编码:ps -ef|grep write_file.jar

结束编码:kill xxxx

 

 重点说明:

结束服务时非特殊情况不可使用 kill -9 xxxx。因为这种方式相当于Windows的结束进程,那么我们程序无法监听到停止事件,除非程序异常而无法正常停止时使用。

正常情况请使用kill xxxx。

 

四、  守护程序Supervisor

jar文件运行之后难免会存在异常关闭的情况,为了让程序能在异常关闭后自动启动并继续运行,因此我们需要部署一套进程守护系统,经过多方面对比决定使用Supervisor进行线程守护。本来Supervisor的官网有详细介绍(听说),但是打不开,官网地址:http://supervisord.org/

同时本人学习的过程参照了http://www.cnblogs.com/Hai–D/p/5820718.html。在此表示感谢。

1、安装

安装的方式比较简单,就两个命令如下:

1、yum install python-setuptools

2、easy_install supervisor

2、配置

         1、创建目录:/etc/supervisor

         2、执行命令echo_supervisord_conf > /etc/supervisor/supervisord.conf 将会自动在目录/etc/supervisor下创建配置文件supervisord.conf,同时配置文件的内容也已初始化

         3、打开配置文件supervisord.conf,把最后两行的内容修改如下:

        [include]

files = conf.d/*.conf

       4、创建目录/etc/supervisor/conf.d,同时在该目录下创建文件ProjectName.conf(ProjectName代表需要监控的项目名称)

       5、打开ProjectName.conf,然后添加内容如下(注意分号后面是注释,可省略):  

[program: ProjectName]
command=nohup java -jar ProjectName.jar &; 运行程序的命令
directory=/root/Publishing/PublishOutput/ ; 命令执行的目录
autorestart=true ; 程序意外退出是否自动重启
autostart=true ; 是否自动启动
stderr_logfile=/var/log/ProjectName.err.log ; 错误日志文件
stdout_logfile=/var/log/ProjectName.out.log ; 输出日志文件
;environment=ASPNETCORE_ENVIRONMENT=Production ; 进程环境变量
user=root ; 进程执行的用户身份
stopsignal=INT
startsecs=1 ; 自动重启间隔

         6、启动

supervisord -c /etc/supervisor/supervisord.conf

         7、查看运行状态

ps -ef | grep ProjectName

如下,表示成功

  

如果在执行supervisord命令时出现如下错误:

Error: Another program is already listening on a port that one of our HTTP servers is configured to use. 

Shut this program down first before starting supervisord.

For help, use /usr/bin/supervisord –h

则表示Supervisor已经启动,可以通过命令supervisorctl shutdown终止它。

3、开机启动

1、在目录/usr/lib/systemd/system/下创建文件supervisord.service

supervisord.service文件内容如下:

[Unit]
Description=Supervisor daemon 

[Service]
Type=forking
ExecStart=/usr/bin/supervisord -c /etc/supervisor/supervisord.conf
ExecStop=/usr/bin/supervisorctl shutdown
ExecReload=/usr/bin/supervisorctl reload
KillMode=process
Restart=on-failure
RestartSec=42s 

[Install]
WantedBy=multi-user.target

 

2、执行命令,启动开机启动服务

systemctl enable supervisord

提示

Created symlink from /etc/systemd/system/multi-user.target.wants/supervisord.service to /usr/lib/systemd/system/supervisord.service.

 

3、验证是否为开机启动

systemctl is-enabled supervisord

提示enabled表示成功

 

4、命令汇总

4.1 启动Supervisor

supervisord -c /etc/supervisor/supervisord.conf

 

4.2 停止Supervisor

supervisorctl shutdown

 

4.3 查看所有任务状态

supervisorctl status

 

4.4 关闭所有任务

supervisorctl shutdown

 

4.5启动或停止服务

supervisorctl stop|start program_name

 

五、附件

 

版权声明:本文为duanjt原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/duanjt/articles/7131993.html