zoukankan      html  css  js  c++  java
  • Cassandra集群配置

    版本:apache-cassandra-1.0.6

    机器1:10.16.233.27
    机器2:10.16.233.41
    机器3:10.16.233.45
    机器4:10.16.233.36
    机器5:10.16.233.39
    机器6:10.16.233.66

    机器1和机器2作为seed_provider
    java jdk已经安装并且设置过JAVA_HOME
    ssh已经设置
    1.解压 apache-cassandra-1.0.6-bin.tar.gz 到/usr/cassandra 目录
    设置CASSANDRA_HOME,打开profile文件
    命令:vim /etc/profile
    设置如下:
        JAVA_HOME=/usr/java/jdk1.6.0_30
        CASSANDRA_HOME=/usr/cassandra
        CLASSPATH=.:$JAVA_HOME/lib:$CASSANDRA_HOME/lib
        PATH=$PATH:$JAVA_HOME/bin:$JAVA_HOME/jre/bin:$CASSANDRA_HOME/bin

        export JAVA_HOME
        export CASSANDRA_HOME
        export PATH
        export CLASSPATH

    2.按需要修改6台机器的conf/cassandra.yaml文件

    修改conf/cassandra.yaml
    2.1设置cluster_name 这里我们命名为E3E4
        # The name of the cluster. This is mainly used to prevent machines in
        # one logical cluster from joining another.
        cluster_name: 'E3E4'

    2.2设置数据文件 提交日志 缓存文件 路径
        # directories where Cassandra should store data on disk.
        data_file_directories:
            - /usr/cassandra/data
        # commit log
        commitlog_directory: /usr/cassandra/commitlog
        # saved caches
        saved_caches_directory: /usr/cassandra/saved_caches

    2.3设置endpoint_snitch
        # endpoint_snitch -- Set this to a class that implements
        # IEndpointSnitch, which will let Cassandra know enough
        # org.apache.cassandra.locator.PropertyFileSnitch:
        #  - Proximity is determined by rack and data center, which are
        #    explicitly configured in cassandra-topology.properties.
        endpoint_snitch: org.apache.cassandra.locator.PropertyFileSnitch

    2.4设置init_token,注:这里要通过算法程序来计算
    算法代码如下:
        #! /usr/bin/python
        import sys
        if(len(sys.argv)>1):
            num=int(sys.argv[1])
        else:
            num=int(raw_input(""))
        for i in range(0,num):
            print 'token %d:%d'%(i,(i*(2**127)/num))
    计算结果(6台机器):
        token 0:0
        token 1:28356863910078205288614550619314017621
        token 2:56713727820156410577229101238628035242
        token 3:85070591730234615865843651857942052864
        token 4:113427455640312821154458202477256070485
        token 5:141784319550391026443072753096570088106
    算好后,依据输出设置initial_token,PS initial_token冒号后有个空格。
        # If blank, Cassandra will request a token bisecting the range of
        # the heaviest-loaded existing node.  If there is no load information
        # available, such as is the case with a new cluster, it will pick
        # a random token, which will lead to hot spots.
        initial_token: 85070591730234615865843651857942052864

    2.5设置seed_provider
        seed_provider:
            # Addresses of hosts that are deemed contact points.
            # Cassandra nodes use this list of hosts to find each other and learn
            # the topology of the ring.  You must change this if you are running
            # multiple nodes!
            - class_name: org.apache.cassandra.locator.SimpleSeedProvider
              parameters:
              # seeds is actually a comma-delimited list of addresses.
              # Ex: "<ip1>,<ip2>,<ip3>"
              - seeds: "10.16.233.41,10.16.233.27"


    2.6 设置listen_address rpc_address为本机IP,这里机器3,机器4的设置如下
          机器3:
          listen_address: 10.16.233.36
          rpc_address: 10.16.233.36
          机器4:
          listen_address: 10.16.233.39
          rpc_address: 10.16.233.39

    2.7修改6台机器:conf/cassandra-topology.properties
        # Cassandra Node IP=Data Center:Rack
        10.16.233.41=DC1:RAC1
        10.16.233.27=DC2:RAC1
        10.16.233.45=DC1:RAC1
        10.16.233.39=DC2:RAC1
        10.16.233.36=DC1:RAC2
        10.16.233.66=DC2:RAC2
        # default for unknown nodes
        default=DC1:RAC1

    2.8 修改conf/log4j-server.properties 设置日志目录:/usr/cassandra/log/system.log
        # rolling log file
        log4j.appender.R=org.apache.log4j.RollingFileAppender
        log4j.appender.R.maxFileSize=20MB
        log4j.appender.R.maxBackupIndex=50
        log4j.appender.R.layout=org.apache.log4j.PatternLayout
        log4j.appender.R.layout.ConversionPattern=%5p [%t] %d{ISO8601} %F (line %L) %m%n
        # Edit the next line to point to your logs directory
        log4j.appender.R.File=/usr/cassandra/log/system.log

    3设置hosts
    [root@tt bin]# vim /etc/hosts
    内容如下:
    127.0.0.1       localhost.localdomain   localhost
    ::1             localhost6.localdomain6 localhost6
    10.16.233.41 tt.cassandra.xa.01
    10.16.233.27 tt.cassandra.xa.02
    10.16.233.45 tt.cassandra.xa.03
    10.16.233.39 tt.cassandra.xa.04
    10.16.233.36 tt.cassandra.xa.05
    10.16.233.66 tt.cassandra.xa.06

    4设置network
    [root@tt bin]# vim /etc/sysconfig/network
    内容如下:
    NETWORKING=yes
    HOSTNAME=tt.cassandra.xa.04

    5 清空数据并且重启机器
    rm -rf /usr/cassandra/data/*
    rm -rf /usr/cassandra/saved_caches/*
    rm -rf /usr/cassandra/commitlog/*
    rm -rf /usr/cassandra/log/*
    6一定要记住关闭防火墙
    [root@tt bin]# iptables -F:关闭防火

    启动Cassandra 并查看:
    #在cassandra的bin目录,10.16.233.39是本机IP
    [root@tt bin]# ./nodetool -h 10.16.233.39 ring
  • 相关阅读:
    数据库小记:根据指定名称查询数据库表名及根据指定名称查询数据库所有表中的字段名称(支持mysql/postgre)
    Java实现 LeetCode第30场双周赛 (题号5177,5445,5446,5447)
    Java实现第十一届蓝桥杯C/C++ 大学 B 组大赛软件类 省赛真题(希望能和各位大佬能一起讨论算法题:讨论群:99979568)
    Java实现第十一届蓝桥杯 省赛真题(希望能和各位大佬能一起讨论算法题:讨论群:99979568)
    Java引用类型之软引用(2)
    Java引用类型之软引用(1)
    Java引用类型
    对象的创建
    类的初始化
    初始化itable
  • 原文地址:https://www.cnblogs.com/jeriffe/p/2299382.html
Copyright © 2011-2022 走看看