Azure WebApp Service 是非常适合中小型项目的云服务。 从我实际使用的感受来看, 有如下几个优点:

1 部署方便, 可以从VS一键发布

2 缩放方便, scale in / scale out 几秒迅速实现

3 调试方便, 测试环境可以远程debug;还可以实时从VS上观测log

4 开发方便, 几乎没有额外的学习成本

另外, 通过VSTS, 还很好的集成了Devops的CICD; 通过slot做stage, 做A/B test。非常实用。

但是今天, 我想分享的是WebApp Service的Web job。 关于Web job的介绍, 请参考MSDN文章

WebJob 两种运行方式: 持续运行/按需运行。

持续运行, 一旦开始后, 就不会退出。 比较适合消息监控模式。 比如一直监控一个消息队列, 当队列中收到消息的时候, 后台任务便开始处理。处理完继续等待新的消息到来。建议使用Azure WebJob SDK开发, 对于使用Azure队列/存储有非常友好的、简单易学的开发框架。

按需运行,一种是手动去触发它,比如做一些数据的初始化工作,只需要在部署完成做一次即可;

另一种是用定时器去触发它。 现在在WebJob部署的时候, 很好的集成了CRON语法的调度设置, 比如 * */20 * * * *, 表示每20分钟执行一次。 如果是从VS部署web job的话, 可以在web job的根路径下放一个settings.job文件, 内容格式如下

1 {
2 /* execute at 3:00 amp everyday morning */
3 "schedule": "0 0 3 * * *"
4 }

这样在部署的时候(选上“按需运行”), 就可以按预定的调度执行了。 在这种情况下, 可以考虑不需要WebJob SDK。

关于部署,除了在Portal上操作之外,在VS中,WebJob项目即可以单独部署——跟WebSite部署一样导入PublishSetting文件,也可以随着指定WebSite一起部署(推荐)。 需要在VS中操作: 1 右键web项目, Add->; 2 选择 Existing Project as Azure Web Job ; 3 选择WebJob项目和运行方式。

在WebSite项目中, 会多出一个文件 webjobs-list.json, 其中描述了有哪些web job

