Java学习之创建Spring程序

一、利用https://start.spring.io/创建Spring程序


创建好之后,下载下来之后,使用idea打开。


二、修改Maven仓库

Maven默认仓库,在国外。国内使用,会很慢,在下载依赖时,时不时卡着不动或者中断。可以将Maven仓库改为阿里云的仓库,具体操作如下:

  • 修改 maven 根目录下的 conf 文件夹中的setting.xml 文件的mirrors 节点;
 
    
      alimaven
      aliyun maven
      http://maven.aliyun.com/nexus/content/groups/public/
      central        
    

  • pom.xml文件添加

        
            alimaven
            aliyun maven
            http://maven.aliyun.com/nexus/content/groups/public/
            
                true
            
            
                false
            
        
    

三、编写第一个Api

@SpringBootApplication
@RestController
public class LearnSpringApplication {

    public static void main(String[] args) {
        SpringApplication.run(LearnSpringApplication.class, args);
    }
    @RequestMapping("/learn")
    public String learn(){
        return "learn spring";
    }

}

我们只需要仅仅一行代码,就生成一个api啦,其他的工作Spring Boot帮我们完成了。现在,就来启动这个application,我们来看看启动的信息:

application输出log

从输出的log可以看到,Tomcat启动了8080端口,我们访问下刚刚的api
curl http://localhost:8080/learn

同时,我们引入了Actuator依赖,给我们做了其他的一些事,譬如说,提供健康检查。
curl http://localhost:8080/actuator
Actuator提供的服务

四、使用Maven打包

接下来,我们使用Maven打包

  • 使用mvn clean package 打包;
  • 切换到Target目录下 >cd target;
  • 查看目录下文件 dir

    可以看到有两个jar包,一个4k,一个18m。为什么会相差这么大呢?一个是jar包原本的大小,18m的jar包包含了运行所需要的依赖,为可执行性文件,可以直接运行。接下来我们来运行下jar包。
  • 运行jarjava -jar learn-spring-0.0.1-SNAPSHOT.jar
    启动失败了

    原来是8080端口被占用了,那我们把idea的启动停止了,重新执行jar包,可以看到和前面启动application输出的log一样,启动了Tomcat 8080端口。
    jar包输出log

    我们再次访问下

五、踩过的坑

似乎看起来,超级简单,一路顺畅,然而一把辛酸泪。

  • 找不到或无法加载主类LearnSpringApplication
    网上百度说是缺少springboot启动插件,然后pom.xml已有这个配置;
    
                org.springframework.boot
                spring-boot-maven-plugin
            

有一说jar包错误,解决方案使用Maven更新依赖,无效。一怒之下,将项目删除,重新从https://start.spring.io/创建项目。

  • org.junit不存在。这次运行mvm package时出现org.junit不存在,继续百度,网上方案皆是说由于scope造成,需要去除test这个配置。
    test表示依赖的作用域,只能在srctest这个目录下起作用,在其他目录不起作用。
    我的项目文件结构为如下图
    项目结构

    标注test应该是正确的,然而,我也没有其他办法,只能试一试,然而,错误依旧。泪奔。

接着,删除仓库下下载的所有依赖,运行mvn clean package,运行项目,错误依旧。再次把项目删除,重新从https://start.spring.io/创建项目,然而,这次的错误再次发生改变。

  • pom.xmlspring-boot-maven-plugin插件报红,MavenDependencies也报红。
    百度说配置下setting.xml阿里镜像,然而我配置的是阿里镜像啊。重新查看Maven菜鸟教程,不仅需要设置setting.xml,pom.xml也需要添加下相关节点:

        
            alimaven
            aliyun maven
            http://maven.aliyun.com/nexus/content/groups/public/
            
                true
            
            
                false
            
        
    

加上,运行mvn clean package,还是报红。
再次使用终极大法,删除仓储,重新建。
这次是先配置好pom.xml,添加repositories节点,运行mvn clean package,没有报红,有希望,run LearnSpringApplication终于成功了。

血泪之经验: 仓库一定要配置好

你可能感兴趣的:(Java学习之创建Spring程序)