使用Azure WebJob的一点心得
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的一点心得的更多相关文章
- WebBrowser一点心得,如果在Javascript和Winform代码之间实现双向通信
原文:WebBrowser一点心得,如果在Javascript和Winform代码之间实现双向通信 最近工作需要,学习了一下winform内嵌webbrowser控件,然后与htm页面中的javasc ...
- 使用Webbrowser的一点心得体会
原文:使用Webbrowser的一点心得体会 自从用上VS2005后,发现多了个WebBrowser控件(.net 2003中不带),为图方便吧,有好多小工具就用这个写的,慢慢也有点体会了,总结一下, ...
- 谈谈选用技术的原则,技术学习方法技巧,阅读代码的技巧及其它 MSF的一点心得
谈谈技术原则,技术学习方法,代码阅读及其它(正文) 这篇文章是前一阵在水木BBS上和别人讨论中偶自己发言的摘编,是偶这几年开发过程完全经验式的总结.完全个人经验,供批判. 一.选用技术的原则 比较规范 ...
- 【并行计算与CUDA开发】基于NVIDIA显卡的硬编解码的一点心得 (完结)
原文:基于NVIDIA显卡的硬编解码的一点心得 (完结) 1.硬解码软编码方法:大体流程,先用ffmpeg来读取视频文件的包,接着开启两个线程,一个用于硬解码,一个用于软编码,然后将读取的包传给解码器 ...
- 关于使用Exception的一点心得
毫无疑问,Exception有很多优点.查看任何一本面向对象的书籍,都会提到异常相对于返回值标记状态的不足以及避免错误导致程序崩溃的问题.看起来是很好的,用起来也是很好的.可是这么多年过去了,异常用的 ...
- SVM一点心得体会
支持向量机的学习说是刚刚开始,又不合理,只能说隔了很长的时间再看,终于在分类这块的层面上有了新的认识. 总的来说,支持向量机分为线性支持向量机和非线性支持向量机,线性支持向量机又可以分为硬间隔最大化线 ...
- 记录自己对EventLoop和性能问题处理的一点心得
1.EventLoop 这里说的EventLoop不是指某一个具体的库或是框架,而是指一种程序实现结构.这种结构多是基于IO多路转接的API(select.poll.epoll之类)以reactor模 ...
- 从Eclipse转移到IntelliJ IDEA一点心得
http://www.ituring.com.cn/article/37792 本人使用IntelliJ IDEA其实并不太久,用了这段时间以后,觉得的确很是好用.刚刚从Eclipse转过来的很多人开 ...
- Android平板上开发应用的一点心得——精确适配不同的dpi和屏幕尺寸
一.引言 Android的开源使厂商无需自行研发OS,大大降低了研发.生产的成本,使得Android平板品牌如雨后春笋般爆发,山寨机厂商们似乎又找到了一丝希望.与此同时带来的是广大开发者的苦不堪言,各 ...
随机推荐
- Java容器 | 基于源码分析List集合体系
一.容器之List集合 List集合体系应该是日常开发中最常用的API,而且通常是作为面试压轴问题(JVM.集合.并发),集合这块代码的整体设计也是融合很多编程思想,对于程序员来说具有很高的参考和借鉴 ...
- 『居善地』接口测试 — 3、Requests库介绍
目录 1.Requests库 2.Requests库文档 3.Requests库安装 4.Requests库的使用 (1)使用步骤 (2)示例练习 5.补充:Json数据和Python对象互相转化 1 ...
- ACM基础板子
新生赛以后就正式成为一名acmer啦 ~虽然没有打过比赛呜呜呜 要好好学算法,拿一个牌牌嘛~ 这里就记录算法学习情况,也怕自己偷懒,学一个就记录,看看长时间拖更就是在摸鱼,摸鱼和鸽子都是本质 ,加油! ...
- Django(32)自定义过滤器
前言 虽然DTL给我们内置了许多好用的过滤器.但是有些时候还是不能满足我们的需求.因此Django给我们提供了一个接口,可以让我们自定义过滤器,实现自己的需求. 自定义过滤器 首先在某个app中,创建 ...
- 使用U盘软碟通安装原版Windows10
https://zhuanlan.zhihu.com/p/171534675 使用U盘软碟通安装原版Windows10 一.准备:8G U盘一个,电脑装好UltraISO这个软件下载地址 二.Wind ...
- ipmitool使用手册(20200401)
ipmitool使用手册原创xinqidian_xiao 最后发布于2018-07-05 12:15:47 阅读数 17579 收藏展开一.查找安装包 查看ipmitool属于哪个安装包 #yum p ...
- 002.Python数据类型
一 python语言注释 就是对代码的解释, 方便大家阅读代码用的 1.1 注释的分类 (1)单行注释 # print 在python2.x print "1" # print 在 ...
- Swift系列九 - 属性
任何一门语言都有属性的概念.Swift中的属性是怎么的呢? 一.属性 Swift中跟实例相关的属性可以分为2大类:存储属性和计算属性. 1.1. 存储属性(Stored Property) 特点: 类 ...
- 统信UOS - 扩展系统盘
一.开root权限,开终端 二.执行lsblk指令,查看磁盘情况 可以发现 / 路径 对应的是loop0,查阅可知loop设备就是一个文件,挂载为一个路径操作的,这就尴尬了,好好的分区不用,你干嘛这么 ...
- 性能调优必备:NIO的优化实现原理
前言 我们就从底层的网络 I/O 模型优化出发,再到内存拷贝优化和线程模型优化,深入分析下 Tomcat.Netty 等通信框架是如何通过优化 I/O 来提高系统性能的. 网络 I/O 模型优化 网络 ...