有奖捉虫:云通信与企业服务文档专题,速来> HOT
本文介绍如何 使用 Gradle 创建 zip 部署包使用 Maven 创建 jar 部署包 这两种方式来创建 zip 或 jar 包。创建完成后,可通过控制台页面直接上传包(小于 50MB),或通过把部署包上传至 COS Bucket 后,在 SCF 控制台上通过指定部署包的 Bucket 和 Object 信息,完成代码包提交。

使用 Gradle 创建 zip 部署包

本节内容提供了通过使用 Gradle 工具来创建 Java 类型云函数部署包的方式。创建好的 zip 包符合以下规则,即可以由云函数执行环境所识别和调用。
编译生成的包、类文件、资源文件位于 zip 包的根目录。
依赖所需的 jar 包,位于 /lib 目录内。

环境准备

确保您已经安装 Java 和 Gradle。
Java 11 请安装 TencentKona11 或 JDK 11。
Java 8 请安装 JDK 8,您可以使用 OpenJDK(Linux)或通过 Java 下载安装合适您系统的 JDK。

Gradle 安装

Gradle 安装详情见 Gradle Installation。手工安装步骤如下:
1. 单击下载 Gradle 的 二进制包带文档和源码的完整包
2. 解压包到自己所期望的目录。例如,Windows 下的 C:\\Gradle 目录或 Linux 下的 /opt/gradle/gradle-4.1 目录。
3. 将解压目录下 bin 目录的路径添加到系统 PATH 环境变量中,请对应操作系统执行以下步骤:
Linux:通过 export PATH=$PATH:/opt/gradle/gradle-4.1/bin 完成添加。
Windows:通过计算机 > 右键 > 属性 > 高级系统设置 > 高级 > 环境变量进入到环境变量设置页面,选择 Path 变量编辑,在变量值最后添加 ;C:\\Gradle\\bin;
4. 在命令行执行以下命令,查看 Gradle 是否正确安装。
gradle -v
输出结果如下,则证明 Gradle 已正确安装。如有问题,请查询 Gradle 的 官方文档
------------------------------------------------------------
Gradle 4.1
------------------------------------------------------------
Build time: 2017-08-07 14:38:48 UTC
Revision: 941559e020f6c357ebb08d5c67acdb858a3defc2
Groovy: 2.4.11
Ant: Apache Ant(TM) version 1.9.6 compiled on June 29 2015
JVM: 1.8.0_144 (Oracle Corporation 25.144-b01)
OS: Windows 7 6.1 amd64

代码准备

准备代码文件

1. 在选定的位置创建项目文件夹,例如 scf_example
2. 在项目文件夹根目录,依次创建目录 src/main/java/ 作为包的存放目录。
3. 在创建好的目录下再创建 example 包目录,并在包目录内创建 Hello.java 文件。最终形成如下目录结构:
scf_example/src/main/java/example/Hello.java
4. Hello.java 文件内输入如下代码内容:
package example;
public class Hello {
public String mainHandler(String name, Context context) {
System.out.println("Hello world!");
return String.format("Hello %s.", name);
}
}

准备编译文件

在项目文件夹根目录下创建 build.gradle 文件并输入如下内容:
apply plugin: 'java'

task buildZip(type: Zip) {
from compileJava
from processResources
into('lib') {
from configurations.runtime
}
}

build.dependsOn buildZip

使用 Maven Central 库处理包依赖

如果需要引用 Maven Central 的外部包,可根据需要添加依赖,build.gradle 文件内容如下:
apply plugin: 'java'

repositories {
mavenCentral()
}

dependencies {
compile (
'com.tencentcloudapi:scf-java-events:0.0.2'
)
}

task buildZip(type: Zip) {
from compileJava
from processResources
into('lib') {
from configurations.runtime
}
}

build.dependsOn buildZip
通过 repositories 指明依赖库来源为 mavenCentral 后,在编译过程中,Gradle 会自行从 Maven Central 拉取依赖项,也就是 dependencies 中指明的 com.tencentcloudapi:scf-java-events:0.0.2 包。

使用本地 Jar 包库处理包依赖

如果已经下载 Jar 包到本地,可以使用本地库处理包依赖。在这种情况下,请在项目文件夹根目录下创建 jars 目录,并将下载好的依赖 Jar 包放置到此目录下。build.gradle 文件内容如下:
apply plugin: 'java'

dependencies {
compile fileTree(dir: 'jars', include: '*.jar')
}

task buildZip(type: Zip) {
from compileJava
from processResources
into('lib') {
from configurations.runtime
}
}

build.dependsOn buildZip
通过 dependencies 指明搜索目录为 jars 目录下的 *.jar 文件,依赖会在编译时自动进行搜索。

编译打包

在项目文件夹根目录下执行命令 gradle build,应有编译输出类似如下:
Starting a Gradle Daemon (subsequent builds will be faster)

