快速做网站流量数据统计分析,泰安seo公司,wordpress保存文件,电商合作平台目录 一、分模块开发
1、分模块开发设计
2、依赖管理
二、继承和聚合
1、聚合
2、继承
三、属性
1、基本介绍
2、版本管理
四、多环境配置与应用
1、多环境开发
2、跳过测试
五、私服
1、私服安装
2、私服仓库分类 一、分模块开发 1、分模块开发设计 ▶ 示意图 …目录 一、分模块开发
1、分模块开发设计
2、依赖管理
二、继承和聚合
1、聚合
2、继承
三、属性
1、基本介绍
2、版本管理
四、多环境配置与应用
1、多环境开发
2、跳过测试
五、私服
1、私服安装
2、私服仓库分类 一、分模块开发 1、分模块开发设计 ▶ 示意图 ▶ 抽取domai层 ▷ 步骤1 : 创建新模块 创建一个名称为maven_03_pojo的jar项目。 ▷ 步骤2 : 项目中创建domain包 在maven_03_pojo项目中创建com.itheima.domain包并将maven_02_ssm中Book类拷贝到该包中 ▷ 步骤3 : 删除原项目中的domain包 删除后maven_02_ssm项目中用到Book的类中都会有红色提示要想解决这个问题我们需要在maven_02_ssm中添加maven_03_pojo的依赖。 ▷ 步骤4 : 建立依赖关系 在maven_02_ssm项目的pom.xml添加maven_03_pojo的依赖 dependencygroupIdcom.itheima/groupIdartifactIdmaven_03_pojo/artifactIdversion1.0-SNAPSHOT/version
/dependency 因为添加了依赖所以在maven_02_ssm中就已经能找到Book类所以刚才的报红提示就会消。 ▷ 步骤5 : 将项目安装本地仓库 将需要被依赖的项目maven_03_pojo使用maven的install命令把其安装到Maven的本地仓库中。 安装成功后在对应的路径下就看到安装好的jar包 说明: 具体安装在哪里和你们自己电脑上Maven的本地仓库配置的位置有关。 当执行maven_02_ssm的compile的命令后就已经能够成功编译。其他的模块类似都是这样拆分。 2、依赖管理 maven基础中有介绍http://t.csdn.cn/1wBO8 二、继承和聚合 1、聚合 ▶ 基本介绍 ● 分模块开发后需要将这四个项目都安装到本地仓库目前我们只能通过项目Maven面板的install来安装并且需要安装四个如果我们的项目足够多那么一个个安装起来还是比较烦的 ● 如果四个项目都已经安装成功当ssm_pojo发生变化后我们就得将ssm_pojo重新安装到maven仓库但是为了确保我们对ssm_pojo的修改不会影响到其他项目模块我们需要对所有的模块进行重新编译那又需要将所有的模块再来一遍项目少的话还好但是如果项目多的话一个个操作项目就容易出现漏掉或重复操作的问题所以提出聚合。 ● 所谓聚合: 将多个模块组织成一个整体同时进行项目构建的过程称为聚合 ● 聚合工程通常是一个不具有业务功能的空工程有且仅有一个pom文件 ● 作用使用聚合工程可以将多个工程编组通过对聚合工程进行构建实现对所包含的模块进行同步构建 ● 当工程中某个模块发生更新变更时必须保障工程中与已更新模块关联的模块同步更新此时可以使用聚合工程来解决批量模块同步构建的问题。 ▶ 具体实现骤 ▷ 步骤1 : 创建一个空的maven项目 ▷ 步骤2 : 将项目的打包方式改为pom ?xml version1.0 encodingUTF-8?
project xmlnshttp://maven.apache.org/POM/4.0.0xmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsdmodelVersion4.0.0/modelVersiongroupIdcom.itheima/groupIdartifactIdmaven_01_parent/artifactIdversion1.0-RELEASE/versionpackagingpom/packaging/project 说明: 项目的打包方式我们接触到的有三种分别是 ● jar : 默认情况说明该项目为java项目 ● war : 说明该项目为web项目 ● pom : 说明该项目为聚合或继承(后面会讲)目 ▷ 步骤3 : pom.xml添加所要管理的项目 ?xml version1.0 encodingUTF-8?
project xmlnshttp://maven.apache.org/POM/4.0.0xmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsdmodelVersion4.0.0/modelVersiongroupIdcom.itheima/groupIdartifactIdmaven_01_parent/artifactIdversion1.0-RELEASE/versionpackagingpom/packaging!--设置管理的模块名称--modulesmodule../maven_02_ssm/modulemodule../maven_03_pojo/modulemodule../maven_04_dao/module/modules
/project ▷ 步骤4 : 使用聚合统一管理项目 测试发现当maven_01_parent的compile被点击后所有被其管理的项目都会被执行编译操作。这就是聚合工程的作用。 说明聚合工程管理的项目在进行运行的时候会按照项目与项目之间的依赖关系来自动决定执行的顺序和配置的顺序无关。聚合工程主要是用来管理项目。 2、继承 ▶ 基本介绍 完成了使用聚合工程去管理项目聚合工程进行某一个构建操作其他被其管理的项目也会执行相同的构建操作。多模块开发存在的另外一个问题重复配置的问题我们先来看张图: ● spring-webmvc、spring-jdbc在三个项目模块中都有出现这样就出现了重复的内容 ● spring-test只在ssm_crm和ssm_goods中出现而在ssm_order中没有这里是部分重复的内容 ● 我们使用的spring版本目前是5.2.10.RELEASE假如后期要想升级spring版本所有跟Spring相关jar包都得被修改涉及到的项目越多维护成本越高面对上面的这些问题就得用到继承。 ● 所谓继承 : 描述的是两个工程间的关系与java中的继承相似子工程可以继承父工程中的配置信息常见于依赖关系的继承。 ● 作用 ○ 简化配置 ○ 减少版本冲突 ▶ 具体实现骤 ▷ 步骤1 : 创建一个空的Maven项目并将其打包方式设置为pom 因为这一步和前面maven创建聚合工程的方式是一摸一样所以我们可以单独创建一个新的工程也可以直接和聚合公用一个工程。实际开发中聚合和继承一般也都放在同一个项目中但是这两个的功能是不一样的。 ▷ 步骤2 : 在子项目中设置其父工程 分别在maven_02_ssm,maven_03_pojo,maven_04_dao的pom.xml中添加其父项目为maven_01_parent !--配置当前工程继承自parent工程--
parentgroupIdcom.itheima/groupIdartifactIdmaven_01_parent/artifactIdversion1.0-RELEASE/version!--设置父项目pom.xml位置路径--relativePath../maven_01_parent/pom.xml/relativePath
/parent ▷ 步骤3 : 优化子项目共有依赖导入问题 1. 将子项目共同使用的jar包都抽取出来维护在父项目的pom.xml中 ?xml version1.0 encodingUTF-8?
project xmlnshttp://maven.apache.org/POM/4.0.0xmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsdmodelVersion4.0.0/modelVersiongroupIdcom.itheima/groupIdartifactIdmaven_01_parent/artifactIdversion1.0-RELEASE/versionpackagingpom/packaging!--设置管理的模块名称--modulesmodule../maven_02_ssm/modulemodule../maven_03_pojo/modulemodule../maven_04_dao/module/modulesdependenciesdependencygroupIdorg.springframework/groupIdartifactIdspring-core/artifactIdversion5.2.10.RELEASE/version/dependencydependencygroupIdorg.springframework/groupIdartifactIdspring-webmvc/artifactIdversion5.2.10.RELEASE/version/dependencydependencygroupIdorg.springframework/groupIdartifactIdspring-jdbc/artifactIdversion5.2.10.RELEASE/version/dependencydependencygroupIdorg.springframework/groupIdartifactIdspring-test/artifactIdversion5.2.10.RELEASE/version/dependencydependencygroupIdorg.mybatis/groupIdartifactIdmybatis/artifactIdversion3.5.6/version/dependencydependencygroupIdorg.mybatis/groupIdartifactIdmybatis-spring/artifactIdversion1.3.0/version/dependencydependencygroupIdmysql/groupIdartifactIdmysql-connector-java/artifactIdversion5.1.47/version/dependencydependencygroupIdcom.alibaba/groupIdartifactIddruid/artifactIdversion1.1.16/version/dependencydependencygroupIdjavax.servlet/groupIdartifactIdjavax.servlet-api/artifactIdversion3.1.0/versionscopeprovided/scope/dependencydependencygroupIdcom.fasterxml.jackson.core/groupIdartifactIdjackson-databind/artifactIdversion2.9.0/version/dependency/dependencies
/project 2. 删除子项目中已经被抽取到父项目的pom.xml中的jar包如在maven_02_ssm的pom.xml中将已经出现在父项目的jar包删除掉 ?xml version1.0 encodingUTF-8?project xmlnshttp://maven.apache.org/POM/4.0.0 xmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsdmodelVersion4.0.0/modelVersiongroupIdcom.itheima/groupIdartifactIdmaven_02_ssm/artifactIdversion1.0-SNAPSHOT/versionpackagingwar/packaging!--配置当前工程继承自parent工程--parentgroupIdcom.itheima/groupIdartifactIdmaven_01_parent/artifactIdversion1.0-RELEASE/versionrelativePath../maven_01_parent/pom.xml/relativePath/parentdependenciesdependencygroupIdjunit/groupIdartifactIdjunit/artifactIdversion4.12/versionscopetest/scope/dependencydependencygroupIdjunit/groupIdartifactIdjunit/artifactIdversion4.11/versionscopetest/scope/dependencydependencygroupIdcom.itheima/groupIdartifactIdmaven_04_dao/artifactIdversion1.0-SNAPSHOT/version!--排除依赖是隐藏当前资源对应的依赖关系--exclusionsexclusiongroupIdlog4j/groupIdartifactIdlog4j/artifactId/exclusionexclusiongroupIdorg.mybatis/groupIdartifactIdmybatis/artifactId/exclusion/exclusions/dependency/dependenciesbuildpluginsplugingroupIdorg.apache.tomcat.maven/groupIdartifactIdtomcat7-maven-plugin/artifactIdversion2.1/versionconfigurationport80/portpath//path/configuration/plugin/plugins/build
/project 删除完后你会发现父项目中有依赖对应的jar包子项目虽然已经将重复的依赖删除掉了但是刷新的时候子项目中所需要的jar包依然存在。当项目的parent标签被移除掉会发现多出来的jar包依赖也会随之消失。 3. 将maven_04_dao项目的pom.xml中的所有依赖删除然后添加上maven_01_parent的父项目坐标 ?xml version1.0 encodingUTF-8?
project xmlnshttp://maven.apache.org/POM/4.0.0xmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsdmodelVersion4.0.0/modelVersiongroupIdcom.itheima/groupIdartifactIdmaven_04_dao/artifactIdversion1.0-SNAPSHOT/version!--配置当前工程继承自parent工程--parentgroupIdcom.itheima/groupIdartifactIdmaven_01_parent/artifactIdversion1.0-RELEASE/versionrelativePath../maven_01_parent/pom.xml/relativePath/parent
/project 刷新并查看Maven的面板会发现maven_04_dao同样引入了父项目中的所有依赖。 这样我们就可以解决刚才提到的第一个问题将子项目中的公共jar包抽取到父工程中进行统一添加依赖这样做的可以简化配置并且当父工程中所依赖的jar包版本发生变化所有子项目中对应的jar包版本也会跟着更新。 ▷ 步骤4 : 优化子项目依赖版本问题 如果把所有用到的jar包都管理在父项目的pom.xml看上去更简单些但是这样就会导致有很多项目引入了过多自己不需要的jar包。如上面看到的这张图: 如果把所有的依赖都放在了父工程中进行统一维护就会导致ssm_order项目中多引入了spring-test的jar包如果这样的jar包过多的话对于ssm_order来说也是一种负担。 那针对于这种部分项目有的jar包该如何管理优化呢? 1. 在父工程mavne_01_parent的pom.xml来定义依赖管理 !--定义依赖管理--
dependencyManagementdependenciesdependencygroupIdjunit/groupIdartifactIdjunit/artifactIdversion4.12/versionscopetest/scope/dependency/dependencies
/dependencyManagement 2. 将maven_02_ssm的pom.xml中的junit依赖删除掉刷新Maven 刷新完会发现在maven_02_ssm项目中的junit依赖并没有出现所以我们得到一个结论: dependencyManagement标签不真正引入jar包而是配置可供子项目选择的jar包依赖子项目要想使用它所提供的这些jar包需要自己添加依赖并且不需要指定version 3. 在maven_02_ssm的pom.xml添加junit的依赖 dependencygroupIdjunit/groupIdartifactIdjunit/artifactIdscopetest/scope
/dependency 注意这里就不需要添加版本了这样做的好处就是当父工程dependencyManagement标签中的版本发生变化后子项目中的依赖版本也会跟着发生变化 4. 在maven_04_dao的pom.xml添加junit的依赖 dependencygroupIdjunit/groupIdartifactIdjunit/artifactIdscopetest/scope
/dependency 这个时候maven_02_ssm和maven_04_dao这两个项目中的junit版本就会跟随着父项目中的标签dependencyManagement中junit的版本发生变化而变化。不需要junit的项目就不需要添加对应的依赖即可。 总结来说继承可以帮助做两件父工程主要是用来快速配置依赖jar包和管理项目中所使用的资源。 ● 将所有项目公共的jar包依赖提取到父工程的pom.xml中子项目就可以不用重复编写简化开发 ● 将所有项目的jar包配置到父工程的dependencyManagement标签下实现版本管理方便维护 ○ dependencyManagement标签不真正引入jar包只是管理jar包的版本 ○ 子项目在引入的时候只需要指定groupId和artifactId不需要加version ○ 当dependencyManagement标签中jar包版本发生变化所有子项目中有用到该jar包的地方对应的版本会自动随之更新 ▶ 聚合与继承的别 ▷ 两种之间的作: ● 聚合用于快速构建项目对项目进行管理 ● 继承用于快速配置和管理子项目中所使用jar包的版本 ▷ 聚合和继承的相同点: ● 聚合与继承的pom.xml文件打包方式均为pom可以将两种关系制作到同一个pom文件中 ● 聚合与继承均属于设计型模块并无实际的模块内容 ▷ 聚合和继承的不同点: ● 聚合是在当前模块中配置关系聚合可以感知到参与聚合的模块有哪些 ● 继承是在子模块中配置关系父模块无法感知哪些子模块继承了自己 ▶ IDEA构建聚合与继承程 ▷ 步骤1 : 创建一个Maven项目 创建一个空的Maven项目可以将项目中的src目录删除掉这个项目作为聚合工程和父工程。 ▷ 步骤2 : 创建子项目 该项目可以被聚合工程管理同时会继承父工程。 创建成功后maven_parent即是聚合工程又是父工程maven_web中也有parent标签继承的就是maven_parent,对于难以配置的内容都自动生成。 三、属性 1、基本介绍 ▶ 图示 ▶ 解决骤 ▷ 步骤1 : 父工程中定义属性 propertiesspring.version5.2.10.RELEASE/spring.versionjunit.version4.12/junit.versionmybatis-spring.version1.3.0/mybatis-spring.version
/properties ▷ 步骤2 : 修改依赖的version dependencygroupIdorg.springframework/groupIdartifactIdspring-core/artifactIdversion${spring.version}/version
/dependency
dependencygroupIdorg.springframework/groupIdartifactIdspring-webmvc/artifactIdversion${spring.version}/version
/dependency
dependencygroupIdorg.springframework/groupIdartifactIdspring-jdbc/artifactIdversion${spring.version}/version
/dependency 此时我们只需要更新父工程中properties标签中所维护的jar包版本所有子项目中的版本也就跟着更新。当然除了将spring相关版本进行维护我们可以将其他的jar包版本也进行抽取这样就可以对项目中所有jar包的版本进行统一维护如: !--定义属性--
propertiesspring.version5.2.10.RELEASE/spring.versionjunit.version4.12/junit.versionmybatis-spring.version1.3.0/mybatis-spring.version
/properties ▶ 配置文件加载属性 想让Maven对于属性的管理范围能更大些比如我们之前项目中的jdbc.properties这个配置文件中的属性能不能也来让Maven进行管理呢? 答案是肯定的具体的实现步骤: ▷ 步骤1 : 父工程定义属性 propertiesjdbc.urljdbc:mysql://127.1.1.1:3306/ssm_db/jdbc.url
/properties ▷ 步骤2 : jdbc.properties文件中引用属性 在jdbc.properties将jdbc.url的值直接获取Maven配置的属性 jdbc.drivercom.mysql.jdbc.Driver
jdbc.url${jdbc.url}
jdbc.usernameroot
jdbc.passwordroot ▷ 步骤3 : 设置maven过滤文件范围 Maven在默认情况下是从当前项目的src\main\resources下读取文件进行打包。现在我们需要打包的资源文件是在maven_02_ssm下,需要我们通过配置来指定下具体的资源目录。 buildresources!--设置资源目录--resourcedirectory../maven_02_ssm/src/main/resources/directory!--设置能够解析${}默认是false --filteringtrue/filtering/resource/resources
/build 说明: directory路径前要添加../的原因是maven_02_ssm相对于父工程的pom.xml路径是在其上一层的目录中所以需要添加。 修改完后注意maven_02_ssm项目的resources目录就多了些东西如下: ▷ 步骤4 : 测试是否生效 测试的时候只需要将maven_02_ssm项目进行打包然后观察打包结果中最终生成的内容是否为Maven中配置的内容。 ▶ 问题解决 有一个问题没有解决因为不只是maven_02_ssm项目需要有属性被父工程管理如果有多个项目需要配置该如何实现? ▷ 方式一: buildresources!--设置资源目录并设置能够解析${}--resourcedirectory../maven_02_ssm/src/main/resources/directoryfilteringtrue/filtering/resourceresourcedirectory../maven_03_pojo/src/main/resources/directoryfilteringtrue/filtering/resource.../resources
/build 可以配但是如果项目够多的话这个配置也是比较繁琐 ▷ 方式二: buildresources!--${project.basedir}: 当前项目所在目录,子项目继承了父项目相当于所有的子项目都添加了资源目录的过滤--resourcedirectory${project.basedir}/src/main/resources/directoryfilteringtrue/filtering/resource/resources
/build 说明: 打包的过程中如果报如下错误: 原因就是Maven发现你的项目为web项目就会去找web项目的入口web.xml[配置文件配置的方式]发现没有找到就会报。 ▷ 解决方案1在maven_02_ssm项目的src\main\webapp\WEB-INF\添加一个web.xml文件 ?xml version1.0 encodingUTF-8?
web-app xmlnshttp://xmlns.jcp.org/xml/ns/javaeexmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsdversion3.1
/web-app ▷ 解决方案2 : 配置maven打包war时忽略web.xml检查 buildpluginsplugingroupIdorg.apache.maven.plugins/groupIdartifactIdmaven-war-plugin/artifactIdversion3.2.3/versionconfigurationfailOnMissingWebXmlfalse/failOnMissingWebXml/configuration/plugin/plugins
/build 上面我们所使用的都是Maven的自定义属性除了${project.basedir}它属于Maven的内置系统属性。 在Maven中的属性分: ○ 自定义属性常用 ○ 内置属性 ○ Setting属性 ○ Java系统属性 ○ 环境变量属性 具体如何查看这些属性: 在cmd命令行中输入mvn help:system 具体使用就是使用 ${key}来获取key为等号左边的值为等号右边的比如获取红线的值对应的写法为 ${java.runtime.name}。 2、版本管理 关于这个版本管理解决的问题是在Maven创建项目和引用别人项目的时候我们都看到过如下内容: 在我们jar包的版本定义中有两个工程版本用的比较多: ● SNAPSHOT快照版本 ○ 项目开发过程中临时输出的版本称为快照版本 ○ 快照版本会随着开发的进展不断更新 ● RELEASE发布版本 ○ 项目开发到一定阶段里程碑后向团队外部发布较为稳定的版本这种版本所对应的构件文件是稳定的 ○ 即便进行功能的后续开发也不会改变当前发布版本内容这种版本称为发布版本 除了上面的工程版本我们还经常能看到一些发布版本: ● alpha版 : 内测版bug多不稳定内部版本不断添加新功能 ● beta版 : 公测版不稳定(比alpha稳定些)bug相对较多不断添加新功能 ● 纯数字版 四、多环境配置与应用 1、多环境开发 ● 我们平常都是在自己的开发环境进行开发 ● 当开发完成后需要把开发的功能部署到测试环境供测试人员进行测试使用 ● 等测试人员测试通过后我们会将项目部署到生成环境上线使用。 ● 这个时候就有一个问题是不同环境的配置是不相同的如不可能让三个环境都用一个数据库所以就会有三个数据库的url配置 ● 我们在项目中如何配置? ● 要想实现不同环境之间的配置切换又该如何来实现呢? ▶ 具体实现骤 ▷ 步骤1 : 父工程配置多个环境,并指定默认激活环境 profiles!--开发环境--profileidenv_dep/idpropertiesjdbc.urljdbc:mysql://127.1.1.1:3306/ssm_db/jdbc.url/properties!--设定是否为默认启动环境--activationactiveByDefaulttrue/activeByDefault/activation/profile!--生产环境--profileidenv_pro/idpropertiesjdbc.urljdbc:mysql://127.2.2.2:3306/ssm_db/jdbc.url/properties/profile!--测试环境--profileidenv_test/idpropertiesjdbc.urljdbc:mysql://127.3.3.3:3306/ssm_db/jdbc.url/properties/profile
/profiles ▷ 步骤2 : 执行安装查看env_dep环境是否生效 查看到的结果为: ▷ 步骤3 : 切换默认环境为生产环境 profiles!--开发环境--profileidenv_dep/idpropertiesjdbc.urljdbc:mysql://127.1.1.1:3306/ssm_db/jdbc.url/properties/profile!--生产环境--profileidenv_pro/idpropertiesjdbc.urljdbc:mysql://127.2.2.2:3306/ssm_db/jdbc.url/properties!--设定是否为默认启动环境--activationactiveByDefaulttrue/activeByDefault/activation/profile!--测试环境--profileidenv_test/idpropertiesjdbc.urljdbc:mysql://127.3.3.3:3306/ssm_db/jdbc.url/properties/profile
/profiles ▷ 步骤4 : 执行安装并查看env_pro环境是否生效 查看到的结果为jdbc:mysql://127.2.2.2:3306/ssm_db 虽然已经能够实现不同环境的切换但是每次切换都是需要手动修改如何来实现在不改变代码的前提下完成环境的切换呢? ▷ 步骤5 : 命令行实现环境切换 ▷ 步骤6 : 执行安装并查看env_test环境是否生效 查看到的结果为jdbc:mysql://127.3.3.3:3306/ssm_db 2、跳过测试 前面在执行install指令的时候Maven都会按照顺序从上往下依次执行每次都会执行test对于test来说有它存在的意义 ● 可以确保每次打包或者安装的时候程序的正确性假如测试已经通过在我们没有修改程序的前提下再次执行打包或安装命令由于顺序执行测试会被再次执行就有点耗费时间了。 ● 功能开发过程中有部分模块还没有开发完毕测试无法通过但是想要把其中某一部分进行快速打包此时由于测试环境失败就会导致打包失败。 遇到上面这些情况的时候我们就想跳过测试执行下面的构建命令具体实现方 ▶ 方式一 : IDEA工具实现跳过测试 图中的按钮为Toggle Skip Tests ModeToggle翻译为切换的意思也就是说在测试与不测试之间进行切换。点击一下出现测试画横线的图片如下: 说明测试已经被关闭再次点击就会恢复。这种方式最简单但是有点暴力会把所有的测试都跳过如果我们想更精细的控制哪些跳过哪些不跳过就需要使用配置插件的方式。 ▶ 方式二 : 配置插件实现跳过测试 在父工程中的pom.xml中添加测试插件配置 buildpluginspluginartifactIdmaven-surefire-plugin/artifactIdversion2.12.4/versionconfigurationskipTestsfalse/skipTests!--排除掉不参与测试的内容--excludesexclude**/BookServiceTest.java/exclude/excludes/configuration/plugin/plugins
/build skipTests : 如果为true则跳过所有测试如果为false则不跳过测试 excludes哪些测试类不参与测试即排除针对skipTests为false来设置的 includes: 哪些测试类要参与测试即包含,针对skipTests为true来设置的 ▶ 方式三 : 命令行跳过测试 使用Maven的命令行mvn 指令 -D skipTests 注意事项: ● 执行的项目构建指令必须包含测试生命周期否则无效果。例如执行compile生命周期不经过test生命周期。 ● 该命令可以不借助IDEA直接使用cmd命令行进行跳过测试需要注意的是cmd要在pom.xml所在目录下进行执行。 五、私服 1、私服安装 ▶ 简单介绍 ● 私服 : 公司内部搭建的用于存储Maven资源的服务器 ● 远程仓库 : Maven开发团队维护的用于存储Maven资源的服务器 所以说: 私服是一台独立的服务器用于解决团队内部的资源共享与资源同步问题 ● Nexus ○ Sonatype公司的一款maven私服产品 ○ 下载地址https://help.sonatype.com/repomanager3/product-information/download ▶ 私服装 ▷ 步骤1 :下载解压 将资料\latest-win64.zip解压到一个空目录下。 ▷ 步骤2 : 启动Nexus 使用cmd进入到解压目录下的nexus-3.30.1-01\bin,执行如下命令: nexus.exe /run nexus 看到如下内容说明启动成功。 ▷ 步骤3 : 浏览器访问 访问地址为: http://localhost:8081 ▷ 步骤4 : 首次登录重置密码 输入用户名和密码进行登录登录成功后出现如下页面 点击下一步需要重新输入新密码为了和后面的保持一致密码修改为admin 设置是否运行匿名访问 点击完成 至此私服就已经安装成功。如果要想修改一些基础配置信息可以使用: ● 修改基础配置信息 ○ 安装路径下etc目录中nexus-default.properties文件保存有nexus基础配置信息例如默认访问端口。 ● 修改服务器运行配置信息 ○ 安装路径下bin目录中nexus.vmoptions文件保存有nexus服务器启动对应的配置信息例如默认占用内存空间。 2、私服仓库分类 ▶ 私服资源操作流程分析 (1) 在没有私服的情况下我们自己创建的服务都是安装在Maven的本地仓库中 (2) 私服中也有仓库我们要把自己的资源上传到私服最终也是放在私服的仓库中 (3) 其他人要想使用你所上传的资源就需要从私服的仓库中获取 (4) 当我们要使用的资源不是自己写的是远程中央仓库有的第三方jar包这个时候就需要从远程中央仓库下载每个开发者都去远程中央仓库下速度比较慢(中央仓库服务器在国外) (5) 私服就再准备一个仓库用来专门存储从远程中央仓库下载的第三方jar包第一次访问没有就会去远程中央仓库下载下次再访问就直接走私服下载 (6) 前面在介绍版本管理的时候提到过有SNAPSHOT和RELEASE如果把这两类的都放到同一个仓库比较混乱所以私服就把这两个种jar包放入不同的仓库 (7) 上面我们已经介绍了有三种仓库一种是存放SNAPSHOT的一种是存放RELEASE还有一种是存放从远程仓库下载的第三方jar包那么我们在获取资源的时候要从哪个仓库种获取呢? (8) 为了方便获取我们将所有的仓库编成一个组我们只需要访问仓库组去获取资源。 所有私服仓库总共分为三大: ● 宿主仓库hosted 保存无法从中央仓库获取的资源 ○ 自主研发 ○ 第三方非开源项目,比如Oracle,因为是付费产品所以中央仓库没有 ● 代理仓库proxy ○ 代理远程仓库通过nexus访问其他公共仓库例如中央仓库 ● 仓库组group ○ 将若干个仓库组成一个群组简化配置 ○ 仓库组不能保存资源属于设计型仓库 ▶ 本地仓库访问私服置 ▷ 步骤1 : 私服上配置仓库 说明 ● 第56步骤是创建itheima-snapshot仓库 ● 第78步骤是创建itheima-release仓库 ▷ 步骤2 : 配置本地Maven对私服的访问权限 serversserveriditheima-snapshot/idusernameadmin/usernamepasswordadmin/password/serverserveriditheima-release/idusernameadmin/usernamepasswordadmin/password/server
/servers ▷ 步骤3 : 配置私服的访问路径 mirrorsmirror!--配置仓库组的ID--idmaven-public/id!--*代表所有内容都从私服获取--mirrorOf*/mirrorOf!--私服仓库组maven-public的访问路径--urlhttp://localhost:8081/repository/maven-public//url/mirror
/mirrors 为了避免阿里云Maven私服地址的影响建议先将之前配置的阿里云Maven私服镜像地址注释掉等练习完后再将其恢复。 至此本地仓库就能与私服进行交互了。 ▶ 私服资源上传与下载 本地仓库与私服已经建立了连接接下来就需要往私服上上传资源和下载资源具体的实现步骤: ▷ 步骤1 : 配置工程上传私服的具体位置 !--配置当前工程保存在私服中的具体位置--
distributionManagementrepository!--和maven/settings.xml中server中的id一致表示使用该id对应的用户名和密码--iditheima-release/id!--release版本上传仓库的具体地址--urlhttp://localhost:8081/repository/itheima-release//url/repositorysnapshotRepository!--和maven/settings.xml中server中的id一致表示使用该id对应的用户名和密码--iditheima-snapshot/id!--snapshot版本上传仓库的具体地址--urlhttp://localhost:8081/repository/itheima-snapshot//url/snapshotRepository
/distributionManagement ▷ 步骤2 : 发布资源到私服 或者执行Maven命令 mvn deploy 注意: 要发布的项目都需要配置distributionManagement标签要么在自己的pom.xml中配置要么在其父项目中配置然后子项目中继承父项目即可。发布成功在私服中就能看到: 现在发布是在itheima-snapshot仓库中如果想发布到itheima-release仓库中就需要将项目pom.xml中的version修改成RELEASE即可。 如果想删除已经上传的资源可以在界面上进行删除操作: 如果私服中没有对应的jar会去中央仓库下载速度很慢。可以配置让私服去阿里云中下载依赖。