Cassandra -- Cassandra 3.0版本安装
============================================================
服务器信息
搭建三节点的Cassandra群集:
SERVER1: 192.168.199.171
SERVER2: 192.168.199.172
SERVER3: 192.168.199.172
============================================================
下载依赖包
cassandra下载地址:https://cassandra.apache.org/download/
JDK 1.8.0_201下载地址:https://download.oracle.com/otn-pub/java/jdk/8u201-b09/42970487e3af4f5aa5bca3f542482c60/jdk-8u201-linux-x64.tar.gz
Python 2.7.13下载地址:https://www.python.org/downloads/release/python-2713/
============================================================
配设JAVA环境
下载java安装包,解压到/usr/java18目录,然后在/etc/profile文件中追加下面代码:
#set java environment
JAVA_HOME=/usr/java18
JRE_HOME=/usr/java18/jre
CLASS_PATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JRE_HOME/lib
PATH=$PATH:$JAVA_HOME/bin:$JRE_HOME/bin
export JAVA_HOME JRE_HOME CLASS_PATH PATH
使用下面命令刷新环境变量:
## 刷新环境配置
source /etc/profile
检查JAVA是否安装正确:
## 查看java版本
java -version ## 查看java路径
echo $JAVA_HOME
============================================================
安装Cassandra
## 创建安装目录
mkdir -p /export/servers/cassandra/ /export/data/cassandra/ ## 创建用户组和用户
groupadd cassandra
useradd cassandra -g cassandra ## 将cassandra安装包解压到/export/servers/cassandra/ ## 修改文件目录权限
chown -R cassandra:cassandra /export/servers/cassandra/ /export/data/cassandra/
============================================================
配置Cassandra
修改/export/servers/cassandra/conf/cassandra.yaml文件的下面属性
## 群集名称
cluster_name: 'cluster1'
## 数据验证
authenticator: PasswordAuthenticator
authorizer: CassandraAuthorizer
## 数据目录
data_file_directories:
- /export/data/cassandra/data ## commitlog目录
commitlog_directory: /export/data/cassandra/commitlog ## saved_caches目录
saved_caches_directory: /export/data/cassandra/saved_caches ## 设置为第一个启动的节点地址
## 种子节点不做引导,它负责处理现有集群中新加入的节点。对于新的集群,引导处理会跳过种子节点。
seeds: "192.168.199.171" ## 将监听地址设置为本地IP
listen_address: 192.168.199.171 ## 将RPC地址设置为本地IP
rpc_address: 192.168.199.171 ## 程序访问端口,默认9042
native_transport_port: 9042 ## endpoint_snitch属性
endpoint_snitch: GossipingPropertyFileSnitch
endpoint_snitch参数选项:
GossipingPropertyFileSnitch
这应该是你的生产使用的。本地节点的机架和数据中心在cassandra-rackdc.properties中定义,并通过gossip传播到其他节点。如果存在cassandra-topology.properties,它将用作回退,从而允许从PropertyFileSnitch进行迁移。 SimpleSnitch
将战略顺序视为接近度。这可以在禁用读修复时提高缓存位置。仅适用于单数据中心部署。 PropertyFileSnitch
接近性由机架和数据中心决定,这些在cassandra-topology.properties中显式配置。 Ec2Snitch
从EC2 API加载当前区域和可用区域信息。当前区域被视为数据中心,可用区域被视为机架。仅使用私有IP,因此这不会在多个区域工作。 Ec2MultiRegionSnitch
使用公共IP作为broadcast_address以允许跨区域连接(因此,您应该将seed地址设置为公共IP)。您将需要打开公共IP防火墙上的storage_port或ssl_storage_port(对于区域内流量,Cassandra将在建立连接后切换到专用IP)。 RackInferringSnitch
接近性由机架和数据中心确定,假定它们分别对应于每个节点的IP地址的第3和第2个八位字节。除非这种情况符合您的部署约定,否则这最好用作编写自定义Snitch类的示例
修改/export/servers/cassandra/conf/cassandra-topology.properties文件内容:
## 设置服务器所在机架
192.168.199.171=DC1:RAC1
192.168.199.172=DC1:RAC1
192.168.199.173=DC1:RAC1 ## 下面为默认
# default for unknown nodes
default=DC1:r1 # Native IPv6 is supported, however you must escape the colon in the IPv6 Address
# Also be sure to comment out JVM_OPTS="$JVM_OPTS -Djava.net.preferIPv4Stack=true"
# in cassandra-env.sh
fe80\:0\:0\:0\:202\:b3ff\:fe1e\:8329=DC1:RAC3
============================================================
启动服务
以此在171/172/173上启动服务
## 切换到cassandra用户
su cassandra ## 启动服务
/export/servers/cassandra/bin/cassandra >/export/data/cassandra/start_server.log
============================================================
检查群集
## 查看群集节点状态
/export/servers/cassandra/bin/nodetool status ## 登录群集171节点
## cqlsh.py仅支持python2.7版本
python27 /export/servers/cassandra/bin/cqlsh.py 192.168.199.171 ## 查看命名空间
describe keyspaces; ## 查看群集版本
select release_version from System.local;
============================================================
替换群集节点
假设群集运行一段时间后,服务器192.169.199.172因为硬件故障导致数据丢失,修复后仍使用该IP加入群集,操作如下:
## 删除原服务器上数据
/bin/rm -rf /export/data/cassandra/* ## 切换到cassandra用户
su cassandra ## 使用cassandra.replace_address配置启动
/export/servers/cassandra/bin/cassandra -Dcassandra.replace_address='192.168.199.173' >/export/data/cassandra/start_server.log
等待一段时间后,数据会自动同步到新节点上
============================================================
删除群集节点
删除群集节点时,需要根据要删除节点的状态决定如何删除。
## 删除在线群集节点(在该节点上运行)
nodetool decommission ## 删除离线群集节点(在任意存活节点运行)
nodetool removenode node_guid
Cassandra -- Cassandra 3.0版本安装的更多相关文章
- (新)elasticsearch6.0版本安装head插件
ES6.0版本安装head插件 1.1 前言 不知道是我电脑问题还是最近的开源软件都比较**,mysql和elasticsearch新版本变动都比较大. elasticsearch6.0貌似已经不支持 ...
- elasticsearch6.0版本安装head插件
ES6.0版本安装head插件 1.1 前言 不知道是我电脑问题还是最近的开源软件都比较**,mysql和elasticsearch新版本变动都比较大. elasticsearch6.0貌似已经不支持 ...
- Vim 8.0 版本安装方法及添加Python支持
利用Git安装 最简单也是最有效的方法 1. 获取Vim仓库: git clone https://github.com/vim/vim.git 2. 升级到最新的版本: cd vim git pul ...
- MongoDB4.0+版本安装
>>>首先要下载MongoDB软件安装包, MongoDB社区版官网下载 >>>双击msi安装文件进行安装,点击"Next" >>& ...
- 最新MySQL5.7.3.0版本安装(图文版本)
转自:http://www.myexception.cn/mysql/1609536.html 可以从http://dev.mysql.com/downloads/下载MySQL服务器安装软件包,我下 ...
- vue3.0版本安装
如果安装过其他版本的vue的话先卸载 npm uninstall -g vue-cli //卸载指令 卸载不会影响以前项目的启动 然后安装 NPM安装: npm install -g @vue/cli ...
- (转)elasticsearch6.0版本安装head插件
1.1 前言 不知道是我电脑问题还是最近的开源软件都比较**,mysql和elasticsearch新版本变动都比较大. elasticsearch6.0貌似已经不支持命令行安装head插件了,反正我 ...
- VueCli 4.0+ 版本安装插件与VueCLI 旧版本的不同
通过VueCli 脚手架 4+ 版本创建的项目,在引入插件文件并配置时,是通过 import {Create* } ,旧版本是直接导入全部,在配置相应的文件时,重新new 一个:然后再通过Vue 进行 ...
- Microsoft Dynamics CRM 9.0 OP 版本 安装 的那些 雷
天天讲安装过程好无聊了,还是搞点有营养的东西来,那么后面来说说刚出来的MSCRM OP 9.0 版本安装的那些雷: 雷1:操作系统要求Windows 2016 Server 这点还好,因为之前安装MS ...
随机推荐
- 2.7 C++构造函数
参考:http://www.weixueyuan.net/view/6339.html 总结: 如果在类中声明了任何一个构造函数,则系统不会自动生成默认构造函数.构造函数同样能够使用类中的成员变量. ...
- 《软件调试 Windows概要》
操作系统是计算机系统中的基本软件.它负责管理系统中的软硬件资源.通常都包括文件管理.内存管理.进程管理.打印管理.网络管理等基本功能.除此之外,支持调试也是操作系统设计的一项根本任务. 0x01 进 ...
- kbmMW授权管理解析(The kbmMW Authorization manager explained)
从kbmMW v.4.40开始,引入了一个新的非常灵活的授权管理器. 它的目的是为开发人员提供为用户定义资源权限的功能,这是一个可选功能,将现有的授权事件驱动方案内置到kbmMW中,使授权开发任务更容 ...
- Python中替换敏感字
敏感词在文本文件document.txt中,当用户输入敏感词语时,用*号代替并打印出来 document.txt中的文件内容如下: 北京 上海 广州 深圳 领导 test.py content=inp ...
- python 字典,列表,集合,字符串,基础进阶
python列表基础 首先当然是要说基础啦 列表list 1.L.append(object) -> None 在列表末尾添加单个元素,任何类型都可以,包括列表或元组等 2.L.extend(i ...
- Map.putAll()用法
import Java.util.HashMap; public class Map_putAllTest {public static void main(String[] args){ //两 ...
- Java虚拟机的组成
Java虚拟机主要分为以下五个区: 一.方法区: 1. 有时候也成为永久代,在该区内很少发生垃圾回收,但是并不代表不发生GC,在这里进行的GC主要是对方法区里的常量池和对类型的卸载 2. 方法区主要用 ...
- certbot自动在ubuntu16.04的nginx上部署let's encrypt免费ssl证书
终结CA收费时代,让互联网更安全 Install On Ubuntu systems, the Certbot team maintains a PPA. Once you add it to you ...
- 【Python】利用正则解析xml练习题
{ "date": "18-03-29 06:04:47", "data": { "deviceType": 1, &q ...
- 新建oracle数据库表空间及删除表空间和用户
进入oracle的命令控制台,按具体情况执行以下命令: sqlplus 默认数据库普通用户登录sqlplus / as sysdba 默认数据库管理员登录sqlplus username/passwo ...