{
"$schema": "http://schemastore.org/schemas/json/webjobs-list.json",
"WebJobs": [
{
"filePath": "../myjob/myjob.csproj"
}
}

在相关的Web job 下 , 会出现文件webjob-publish-settings.json, 其中描述了Web job的名称和运行方式;并且项目会依赖nuget package: Microsoft.Web.WebJobs.Publish

1 {
2 "$schema": "http://schemastore.org/schemas/json/webjob-publish-settings.json",
3 "webJobName": "myjob",
4 "runMode": "Continuous"
5 }

再加上前面提到的settings.job文件, 那么部署的三要素:部署到哪/如何运行/如何调度,就都齐了

关于WebJob的实例缩放,默认的WebJob会随着WebSite实例一起缩放, 也就是说, 有几个WebSite instance, 就会有多少个WebJob instance。 所以,我们在设计Web Job的时候, 要考虑到多实例同时运行这个特点。使用消息队列(Azure Storage Queue)就是一个很好的方式。 或者我们也可以让Web Job无论如何都只有一个实例——对于使用Web Job SDK的,  请参考Microsoft.Azure.WebJobs.SingletonAttribute; 对于普通的exe/cmd 等webjob, 可以在settings.job中添加

1 {
2 ......,
3 "is_singleton": true
4 }

结尾语:

本文分享了使用Web job的两种运行模式, Web Job的部署方式和Web Job实例缩放需要注意的问题。

Web Job 本质上会和Website 共享相同的计算资源。 所以在使用的时候还是需要注意。 如果Web Job特别的耗费计算资源, 为了不影响业务系统Website的运行, 建议不要放在一个Host Plan中。

使用Azure WebJob的一点心得的更多相关文章

  1. WebBrowser一点心得,如果在Javascript和Winform代码之间实现双向通信

    原文:WebBrowser一点心得,如果在Javascript和Winform代码之间实现双向通信 最近工作需要,学习了一下winform内嵌webbrowser控件,然后与htm页面中的javasc ...

  2. 使用Webbrowser的一点心得体会

    原文:使用Webbrowser的一点心得体会 自从用上VS2005后,发现多了个WebBrowser控件(.net 2003中不带),为图方便吧,有好多小工具就用这个写的,慢慢也有点体会了,总结一下, ...

  3. 谈谈选用技术的原则,技术学习方法技巧,阅读代码的技巧及其它 MSF的一点心得

    谈谈技术原则,技术学习方法,代码阅读及其它(正文) 这篇文章是前一阵在水木BBS上和别人讨论中偶自己发言的摘编,是偶这几年开发过程完全经验式的总结.完全个人经验,供批判. 一.选用技术的原则 比较规范 ...

  4. 【并行计算与CUDA开发】基于NVIDIA显卡的硬编解码的一点心得 (完结)

    原文:基于NVIDIA显卡的硬编解码的一点心得 (完结) 1.硬解码软编码方法:大体流程,先用ffmpeg来读取视频文件的包,接着开启两个线程,一个用于硬解码,一个用于软编码,然后将读取的包传给解码器 ...

  5. 关于使用Exception的一点心得

    毫无疑问,Exception有很多优点.查看任何一本面向对象的书籍,都会提到异常相对于返回值标记状态的不足以及避免错误导致程序崩溃的问题.看起来是很好的,用起来也是很好的.可是这么多年过去了,异常用的 ...

  6. SVM一点心得体会

    支持向量机的学习说是刚刚开始,又不合理,只能说隔了很长的时间再看,终于在分类这块的层面上有了新的认识. 总的来说,支持向量机分为线性支持向量机和非线性支持向量机,线性支持向量机又可以分为硬间隔最大化线 ...

  7. 记录自己对EventLoop和性能问题处理的一点心得

    1.EventLoop 这里说的EventLoop不是指某一个具体的库或是框架,而是指一种程序实现结构.这种结构多是基于IO多路转接的API(select.poll.epoll之类)以reactor模 ...

  8. 从Eclipse转移到IntelliJ IDEA一点心得

    http://www.ituring.com.cn/article/37792 本人使用IntelliJ IDEA其实并不太久,用了这段时间以后,觉得的确很是好用.刚刚从Eclipse转过来的很多人开 ...

  9. Android平板上开发应用的一点心得——精确适配不同的dpi和屏幕尺寸

    一.引言 Android的开源使厂商无需自行研发OS,大大降低了研发.生产的成本,使得Android平板品牌如雨后春笋般爆发,山寨机厂商们似乎又找到了一丝希望.与此同时带来的是广大开发者的苦不堪言,各 ...

随机推荐

  1. Spring Cloud Alibaba(10)---Sentinel控制台搭建+整合SpringCloudAlibaba

    上一篇博客讲了Sentinel一些概念性的东西 Spring Cloud Alibaba(9)---Sentinel概述 这篇博客主要讲 Sentinel控制台搭建,和 整合SpringCloudAl ...

  2. [基本运算符、流程控制之if判断、与用户交互、深浅拷贝]

    [基本运算符.流程控制之if判断.与用户交互] 基本运算符 1.算数运算符 python支持的算术运算符与数学上计算的符号使用是一致的 salary = 3.3 res = salary * 12 p ...

  3. 原生JS和jQuery创建元素的方法

    jQ创建元素的方法 1.原生代码 .creatElement('tr')` .innerHTML = '<h1>加油</h1>' document.write('<h1& ...

  4. CPU缓存是位于CPU与内存之间的临时数据交换器,它的容量比内存小的多但是交换速度却比内存要快得多。CPU缓存一般直接跟CPU芯片集成或位于主板总线互连的独立芯片上

    一.什么是CPU缓存 1. CPU缓存的来历 众所周知,CPU是计算机的大脑,它负责执行程序的指令,而内存负责存数据, 包括程序自身的数据.在很多年前,CPU的频率与内存总线的频率在同一层面上.内存的 ...

  5. Rust 多态

    Rust 多态 分发 多态的上下文中的方法解析过程被称为分发,调用该方法称为分发化,在支持多态的主流语言中,分发可以通过以下任意一种方式进行. 静态分发 当在编译期决定要调用的方法时,它被称为静态分发 ...

  6. Bash shell的特性

    bash的特性 命令补全 Tab键 ​ 命令补全 ​ 路径补全 ​ 选项补全 ​ yum install -y bash-completion ​ -长格式 ​ --all ​ -短格式 ​ -a 快 ...

  7. Python应用与实践-转自(吴秦(Tyler))

    1.      Python是什么? 1.1.      Python语言 1.2.      Python哲学 2.      Python在工作中的应用 2.1.      实例1:文件批量处理 ...

  8. power delivery功率输出

    delivery

  9. 使用nuget包下载Entity Framework6.0无法使用模型类与数据库上下文自动生成controller与view

    解决方法:卸载掉原有的6.0版本EF,从控制台安装5.0版本的. >工具>库程序包管理器>程序包管理器控制台.在PM>后面输入安装命令. 命令如下 Install-Packag ...

  10. 【无人机航空摄影测量精品教程】目录:摄影测量、Pix4d、EPS、CC、PhotoScan项目化作业流程及注意事项汇总

    目录 1. 专栏简介 2. 专栏地址 3. 专栏目录 1. 专栏简介 该专栏为目前最为热门的无人机航测内外业项目,主要内容包括:无人机航测外业作业流程(像控点布设.航线规划.仿地飞行.航拍)和内业数据 ...