2

我正在尝试在 Windows 机器上设置两个节点 Cassandra 集群。我基本上有两台 Windows 机器,我正在关注这个 datastax教程

每当我使用以下命令从上述教程中获取令牌编号时 -

python -c "num=2; print ""\n"".join([(""token %d: %d"" %(i,(i*(2**127)/num))) for i in range(0,num)])"

我总是收到这个错误 -

C:\Users\username>python -c "num=2; print ""\n"".join([(""token %d: %d"" %(i,(i*(2**127)/num))) for i
in range(0,num)])"
  File "<string>", line 1
    num=2; print "\n".join([("token %d: %d" %(i,(i*(2**127)/num))) for i in range(0,num)])
                    ^
SyntaxError: invalid syntax
4

1 回答 1

1

将该命令放入实际的 Python 脚本中可能会更好。这是我使用的类似 Python 脚本(另存为 newCluster.py):

import sys

if (len(sys.argv) > 1):
        num=int(sys.argv[1])
else:
        num=int(raw_input("How many nodes are in your cluster? "))
for i in range(0, num):
        print 'node %d: %d' % (i, (i*(2**127)/num))

当我为两个节点运行它时,我得到:

How many nodes are in your cluster? 2
node 0: 0
node 1: 85070591730234615865843651857942052864

这正是我编辑和运行它的方式:

在此处输入图像描述

您使用的是哪个版本的 Python?我已经在 2.6.7 和 2.7.3 中测试过这个脚本。

同样要保持平衡,两个节点集群的 initial_token 值只需相差 85,070,591,730,234,615,865,843,651,857,942,052,864。它们不一定必须是 0 和 85070591730234615865843651857942052864;尽管这两个值应该可以正常工作。

于 2013-11-01T07:33:52.153 回答