昨天被阿里云的这个酷炫大屏吸引了!
我等 85 后开发者竟然这么少!挺好奇到底什么鬼货色都是 90、95 后在玩?就深刻看了一下。
这是一个对于 Serverless 的体验流动,Serverless 在国内始终都处于不温不火的状态,所以很多开发者其实都不太理解 Serverless 到底是啥!
如果你也有这样的好奇,那么能够跟我一样来体验一下,简略的写个 Hello World,有个最直观的感触这个充斥将来感产品吧!
P.S. 加入流动,退出钉钉群还能每天抽奖一次,有机会赢取 AirPods、高达 PG 模型(我喜爱的)、Cherry 机械键盘等丰盛大礼哦!
如何参加
-【官网】流动主页:https://developer.aliyun.com/…
-【官网】通关宝典:https://help.aliyun.com/docum…
官网文档还是如其余阿里我的项目一样的有待进步(lan)….
如果你最本人的摸索能力有足够信念,能够间接通过官网文档来试试。
如果想少踩坑,能够看我上面写的 超粗疏通关宝典,实现一个 Java 版本的 Hello World!
第一步:进入产品列表,点击创立利用
第二步:抉择“空利用”标签
- Serverless 应用服务器抉择:“函数计算 FC”
- 开发语言选择:Java
第三步:填写利用名称、利用介绍,本人定义就好
第四步:点击新建的利用卡片中的“开发部署”按钮
第五步:新建 helloworld.java
内容如下:
package com.alibaba.serverless.helloworld;
import java.io.UnsupportedEncodingException;
import java.util.UUID;
import com.aliyun.fc.runtime.Context;
import com.aliyun.fc.runtime.FunctionComputeLogger;
import com.aliyun.fc.runtime.FunctionInitializer;
import com.aliyun.fc.runtime.PojoRequestHandler;
import com.aliyuncs.utils.Base64Helper;
/**
* 对应到部署路由中的函数名:* com.alibaba.serverless.helloworld.helloworld::handleRequest
*/
public class helloworld implements FunctionInitializer, PojoRequestHandler<ApiGwRequest, ApiGwResponse> {
/*
* 云函数运行时初始化时的回调函数。*/
@Override
public void initialize(Context context) {FunctionComputeLogger logger = context.getLogger();
logger.debug(String.format("RequestID is %s %n", context.getRequestId()));
}
/*
* Web 云函数解决入口,每次调用时的入口。* @param request 每次申请的所有信息都在 request 中
*/
@Override
public ApiGwResponse handleRequest(ApiGwRequest request, Context context) {FunctionComputeLogger logger = context.getLogger();
// 读取申请对象
String requestPath = request.getPath();
String bodyContext = "";
if (requestPath.startsWith("")) {bodyContext = "你好,世界!";}
// 构建返回对象
ApiGwResponse response = new ApiGwResponse();
response.getHeaders().put("responseHeader", "testValue");
response.getHeaders().put("Content-type", "text/html; charset=utf-8");
boolean isBase = false;
if (isBase) {
try {bodyContext = Base64Helper.encode(bodyContext, "UTF-8");
} catch (UnsupportedEncodingException e) {isBase = false;}
}
response.setBody(bodyContext);
response.setBase64Encoded(isBase);
response.setStatusCode(200);
logger.info("Response 返回:" + bodyContext);
return response;
}
}
第六步:按下图操作,提交代码
第七步:部署利用到日常环境
点击左侧工具栏的第一个图标,进入部署界面,点击“增加一条路由”。
图中 2 局部的内容为:com.alibaba.serverless.helloworld.helloworld::handleRequest
,对应的就是之前创立的 helloworld.java
中的 handleRequest 法,意思就是 /helloworld 申请会被这个类中的 handleRequest 来解决。
留神,申请办法要设置为 POST,前面会说为什么!
第八步:测试 /helloworld 接口
在部署标签边上就有一个测试工具,输出用户门路/helloworld
,点击测试就能够发动申请了,取得后果如下图所示:
回过头来看一下代码,对用的 body 内容:
这个测试工具是不是总感觉有点怪?!是的,竟然没有 HTTP Request Method 的抉择,这个申请默认都是用 POST 来发的,所以在上一步中咱们配置了 /helloworld 为 POST 申请,不然这里就不会胜利。看官网宝典的兄弟,发现这个坑了吗?
怎么样的?你的第一次 Serverless 之旅还算顺利吗?
点击这里一起来试试这种将来的开发方式吧
本文首发:Serverless 初体验:疾速开发与部署一个 Hello World(Java 版),转载请注明出处。
欢送关注我的公众号:程序猿 DD,取得独家整顿的学习资源和日常干货推送。