当前位置: 首页 > news >正文

党校网站建设整改/深圳营销推广引流公司

党校网站建设整改,深圳营销推广引流公司,网络浏览器,wordpress首页urljepsen是一个分布式测试库,我们可以使用它对某个分布式系统执行一系列操作,并最终验证这些操作是否正确执行。jepsen已经成功验证了很多分布式系统,我们可以在它的源码里面看到相关系统的测试代码,包括mysql-cluster,z…

jepsen是一个分布式测试库,我们可以使用它对某个分布式系统执行一系列操作,并最终验证这些操作是否正确执行。

jepsen已经成功验证了很多分布式系统,我们可以在它的源码里面看到相关系统的测试代码,包括mysql-cluster,zookeeper,elasticsearch等。

为什么要研究jepsen,主要在于我们需要进行分布式数据库tidb的测试,自己写一套分布式测试框架难度比较大,并且还不能保证在分布式环境下面自身测试框架是不是对的,于是使用一个现成的,经过验证的测试框架就是现阶段最好的选择了,于是我们就发现了jepsen。

jepsen是使用clojure进行开发的,所以这也就是为什么我要学习clojure的原因,不过比较郁闷的是,学了几天,还是没有看懂太多的代码,只能慢慢不断摸索了。

Design

一个Jepsen的测试通过会在一个control node上面运行相关的clojure程序,control node会使用ssh登陆到相关的系统node(jepsen叫做db node)进行一些测试操作。

当我们的分布式系统启动起来之后,control node会启动很多进程,每一个进程都能使用特定的client访问到该分布式系统。一个generator为每一个进程生成一系列的操作,让其执行。每一个操作都会被记录到history里面。在执行操作的同时,另一个nemesis进程会尝试去破坏这个分布式系统,譬如使用iptable断开网络连接等。

最后,当所有操作执行完毕之后,jepsen会使用一个checker来分析验证history并且生成相关的报表。

从上面可以看出,jepsen的设计原理其实很简单,就是对分布式系统执行一系列操作,并且同时不停的破坏系统,最后通过验证操作的结果来检验整个分布式系统的健壮性。

Install

Jepsen的安装使用不是一件很容易的事情,因为它需要一个control node,五个db node来测试,幸运的是,我们有docker,现在docker支持了docker in docker技术,所以我们可以很方便的使用一个docker来运行五个docker。

Jepsen已经提供了相关的docker image,我们可以直接使用:

docker run --privileged -t -i tjake/jepsen

但有时候我们需要测试自己的case,所以需要提供volumn的支持,于是我稍微修改了一下,使用了一个定制的docker:

FROM tjake/jepsen

RUN mkdir /jepsen_dev

VOLUME /jepsen_dev

ADD ./bashrc /root/.bashrc

在启动的时候,我们可以将自己的test case mount到docker里面,便于使用,使用docker build构建:

docker build -t jepsen_dev .

Example test

构建好jepsen的docker环境之后,我们就可以编写简单地测试了,参考它的文档,我们建立一个meowdb的工程,使用jepsen 0.0.6版本,然后在meowdb_test.clj里面写上如下代码:

(ns jepsen.meowdb-test

(:require [clojure.test :refer :all]

[jepsen.core :refer [run!]]

[jepsen.meowdb :as meowdb]))

(def version

"What meowdb version should we test?"

"1.2.3")

(deftest basic-test

(is (:valid? (:results (run! (meowdb/basic-test version))))))

然后在meowdb.clj里面:

(ns jepsen.meowdb

"Tests for MeowDB"

(:require [clojure.tools.logging :refer :all]

[clojure.core.reducers :as r]

[clojure.java.io :as io]

[clojure.string :as str]

[clojure.pprint :refer [pprint]]

[knossos.op :as op]

[jepsen [client :as client]

[core :as jepsen]

[db :as db]

[tests :as tests]

[control :as c :refer [|]]

[checker :as checker]

[nemesis :as nemesis]

[generator :as gen]

[util :refer [timeout meh]]]

[jepsen.control.util :as cu]

[jepsen.control.net :as cn]

[jepsen.os.debian :as debian]))

(defn basic-test

"A simple test of MeowDB's safety."

[version]

tests/noop-test)

我们启动docker:

docker run --privileged -t -i -v meowdb:/jepsen_dev --name jepsen jepsen_dev

然后执行lein test,如果没有啥意外,我们会输出如下类似的结果:

INFO jepsen.store - Wrote /jepsen_dev/meowdb/store/noop/20151211T094940.000Z/history.txt

INFO jepsen.store - Wrote /jepsen_dev/meowdb/store/noop/20151211T094940.000Z/results.edn

INFO jepsen.core - Everything looks good! ヽ(‘ー`)ノ

{:valid? true,

:linearizable-prefix [],

:worlds ({:model {}, :fixed [], :pending #{}, :index 0})}

Ran 1 tests containing 1 assertions.

0 failures, 0 errors.

这里仅仅是对jepsen的一个简单介绍,后续我还需要仔细研究,争取早日能用到tidb上面。

http://www.lbrq.cn/news/1550791.html

相关文章:

  • 网站后台数据分析怎么做/班级优化大师使用心得
  • 贵德网站建设/搜索引擎提交入口大全
  • 网站的引导页怎么做的/青岛网站建设
  • 深圳哪里网站建设好/武汉seo霸屏
  • discuz培训网站模板下载/sem运营有出路吗
  • 外贸网站推广建设/关键词优化一年的收费标准
  • 怎样建个网站/软文广告有哪些
  • 长沙企业网站建设收费/网站发布与推广
  • 信宜网站建设公司/中国搜索引擎市场份额
  • app要有网站做基础/百度竞价托管一月多少钱
  • 做外贸的数据网站有哪些/本周国内新闻
  • 溧水区住房和城乡建设厅网站/滨州seo排名
  • 小程序网站建设/百度人气榜
  • 在云服务器上搭建网站/品牌营销策略
  • 偃师网站开发/做网站公司
  • 昆山教育云平台网站建设/seo广告优化多少钱
  • 专业的营销网站建设公司排名/市场营销网络
  • 创意营销策划案例/seo优化排名服务
  • 网站设计文案/焦作整站优化
  • 做网站找哪家又便宜又好/宁波网络推广平台
  • 免费上线个人网站/百度手机版
  • 沈阳网站建设公司哪个好/关键词优化资讯
  • 网站建设与网页制作盒子模型/semicircle
  • 开发商虚假宣传可以退房吗/淘宝关键词优化
  • 用lls建设一个网站/百度投诉中心24人工
  • 网站开发论文主要内容/深圳短视频seo教程
  • 汕头建站价格/网站关键词排名优化电话
  • 做动态网站需要多少钱/网站收录是什么意思
  • 网站建设需要域名/百度官方网站网址
  • 网站建设 话术/高级搜索
  • Swift 实战:判断点集是否关于某条直线对称(LeetCode 356)
  • 当使用STL容器去存放数据时,是存放对象合适,还是存放对象指针(对象地址)合适?
  • 普通用户使用docker命令
  • C++算法竞赛:位运算
  • 向量数据库基础和实践 (Faiss)
  • RAC环境redo在各节点本地导致数据库故障恢复---惜分飞