<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
===================发布到独立的Tomcat运行============
在开发阶段我们推荐使用内嵌的tomcat进行开发,因为这样会方便很多,但是到生成环境,我希望在独立的tomcat容器中运行,因为我们需要对tomcat做额外的优化,这时我们需要将工程打包成war包发进行发布。
1. 工程的打包方式为war
2. 将spring-boot-starter-tomcat的范围设置为provided
设置为provided是在打包时会将该包排除,因为要放到独立的tomcat中运行,是不需要的。
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
发现原来项目中没有配置上面配置,因为我们配置了Springboot,具有依赖传递,因此自动加上上面的配置,我们需要手动配上覆盖依赖传递的配置:
3. 修改代码,设置启动配置
需要继承SpringBootServletInitializer,然后重写configure,将Spring Boot的入口类设置进去。
package cn.qlq.config;
import javax.sql.DataSource;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.boot.web.support.SpringBootServletInitializer;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.PropertySource;
import com.jolbox.bonecp.BoneCPDataSource;
* 发布到独立的Tomcat需要继承SpringBootServletInitializer类并重写configure方法
@Configuration // 通过该注解来表明该类是一个Spring的配置,相当于一个xml文件
@ComponentScan(basePackages = "cn.qlq") // 配置扫描包
@PropertySource(value = { "classpath:db.properties" }, ignoreResourceNotFound = true)
public class SpringConfig extends SpringBootServletInitializer {
@Value("${jdbc.url}")
private String jdbcUrl;
@Value("${jdbc.driverClassName}")
private String jdbcDriverClassName;
@Value("${jdbc.username}")
private String jdbcUsername;
@Value("${jdbc.password}")
private String jdbcPassword;
@Bean(destroyMethod = "close")
public DataSource dataSource() {
BoneCPDataSource boneCPDataSource = new BoneCPDataSource();
// 数据库驱动
boneCPDataSource.setDriverClass(jdbcDriverClassName);
// 相应驱动的jdbcUrl
boneCPDataSource.setJdbcUrl(jdbcUrl);
// 数据库的用户名
boneCPDataSource.setUsername(jdbcUsername);
// 数据库的密码
boneCPDataSource.setPassword(jdbcPassword);
// 检查数据库连接池中空闲连接的间隔时间,单位是分,默认值:240,如果要取消则设置为0
boneCPDataSource.setIdleConnectionTestPeriodInMinutes(60);
// 连接池中未使用的链接最大存活时间,单位是分,默认值:60,如果要永远存活设置为0
boneCPDataSource.setIdleMaxAgeInMinutes(30);
// 每个分区最大的连接数
boneCPDataSource.setMaxConnectionsPerPartition(100);
// 每个分区最小的连接数
boneCPDataSource.setMinConnectionsPerPartition(5);
return boneCPDataSource;
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
// 设置启动类,用于独立tomcat运行的入口
return builder.sources(SpringConfig.class);
4.打war包:
打包成功:
5. 部署到tomcat
(1)将war包解压到webapps下的ROOT目录中(将原来的ROOT文件夹下面的东西删除掉),启动:
WEB-INF下面 没有web.xml
解释:上面解压后的文件没有web.xml,但是仍能启动。因为SpringConfig继承了SpringBootServletInitializer,所以打包的时候spring-boot做了一系列初始化工作(如上面的org文件夹)。
(2)启动测试:
- 第二种:将此项目类似于普通的项目进行部署,访问需要加项目名称
(1)将打出的war包复制到Tomcat安装目录下的webapps目录下,并将war包重新命名为SSM.war,启动Tomcat(Tomcat启动的时候会自动扫描war包并解压)
(2)启动测试:
springboot项目方式不支持用Eclipse的export导出为war包然后部署到tomcat,因为这种Eclipse的Export打出的war包没有带springboot所做的初始化工作。打包的东西如下:
==============web项目打成jar包独立运行===============
这种方式使用简单,只需要安装JDK环境即可使用。但是不利于tomcat的优化,而且一个项目对应一个内嵌的tomcat。
1.工程打包方式改为jar包
2. 将spring-boot-starter-tomcat的范围设置为默认值compile
3.使用clean package命令打成jar包
4.采用java -jar的方式启动测试:(这种方式启动是不作为守护进程,窗口关闭即关掉此JVM)
java -jar ./springboot-ssm-0.0.1-SNAPSHOT.jar
补充:如果是IDEA中运行项目需要去掉provided,原因是
这可能是Intellij的一个bug,在使用spring-boot的时候,如果把某个引入的依赖设置为provided,那么在Intellij启动时就会找不到相应的类。因此,此时需要把此项配置给注释掉,但是打包上线的时候并不需要这些依赖,那么在打包的时候就把注释打开,即可。
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</dependency>
补充:pom.xml可以设置打成jar包的名字
<finalName>icc</finalName>
linux定时重启java服务 linux定时重启服务命令
1.譬如要在每天早上1点重启机器,它的命令该怎样写? 2.譬如要在每周一早上1点重启机器,它的命令该怎样写经本人实践证明,可使用如下方法实现Linux系统在每天凌晨一点三十分自动重启系统。
1,编辑系统的crontab文件
#vi /etc/crontab
2,在crontab文件里面的run-parts部分加入一行:
30 1 * * * root init 6