目录
前言
1. IDEA中配置Maven
2. 创建Maven工程
3. pom核心配置文件
4. 添加插件
5.运行Maven项目
6.maven项目打包
7.说明(scala)
前言
在IDEA中创建Maven项目,前提是已经安装配置好Maven环境 。
1. IDEA中配置Maven
1)打开IDEA 创建一个新的project
2)起名为test
3)打开IDEA 选择File --> Settings --> 搜素maven,就会看到如下界面
4)修改默认配置配置
修改路径
2. 创建Maven工程
在IDEA中配置好maven后, 接下来我们使用maven去快速的去构建一个 JavaWeb项目
1)project创建好以后, 选择创建module
2)选中创建一个 maven 工程
3)点击 Next填写项目信息
4)进行一下修改
5)创建好的工程,长这个样子
Maven目录说明:
src/main/java —— 存放项目的.java 文件
src/main/resources —— 存放项目资源文件,如数据库的配置文件
src/test/java —— 存放所有单元测试.java 文件,如 JUnit 测试类
target —— 项目输出位置,编译后的class 文件会输出到此目录
pom.xml ——maven 项目核心配置文件
3. pom核心配置文件
一个 maven 工程都有一个 pom.xml 文件,通过 pom.xml 文件定义项目的信息、项目依赖、引入插件等等。
1)创建一个Servlet, 缺少jar包报错, 要解决问题,就是要将 servlet-api-xxx.jar 包放进来,作为 maven 工程应当添加 servlet的坐标,从而导入它的jar
2)pom.xml 文件中引入依赖包的坐标
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.lagou</groupId>
<artifactId>hello_maven</artifactId>
<version>1.0-SNAPSHOT</version>
<dependencies>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.1.0</version>
<scope>provided</scope>
</dependency>
</dependencies>
</project>
3)一个Maven工程就是由groupId,artifactId和 version 作为唯一标识, 在引用其他第三方库的时候,也是通过这3个变量确定。
坐标的概念:
- 在maven中坐标就是为了定位一个唯一确定的jar包。
- maven世界拥有大量构建,我们需要找一个用来唯一标识一个构建的统一规范,拥有了统一规范,就可以把查找工作交给机器
Maven坐标主要组成(GAV) - 确定一个jar在互联网位置
标签 | 含义 |
groupId | 定义当前Maven组织名称,通常是公司名 |
artifactId | 定义实际项目名称 |
version | 定义当前项目的当前版本 |
packaging | 打包类型 war:执行 package 会打成 war 包 |
dependency | 使用 |
4)maven 的依赖管理, 是对项目所依赖的 jar 包进行统一管理。
标签 | 含义 |
dependencies | 表示依赖关系 |
dependency | 使用 |
<dependencies>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>3.1.0</version>
</dependency>
</dependencies>
5)坐标的来源方式
添加依赖需要指定依赖 jar 包的坐标,但是很多情况是不知道 jar 包的的坐标,可以通过从网站中搜索查询。
5.1) 输入网址,进入网址 , 进行查询
5.2) 点击进入后,可以看到各个版本的信息,选择3.1.0
4. 添加插件
1)添加编译插件, 设置 jdk 编译版本
以 jdk11为例:需要设置编译版本为 11,这里需要使用 maven 的插件来设置。
在pom中加入如下配置:
<!-- properties 是全局设置,可以设置整个maven项目的编译器 JDK版本 -->
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<!-- 重点 -->
<maven.compiler.source>11</maven.compiler.source>
<maven.compiler.target>11</maven.compiler.target>
</properties>
<!-- 在build中 我们需要指定一下项目的JDK编译版本,maven默认使用1.5版本进行编译
注意 build 与 dependencies是平级关系,标签不要写错位置 -->
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<release>11</release>
</configuration>
</plugin>
</plugins>
</build>
5.运行Maven项目
1)完善项目代码
2)配置、部署项目
3)运行项目
6.maven项目打包
胖包:将maven项目中的依赖包和项目打为一个包 。
瘦包:直接打包,不打包依赖包,仅打包出项目中的代码到JAR包中。
1)打瘦包
2)打胖包
2.1)快捷键:Alt+shirt+ctrl+s
2.2)定入口函数和胖包的保存路径
2.3)开始打包
2.4)打胖包完成
3)同时打胖包和瘦包
3.1)修改maven项目的pom文件
<build>
<plugins>
<plugin>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.3.2</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
<plugin>
<artifactId>maven-assembly-plugin</artifactId>
<configuration>
<descriptorRefs>
<descriptorRef>jar-with-dependencies</descriptorRef>
</descriptorRefs>
<archive>
<manifest>
<mainClass>入口函数</mainClass>
</manifest>
</archive>
</configuration>
<executions>
<execution>
<id>make-assembly</id>
<phase>package</phase>
<goals>
<goal>single</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
3.2)完成打包
7.说明(scala)
<build>
<plugins>
<plugin>
<groupId>org.scala-tools</groupId>
<artifactId>maven-scala-plugin</artifactId>
<version>2.15.2</version>
<executions>
<execution>
<goals>
<goal>compile</goal>
<goal>testCompile</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.6.0</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.19</version>
<configuration>
<skip>true</skip>
</configuration>
</plugin>
</plugins>
</build>
如何运行scala的包
spark -submit
--class 类路径
--master spark://ip地址:7077
包路径