BUILD SUCCESSFUL in 5s
3 actionable tasks: 3 executed
如果显示编译失败,请根据输出的编译错误信息调整代码。 编译后的 zip 包位于项目文件夹内的 /build/distributions 目录内,并以项目文件夹名命名为 scf_example.zip

使用 Maven 创建 jar 部署包

本节内容提供了通过使用 Maven 工具来创建 Java 类型云函数部署 jar 包的方式。

环境准备

确保您已经安装 Java 和 Gradle。
Java 11 请安装 TencentKona11 或 JDK 11。
Java 8 请安装 JDK 8,您可以使用 OpenJDK(Linux)或通过 Java 下载安装合适您系统的 JDK。

Maven 安装

Maven 安装详情见 Installing Apache Maven。手工安装步骤如下:
1. 下载 Maven 的 zip 包或 tar.gz 包。
2. 解压包到自己所期望的目录。例如,Windows 下的 C:\\Maven 目录或 Linux 下的 /opt/mvn/apache-maven-3.5.0 目录。
3. 将解压目录下 bin 目录的路径添加到系统 PATH 环境变量中,请对应操作系统执行以下步骤:
Linux:通过 export PATH=$PATH:/opt/mvn/apache-maven-3.5.0/bin 完成添加。
Windows:通过计算机 > 右键 > 属性 > 高级系统设置 > 高级 > 环境变量进入到环境变量设置页面,选择 Path 变量编辑,在变量值最后添加 ;C:\\Maven\\bin;
4. 在命令行下执行以下命令,查看 Maven 是否正确安装。
mvn -v
输出结果如下,则证明 Maven 已正确安装。如有问题,请查询 Maven 的 官方文档
Apache Maven 3.5.0 (ff8f5e7444045639af65f6095c62210b5713f426; 2017-04-04T03:39:06+08:00)
Maven home: C:\\Program Files\\Java\\apache-maven-3.5.0\\bin\\..
Java version: 1.8.0_144, vendor: Oracle Corporation
Java home: C:\\Program Files\\Java\\jdk1.8.0_144\\jre
Default locale: zh_CN, platform encoding: GBK
OS name: "windows 7", version: "6.1", arch: "amd64", family: "windows"

代码准备

准备代码文件

1. 在选定的位置创建项目文件夹,例如 scf_example
2. 在项目文件夹根目录,依次创建目录 src/main/java/ 作为包的存放目录。
3. 在创建好的目录下再创建 example 包目录,并在包目录内创建 Hello.java 文件。最终形成如下目录结构:
scf_example/src/main/java/example/Hello.java
4. Hello.java 文件内输入如下代码内容:
package example;
public class Hello {
public String mainHandler(String name, Context context) {
System.out.println("Hello world!");
return String.format("Hello %s.", name);
}
}

准备编译文件

在项目文件夹根目录下创建 pom.xml 文件并输入如下内容:
Java 11
Java 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/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>

<groupId>examples</groupId>
<artifactId>java-example</artifactId>
<packaging>jar</packaging>
<version>1.0-SNAPSHOT</version>
<name>java-example</name>

<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</artifactId>
<version>2.3</version>
<configuration>
<source>11</source>
<target>11</target>
</configuration>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>shade</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>

<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>examples</groupId>
<artifactId>java-example</artifactId>
<packaging>jar</packaging>
<version>1.0-SNAPSHOT</version>
<name>java-example</name>

<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</artifactId>
<version>2.3</version>
<configuration>
<createDependencyReducedPom>false</createDependencyReducedPom>
</configuration>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>shade</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>


使用 Maven Central 库处理包依赖

如果需要引用 Maven Central 的外部包,可以根据需要添加依赖,pom.xml 文件内容如下,添加依赖请关注 <dependencies> 部分。
<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>examples</groupId>
<artifactId>java-example</artifactId>
<packaging>jar</packaging>
<version>1.0-SNAPSHOT</version>
<name>java-example</name>

<dependencies>
<dependency>
<groupId>com.tencentcloudapi</groupId>
<artifactId>scf-java-events</artifactId>
<version>0.0.2</version>
</dependency>
</dependencies>

<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</artifactId>
<version>2.3</version>
<configuration>
<createDependencyReducedPom>false</createDependencyReducedPom>
</configuration>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>shade</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>

编译打包

在项目文件夹根目录下执行命令 mvn package,应有编译输出类似如下:
[INFO] Scanning for projects...
[INFO]
[INFO] ------------------------------------------------------------------------
[INFO] Building java-example 1.0-SNAPSHOT
[INFO] ------------------------------------------------------------------------
[INFO]
...
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 1.785 s
[INFO] Finished at: 2017-08-25T10:53:54+08:00
[INFO] Final Memory: 17M/214M
[INFO] ------------------------------------------------------------------------
如果显示编译失败,请根据输出的编译错误信息调整代码。 编译后的 jar 包位于项目文件夹内的 target 目录内,并根据 pom.xml 内的 artifactId、version 字段命名为 java-example-1.0-SNAPSHOT.jar