【ArchSummit】如何通过AIOps推动可量化的业务价值增长和效率提升?>>> 了解详情
写点什么

微软推新一代事务性文件系统——TxF

  • 2007-07-05
  • 本文字数:1448 字

    阅读完需:约 5 分钟

MSDN 杂志 7 月刊中对新的文件系统作了介绍,作为 Windows 平台一项“革命性”的新技术特性,Vista 和将要发布的 Longhorn 中会支持并不断加强具有事务性的文件系统—— TxF

对于从事服务端开发的技术人员而言,使用事务,尤其是控制分布式操作的事务是个至关重要的能力,如果某个环节“拿捏”不当,将在系统运维过程中用数十倍甚至数百倍的精力来解决。之前文件系统一直被作为一个典型的非事务性对象使用,也就是当数据库、队列、WCF 等事务性对象在某种条件下回退的时候,中间操作过的文件系统也会保留痕迹;与之不同的是,TxF = NTFS + Tx,也就是文件系统也具有操作上的“All or Nothing”的事务性特征。在文章中,作者列举了这一文件系统的三个优势“提升应用稳定性”、“提升平台稳定性”和“增加创新机会”:

借助 TxF 可以有效减少应用在异常情况下的“扫尾”工作,应用的可靠性交给操作系统保证。 在不使用 TxF 的时候,如果事务本身有多层嵌套,而且调用环境又是分布式环境,那么每处涉及文件访问的位置都需要“设防”。需要回退的话,如何通知远端文件系统本身就很困难(限于各种访问控制策略),加之错误本身很多时候就是因为连通性原因导致;在 TxF 环境下,应用不需要关心事务的层次,也不需要关心连通性故障。

另外,使用 TxF 对于在线软件更新之类的应用特性也很有用,“半拉子”的情况最令人头疼,这种情况下应该考虑 TxF 的 All or Nothing 了。

但另外一个重要的地方是提供了一个“选项”——文件操作在异常处理时怎么办。实现方式上,TxF 依赖于操作系统中 KTM(Kernel Transaction Manager),而 KTM 可以与大家熟悉的 DTC 进行交互,相当于 TxF 可以间接地和任何支持 DTC 的技术进行事务协同。包括:

  • 所有主流商用数据库平台、支持 DTC 分布式事务的开源数据库平台。
  • 通过 WS-AtomicTransaction 协议保证的 Web Service 调用。
  • 声明为 OleTransactionProtocol 的 WCF。
  • 还有各主要商用队列产品。
  • 再外延的话,由于 DTC 本身对 XA-Transactions 有支持,所以 TxF 甚至可以把操作 Enlist 到异构操作系统平台的事务管理产品中。

虽然 TxF 为开发人员开辟了一个非常广阔的调用空间,但它只是个“选项”,非事务性的文件系统在很多应用情境下还是非常必要的,诸如:

  • “业务操作日志”,必须保证它不会随着业务操作的回退而被“擦”掉。
  • 还有就是长事务的情况,过多被打开而未关闭的文件将成为服务器的负载,尤其在宕机重启后,“扫尾”工作将成为系统的负担。
  • 另外就是文件系统本身不适合多 Writer 的情况,每次一个 TxF 文件仅允许一个 Writer 写入(除非其它 Writer 与之在同一个事务内)。
  • 还有就是各种“锁”的问题,尤其当 TxF 与其他事务性资源一起因为断电等原因恢复的时候,TxF 文件本身会被持续锁定,直到其他资源(例如:SQL Server)恢复之后才开始可以被释放,但如果外层宿主程序本身是个随操作系统启动的后台服务,状况就很容易恶化。

与 Longhorn 一起到来的应该会是 SOA 渐入主流的开发时代,XML 将成为消息方式的主流,届时 XML 数据库和文件系统均会被用来存储 XML 数据,保证报文的 I/O 与前端 Service 调用结果的事务性同步将会很重要。Txf 作为一项革新技术,如何在有效隔离事务边界的情况下,被妥善地使用将是一个很大的挑战。


