This is the fifth day of my participation in the August More text Challenge. For details, see:August is more challenging

preface

In the process of creating and using Maven projects, when we need to use third-party plug-ins, we do so through dependency management, which is the pom.xml file that is required in Maven projects. Project Object Model (POM), which defines the form of a Maven Project. Therefore, POM.xml can be viewed as a navigation in a Maven project.

Maven repositories

The so-called warehouse, and we usually say granary what is similar, in fact, are used to store things. In the Maven project, the repository is used to store the jar packages used by our project and the various JARS used by Maven.

According to the different storage location of the warehouse, we can divide it into local warehouse and remote warehouse.

The local repository is a folder on our PERSONAL PC where jar packages are stored. It is used to store the jars required by the Maven project.

While remote warehouse refers to the warehouse stored on the Internet, we can further subdivide it into central warehouse, central warehouse mirror, private server.

  • Central repository: one of the most authoritative repositories in the world, available to all of our developers at repo.maven.apache.org.
  • Central warehouse Mirror: As the name suggests, it is a backup of the central warehouse, scattered across major cities on every continent, so that programmers everywhere can use it more quickly.
  • Private server: Private server is in the security consideration, generally built in the LOCAL area network (LAN), only provided for internal personnel use.

So how do we use the warehouse? Or what is the order in which a Maven project retrives resources from the repository?

In general, there is no need for human intervention when we use Maven repository resources. Suppose we want to use a driver, we first to pom. Configured in the XML, then Maven will automatically go to check whether there is the resource in the our local warehouse, if not, then to the private servers at noon to find, if you haven’t found, then to the central warehouse to query in the mirror and finally if the mirror can’t find in the warehouse, Then we’ll have to search the central warehouse.

Maven coordinates

Coordinates, in fact, are the equivalent of our identity card, it is unique, used to identify an item. Generally, a coordinate consists of the following parts: Packaging is optional, classifier cannot be defined directly.

  • groupId: Defines the actual organization to which a Maven project belongs. It is generally agreed to start with the reverse domain name of the name of the organization that created the project. For example, if the company’s domain name is google.com, then we cangroupIdSet tocom.google.
  • ArtifactId: Defines a Maven project (module) in the actual project. It is recommended to prefix the actual project name.
  • version: Defines the current version of the Maven project, usually identified by a three-digit number, such as1.1.1.
  • packaging: Project packaging method, which can bejar,war,rar,ear,pom, by defaultjar.
  • Classifier: Auxiliary builds that help define the output of the build, corresponding to the main component.
  • dependencies: Add what the project needsjarThe corresponding Maven coordinates,, represent the various resource descriptions required in our project.
  • dependency:dependenciesA subtag of adependencyThat corresponds to a coordinate.
  • Properties: Used to set properties.
  • Scope: indicates the scope of a dependency. There are usually several types:
Depend on the range Valid at compile time Valid for test period Runtime valid Packaging effectively
compile 😄 😄 😄 😄
test 😡 😄 😡 😡
privided 😄 😄 😡 😡
runtime 😡 😄 😄 😄
system 😄 😄 😡 😡

Here is a simple example of Maven coordinates:

<groupId>com.cunyu</groupId>
<artifactId>MavenDemo</artifactId>
<version>1.1.1</version>
Copy the code

Rely on the conflict

Causes of conflict

Multiple dependency definitions are common in Maven projects, and each dependency defines its own dependency within a Maven project. Sometimes dependency conflicts occur, usually due to the transitivity of JAR dependencies. If different versions of a dependency are introduced at the same time in a project, dependency conflicts can result.

Conflict resolution

When conflicts arise, how do they need to be resolved? Usually we have two strategies:

  • Maven’s default processing policy:
  1. Shortest path first: For different path lengthsjarPackage, preferentially select the shorter path to take effect.
  2. First declaration priority: When the paths are the same, for exampleA -> B -> CE -> F -> C, then the first to declare is the first to choose the effective.
  • Remove dependency: a dependency package used to exclude a dependency

In addition to the above strategy, we can also manually use the < Exclusion > tag in pom.xml to exclude conflicting dependencies, as shown in the following example to exclude spring-core conflicts:

<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-context</artifactId>
    <version>5.1.9. RELEASE</version>
    <exclusions>
        <exclusion>
            <groupId>org.springframework</groupId>
            <artifactId>spring-core</artifactId>
        </exclusion>
    </exclusions>
</dependency>
Copy the code

conclusion

That’s the end of Maven’s repository and coordinates for today, and why dependencies conflict in Maven and how to resolve them. Personal level is limited, there may be some missing aspects, if you have more knowledge about the above aspects, welcome to comment exchange. Now that we’re almost done with the core knowledge of Maven, let’s take a look at how to use Maven in the real world next time.