限时领|《AI 百问百答》专栏课+实体书(包邮)! 了解详情
写点什么

RethinkDB 已经将其数据库移植到 Windows

  • 2016-02-14
  • 本文字数:1054 字

    阅读完需:约 3 分钟

RethinkDB 已经推出了其数据库的 Windows 版本。该版本耗时一年开发,可以运行在 64 位 Windows 操作系统上,目前尚处于 Beta 测试阶段。

考虑到此次移植所付出的巨大的时间成本,我们采访了 RethinkDB 联合创始人 Michael Glukhovsky,了解更多关于其数据库 Windows 版本的细节。

InfoQ:将 RethinkDB 移植到 Windows,最困难的部分有哪些?

MG:RethinkDB 的异步 I/O 操作依赖特定于平台的 API。Windows 上的相关 API 同 Linux 的 epoll 和 OS X 的 kqueue 有很大的不同。在 Linux 上,开发人员使用 epoll 获取通知,让他们知道一个描述符已经读或写就绪。在 Windows 上,开发人员使用 I/O 完成端口(IOCP),这需要将异步操作进行排队,并在操作成功或失败时发送通知。改写构建系统是另一个主要的难点。我们必须在 Windows 上统一编译所有第三方开源依赖。

InfoQ:RethinkDB 有一个跨不同操作系统的公用代码库吗?

MG:是的,RethinkDB 有一个统一的跨平台代码库。不过,有些特定于平台的代码路径依赖于本地平台的 API。在我们的 GitHub 库中,有一个arch目录,其中包含了所有特定于平台的代码。据我们估计,RethinkDB 有 3% 到 4% 的源代码是特定于某个操作系统的。

InfoQ:Windows 版本的功能同 Linux 和 OS X 版本一样吗?

MG:RethinkDB on Windows 在功能上与 Linux 和 OS X 版本相同。该数据库的特性在所有三个平台上都是一致的。不过,我们仍然在优化 Windows 版本,以便它达到同样的性能。

InfoQ:您能给我们大体介绍下路线图上有哪些特性吗?

MG:对于新的 Windows 移植,我们正努力让开发人员可以将数据库作为一个 Windows 服务运行。更广泛地讲,我们正在实现一些安全特性,如支持数据库用户账户和权限。此外,我们还在扩展数据库的实时处理能力,让开发人员可以在更多的操作中使用 changefeeds。

RethinkDB 是一个开源、分布式、可扩展的数据库,可以配置用于实时向应用程序推送数据变化通知,而不是让应用程序不断地轮询数据库变化。 InfoQ 过去曾经介绍过 RethinkDB

Kyle Kingsbury Jepsen 系列文章的作者,他最近对 RethinkDB 进行了测试,以核实它在使用majority读 & 写时是否支持线性操作。Kingsbury 总结道:

据我所知,RethinkDB 的安全声明是准确的。如果写操作的一致性水平低于majority,那么可能会丢失更新,并在使用singleoutdated读时遇到各种读异常,但是majority/majority似乎是线性的。

关于这一点,我们建议读者阅读 Kingsbury 详细介绍有关测试执行和测试结果的博文来了解更多信息。

查看英文原文: RethinkDB Has Ported Their Database to Windows

2016-02-14 18:002036
用户头像

发布了 1008 篇内容, 共 424.2 次阅读, 收获喜欢 346 次。

关注

评论

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

编程的未来 Java, C, Go, Swift, Dart? Uncle Bob Martin - The Future of Programming

John(易筋)

Java 敏捷开发 编程的未来 编程简史 Bob大叔

架构师训练营第一次课程感想小记1

tuuezzy

软件工程 求职 架构师 UML

Assignment 01

高冰洁

食堂就餐卡系统设计

ARTS打卡第二周6.1-6.7

我笔盒呢

第一周作业一:食堂就餐卡系统设计

DZ

徒手撸框架--实现IoC

犀利豆

Java spring

Apache Spark有哪些局限性

奈学教育

Apache Spark

ERC20 Short Address Attack

程序那些事

区块链 以太坊 Token ERC20 代币

架构师训练营第二周

Melo

「编程模型」C++封装资源

顿晓

c++ 封装 资源封装 自动化管理 简化代码

架构师训练营第一周学习总结

全力以赴@

Java15都快出来了,你还不会Java8中的Lambda?

Java全栈封神

Java Lambda java8

Apache Spark有哪些局限性

古月木易

spark

【JS】给console来的样式

德育处主任

Java html5 大前端 Web console

五分钟学会Elasticsearch查询代理设计

古月木易

五分钟学会Elasticsearch查询代理设计

奈学教育

elasticsearch ES

终于有一个 Java 可以用的微信机器人了

犀利豆

Java

徒手撸框架--实现Aop

犀利豆

Java spring

【总结】优秀架构师的职责及综合能力

大家都知道递归,尾递归呢?什么又是尾递归优化?

程序猿石头

面向对象五大基本原则

彭阿三

面向对象设计 面向对象五个基本原则 基本原则

浅谈互联网思维和区块链思维

CECBC

区块链思维

小师妹学JavaIO之:MappedByteBuffer多大的文件我都装得下

程序那些事

Java io nio 小师妹 buffer

读懂才会用:Redis ZSet 的几种使用场景

小眼睛聊技术

Java redis 学习 架构 后端

SignalR Core之Hubs基本概念

猫定谔的靴

.net core SignalR realtime Hubs

Solidity的Bytecode和Opcode简介

程序那些事

区块链 智能合约 以太坊 Ethereum eth

平常心平常心

zhoo299

随笔杂谈

IP 基础知识全家桶,45 张图一套带走

小林coding

计算机网络 计算机基础 IP

iPad配置OpenVPN客户端

wong

ipad OpenVPN

回忆杀:我的编程能力是如何突飞猛进起来的

程序员小跃

Java android 编程 面向对象思想

RethinkDB已经将其数据库移植到Windows_数据库_Abel Avram_InfoQ精选文章