作者简介:王翔,全国海关信息中心高级架构师,从事海关主要广域分布式系统的设计和实施,多次参与各业务系统的优化。此外,作为信息安全工作组副组长,他还一直致力于应用密码技术和公钥基础设施保障海关业务的安全运行。此外,他还是《程序员》杂志的专栏作者。

2007-07-05 23:271370
用户头像

发布了 61 篇内容, 共 96884 次阅读, 收获喜欢 0 次。

关注

评论

发布
暂无评论
发现更多内容

倒计时1天!计算巢软件免费试用中心发布,即刻报名!

阿里云弹性计算

计算巢 试用中心

NFT盲盒游戏商城交易系统开发技术

薇電13242772558

NFT 盲盒

不容错过!什么是领域驱动设计?为什么落地这么难?

京东科技开发者

前端 代码 领域驱动模型DDD 中台架构 研发提效

80%Java开发者面试都问的SpringBoot你竟不会?看完这些笔记足以

退休的汤姆

Java 面经 秋招 spring、

数字化转型别着急,先看看如何打通数据孤岛吧

雨果

数字化转型 打通数据孤岛

基于SpringBoot的SSMP整合

SpringBoot 2 Mybatis-Plus 8月月更

一个奇葩的线上问题,导致我排查了一天

艾小仙

Java elasticsearch 程序员 ELK

合合信息对于表格识别与内容提炼技术理解及研发趋势

合合技术团队

人工智能 表格识别 合合信息

获取IP地址的途径有哪些?要如何保护IP地址不被窃取?

郑州埃文科技

IP地址 追踪IP 保护IP

让“上链”触手可及:VoneBaaS 赋能传统应用场景

旺链科技

区块链 数字化转型 产业区块链

阿里架构师花近十年时间整理出来的Java核心知识pdf(Java岗)

退休的汤姆

Java 面经 校招 秋招 java·工程师

Http缓存原来如此,牛波牛波

知识浅谈

HTTP缓存 8月月更

如何学习一项新技术?

平凡人生

App Push 通用测试方案

转转技术团队

测试工具

图文详解:内存总是不够,我靠HBase说服了Leader为新项目保驾护航

浅羽技术

数据库 大数据 微服务 HBase 8月月更

iofod——WeUI基础组件解析

独来独往

前端 低代码 开发工具 weui iofod

java的可变参数

TimeFriends

8月月更

用两个栈实现队列

掘金安东尼

算法 前端 8月月更

Go-Excelize API源码阅读(二十)——SetDefinedName

Regan Yue

Go 开源 源码阅读 8月日更 8月月更

基于 gh-ost 的在线 Schema 变更

Bytebase

MySQL 数据库

讲座回顾丨基于 OpenYurt 和 EdgeX 的云边端协同新可能

阿里巴巴云原生

阿里云 云原生 边缘计算

《 合 成 大 西 瓜 》 重 制 版 !( 联 机 版 在 做 了 )

HullQin

CSS JavaScript html 前端 8月月更

数字馆藏电子商务平台开发:如何发展数字藏品?

开源直播系统源码

软件开发 区块链技术 NFT 数字藏品 数字藏品开发

{版本发布公告}HMS Core 6.6.0来啦

HMS Core

低成本、强交互、沉浸式的云游戏,究竟如何实现?

阿里云视频云

视频云 云游戏

讲真,这份秋招豪礼【面试锦囊】真舍不得给你们

浅羽技术

面试 面试题 秋招 8月月更 秋招你准备的怎样了

微服务全链路灰度新能力

阿里巴巴云原生

阿里云 微服务 云原生 灰度 全链路

云原生(二十五) | Kubernetes篇之Kubernetes(k8s)临时存储

Lansonli

云原生 k8s 8月月更

别小看 Log 日志,它难住了我们组的架构师

浅羽技术

日志 log4j slf4j logback 8月月更

前端的状态管理与时间旅行:San实践篇

百度Geek说

前端 JavaScrip

AIGC:自动化内容生成,AI的下一个引爆点?

晨山资本

AI 2D 3D模型 3D点云

微软推新一代事务性文件系统——TxF_.NET_王翔_InfoQ精选文章