Updated on 2023-11-28 GMT+08:00

Preparations

If you are using CodeArts Build for the first time, create a project before starting this example.

Prepare a Repository for the WebServer Project

  1. Create the WebServer directory for storing code and enter the directory.
  2. Create the pom.xml file in the WebServer directory. The file content is as follows:

    <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/maven-v4_0_0.xsd">
      <modelVersion>4.0.0</modelVersion>
      <groupId>com.xx.demo</groupId>
      <artifactId>server</artifactId>
      <packaging>jar</packaging>
      <version>1.0</version>
      <name>server</name>
      <url>http://maven.apache.org</url>
      <dependencies>
        <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>3.8.1</version>
        <scope>test</scope>
        </dependency>
      </dependencies>
    
    
      <build>
        <pluginManagement>
          <plugins>
            <plugin>  
              <groupId>org.apache.maven.plugins</groupId>  
              <artifactId>maven-jar-plugin</artifactId>  
              <version>2.6</version>  
              <configuration>  
                <archive>  
                  <manifest>  
                    <addClasspath>true</addClasspath>  
                  </manifest>  
                  <manifestEntries>  
                    <Main-Class>  
                      HelloWorld
                    </Main-Class>  
                  </manifestEntries>  
                </archive>  
              </configuration>  
            </plugin> 
          </plugins>
        </pluginManagement>
      </build>
    </project>

  3. Create the src\main\java directory.
  4. Create the HelloWorld.java file in the directory created in Step 3. The file content is as follows:

    public class HelloWorld {
      public static void main(String[] args) {
        System.out.println("Hello World!");
      }
    }

  5. On the CodeArts Build homepage, click in the upper right corner and select Custom Build Environments.
  6. On the Custom Build Environments page, click CentOS 7-based x86 Base Image to obtain the Dockerfile corresponding to the base image.

    In this example, CentOS is used as the base image.

  7. View the coordinate definition of the build package in the pom.xml file of the WebServer project in Step 2.

    The Maven build package name is <artifact_ID>-<version>.packaging. By default, the build package is generated in the ./target directory. The final build package path is ./target/server-1.0.jar.

  8. Use the build package path obtained in Step 6 to compile the Dockerfile. The content is as follows:

    FROM centos 
    MAINTAINER <devcloud@demo.com> 
    USER root 
    RUN mkdir /demo 
    COPY ./target/server-1.0.jar /demo/app.jar

  9. On the navigation bar, choose Services > Repo. Create a repository named WebServer by referring to Creating a Repository, and upload the file created in Step 2, Step 3, and Step 7 to the repository by referring to Uploading Code to a Repository. After the code is uploaded, you can go to the repository to view the code.

Prepare a Repository for the WebUtil Project

  1. Create the WebUtil directory for storing code.
  2. Create the pom.xml file in the directory created in Step 1. The file content is as follows:

    <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/maven-v4_0_0.xsd">
      <modelVersion>4.0.0</modelVersion>
      <groupId>com.xx.demo</groupId>
      <artifactId>util</artifactId>
      <packaging>jar</packaging>
      <version>1.0</version>
      <name>util</name>
      <url>http://maven.apache.org</url>
      <dependencies>
        <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>3.8.1</version>
        <scope>test</scope>
        </dependency>
      </dependencies>
    
    
      <build>
        <pluginManagement>
          <plugins>
            <plugin>  
              <groupId>org.apache.maven.plugins</groupId>  
              <artifactId>maven-jar-plugin</artifactId>  
              <version>2.6</version>  
              <configuration>  
                <archive>  
                  <manifest>  
                    <addClasspath>true</addClasspath>  
                  </manifest>  
                  <manifestEntries>  
                    <Main-Class>  
                      HelloWorld
                    </Main-Class>  
                  </manifestEntries>  
                </archive>  
              </configuration>  
            </plugin> 
          </plugins>
        </pluginManagement>
      </build>
    </project>

  3. Create the src\main\java directory.
  4. Create the HelloWorld.java file in the directory created in Step 3. The file content is as follows:

    public class HelloWorld {
      public static void main(String[] args) {
        System.out.println("Hello World!");
      }
    }

  5. On the navigation bar, choose Services > Repo. Create a repository named WebUtil by referring to Creating a Repository, and upload the file created in Step 2 and Step 4 to the repository by referring to Uploading Code to a Repository. After the code is uploaded, you can go to the repository to view the code.

Prepare a Self-hosted Repo Endpoint

  1. In the navigation pane, choose Settings > General > Service Endpoints.
  2. Click Create Endpoint and select nexus repository.
  3. In the displayed dialog box, enter the required parameters.

    • Service Endpoint Name: Use the displayed self-hosted repo endpoint name.
    • Repository URL: the address of the self-hosted repo.
    • Username: the username in the configuration file downloaded from the self-hosted repo.
    • Password: the password in the configuration file downloaded from the self-hosted repo.

    The following describes how to obtain the parameters.

    1. In the navigation pane, choose Artifact > Self-hosted Repos and click next to the repository path to obtain the address of the self-hosted repo.

    2. Click Set Me Up.
    3. Select Maven as the Dependency Manager and click Download Configuration File.

    4. Obtain the username and password for the file.

      Use the username and password under a specific ID. The ID refers to the last parameter of the repository address.

  4. When creating an image and pushing it to the SWR repository, go to the SWR console, create an organization, and specify the SWR organization name.