zoukankan      html  css  js  c++  java
  • 开发函数计算的正确姿势——运行 Selenium Java

    前言

    首先介绍下在本文出现的几个比较重要的概念:

    函数计算(Function Compute): 函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传。函数计算准备计算资源,并以弹性伸缩的方式运行用户代码,而用户只需根据实际代码运行所消耗的资源进行付费。函数计算更多信息参考
    Fun: Fun 是一个用于支持 Serverless 应用部署的工具,能帮助您便捷地管理函数计算、API 网关、日志服务等资源。它通过一个资源配置文件(template.yml),协助您进行开发、构建、部署操作。Fun 的更多文档参考

    备注: 本文介绍的技巧需要 Fun 版本大于等于 2.10.2。

    依赖工具

    本项目是在 MacOS 下开发的,涉及到的工具是平台无关的,对于 Linux 和 Windows 桌面系统应该也同样适用。在开始本例之前请确保如下工具已经正确的安装,更新到最新版本,并进行正确的配置。

    Fun 和 Fcli 工具依赖于 docker 来模拟本地环境。

    对于 MacOS 用户可以使用 homebrew 进行安装:

    brew cask install docker
    brew tap vangie/formula
    brew install fun
    brew install fcli
    

    Windows 和 Linux 用户安装请参考:

    1. https://github.com/aliyun/fun/blob/master/docs/usage/installation.md
    2. https://github.com/aliyun/fcli/releases

    安装好后,记得先执行 fun config 初始化一下配置。

    注意, 如果你已经安装过了 fun,确保 fun 的版本在 2.10.2 以上。

    $ fun --version
    2.10.1
    

    快速开始

    初始化

    使用 fun init 命令可以快捷地将本模板项目初始化到本地。

    fun init vangie/selenium-java-example
    

    安装依赖

    $ fun install
    ...
    

    本地测试

    测试代码 ChromeDemo 的内容为:

    public class ChromeDemo implements StreamRequestHandler {
    
    
        public void handleRequest(InputStream inputStream,
                                  OutputStream outputStream,
                                  Context context) throws IOException {
    
            System.setProperty("webdriver.chrome.driver", "/code/chromedriver");
    
            ChromeOptions options = new ChromeOptions();
            options.setBinary("/code/headless-chromium");
            options.addArguments("--disable-extensions"); // disabling extensions
            options.addArguments("--disable-gpu"); // applicable to windows os only
            options.addArguments("--disable-dev-shm-usage"); // overcome limited resource problems
            options.addArguments("--no-sandbox"); // Bypass OS security model
            options.addArguments("--headless");
    
            WebDriver driver = new ChromeDriver(options);
    
            driver.get("https://ide.fc.aliyun.com");
    
            outputStream.write(("Page title is: " + driver.getTitle() + "
    ").getBytes());
    
            driver.quit();
    
        }
    
    }
    

    本地运行

    $ mvn package && fun local invoke selenium
    ...
    FC Invoke Start RequestId: 68c83b4c-b053-479c-9b0e-9503582ccb56
    handle user request is com.aliyun.fc.selenium.ChromeDemo::handleRequest
    cache is null!
    Starting ChromeDriver 2.35.528139 (47ead77cb35ad2a9a83248b292151462a66cd881) on port 20652
    Only local connections are allowed.
    Mar 05, 2019 11:34:27 AM org.openqa.selenium.remote.ProtocolHandshake createSession
    INFO: Detected dialect: OSS
    Page title is: 云端集成开发环境
    FC Invoke End RequestId: 68c83b4c-b053-479c-9b0e-9503582ccb56
    
    
    RequestId: 68c83b4c-b053-479c-9b0e-9503582ccb56          Billed Duration: 5265 ms        Memory Size: 1998 MB    Max Memory Used: 240 MB
    
    

    部署

    $ mvn package && fun deploy
    

    执行

    $  fcli function invoke -s chrome -f selenium
      Page title is: 云端集成开发环境
    

    关于文件尺寸

    由于 chromedriver 和 headless-chromium 压缩后体积已经非常接近 50MB,留给用户 Jar 的空间非常少,所以另外制作了一个高压缩比版本,使用压缩比更高的 brotli 算法进行压缩,压缩后的大小为 32.7MB。然后在运行时使用 initializer 进行解压,解压耗时大约为 3.7 S。https://github.com/vangie/packed-selenium-java-example

    参考阅读

    1. https://github.com/smithclay/lambdium
    2. https://medium.com/clog/running-selenium-and-headless-chrome-on-aws-lambda-fb350458e4df

    加入我们

    团队介绍

    阿里云函数服务是一个全新的,支持事件驱动编程模式的计算服务。 他帮助用户聚焦自身业务逻辑,以 Serverless的方式构建应用,快速的实现低成本,可扩展,高可用的系统,而无需考虑服务器等底层基础设施的管理。 用户能够快速的创建原型,同样的架构能随业务规模平滑伸缩。让计算变得更高效,更经济,更弹性,更可靠。无论小型创业公司,还是大型企业,都受益其中。我们的团队正在迅速扩张,求贤若渴。我们想寻找这样的队友:
    基本功扎实。既能阅读论文追踪业界趋势,又能快速编码解决实际问题。
    严谨的,系统化的思维能力。既能整体考虑业务机会,系统架构,运维成本等诸多因素,又能掌控设计/开发/测试/发布的完整流程,预判并控制风险。
    好奇心和使命感驱动。乐于探索未知领域,不仅是梦想家,也是践行者。
    坚韧、乐观、自信。能在压力和困难中看到机会,让工作充满乐趣!
    如果您对云计算充满热情,想要构建一个有影响力计算平台和生态体系,请加入我们,和我们一起实现梦想!

    职位描述

    构建新一代 Serverless 计算平台,包括:

    1. 设计和实现完整可扩展的前端系统,包括身份验证/权限管理,元数据管理,流量控制,计量计费,日志监控等等
    2. 设计和实现弹性可靠的后端系统,包括资源调度,负载均衡,容错处理等等
    3. 丰富易用的 SDK/Tools/CLI/控制台
    4. 用户需求驱动,追踪业界趋势,利用技术推动业务的成长

    职位要求

    1. 算法/数据结构/操作系统等基础知识扎实,优秀的逻辑思维能力。
    2. 至少掌握一门编程语言。例如 Java/Go/C/C#/C++。
    3. 有大规模、高可用分布式系统开发经验者优先。
    4. 有 Web/Mobile Backends/Microservice 开发经验者优先。
    5. 良好的沟通能力和团队合作精神,有一定的组织协调能力。
    6. 本科及以上学历
    7. 3 年以上工作经验,通过“阿里巴巴编码规范” 认证的同学优先录取,认证地址:https://edu.aliyun.com/certification/cldt02

    简历提交

    yixian.dw AT alibaba-inc.com

    阿里巴巴云原生技术圈关注微服务、Serverless、容器、Service Mesh 等技术领域、聚焦云原生流行技术趋势、云原生大规模的落地实践,做最懂云原生开发者的技术圈。”

  • 相关阅读:
    MySQL 常用到的几个字符处理函数
    MySQL DATE_SUB查询工龄大于35的员工信息
    Mysql 没有nvl()函数,却有一个类似功能的函数ifnull();
    switch 循环中的case理解
    批处理系统和分时系统各具有什么特点?为什么分时系统的响应比较快?
    存储式计算机的主要特点是什么?
    代码实现导航栏分割线
    Keras函数式API介绍
    Keras通过子类(subclass)自定义神经网络模型
    R语言kohonen包主要函数介绍
  • 原文地址:https://www.cnblogs.com/alisystemsoftware/p/12336913.html
Copyright © 2011-2022 走看看