Introduction
創(chuàng)新互聯(lián)專注于海州企業(yè)網(wǎng)站建設(shè),成都響應(yīng)式網(wǎng)站建設(shè)公司,成都商城網(wǎng)站開發(fā)。海州網(wǎng)站建設(shè)公司,為海州等地區(qū)提供建站服務(wù)。全流程定制制作,專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)What is Cassandra?
The Apache Cassandra database is the right choice when you need scalability(伸縮) and high availability without compromising performance. Linear scalability and proven fault-tolerance(容錯(cuò)系統(tǒng))on commodity hardware or cloud infrastructure make it the perfect platform for mission-critical data.Cassandra's support for replicating across multiple datacenters is best-in-class, providing lower latency for your users and the peace of mind of knowing that you can survive(生存) regional outages.
Prerequisites
CentOS release 6.5 (Final)
系統(tǒng)參數(shù)配置
[root@sht-sgmhadoopdn-02 ~]# vim /etc/security/limits.conf
tnuser soft memlock unlimited
tnuser hard memlock unlimited
[root@sht-sgmhadoopdn-02 ~]# sysctl -w vm.max_map_count=131072
[root@sht-sgmhadoopdn-02 ~]# echo "vm.max_map_count=131072" >> /etc/sysctl.conf
[root@sht-sgmhadoopdn-02 ~]#vim /etc/security/limits.d/90-nproc.conf
* soft nproc 1024
改為:
* soft nproc 10240
[root@sht-sgmhadoopdn-02 ~]# swapoff -a
軟件準(zhǔn)備:cassandra,jdk,python
[root@sht-sgmhadoopdn-02 softwore]# ll
total 218276
-rw-r--r-- 1 dhchen Corp_User 25288340 Aug 14 14:44 apache-cassandra-2.1.18-bin.tar.gz
-rw-r--r-- 1 dhchen Corp_User 181442359 Aug 14 14:43 jdk-8u111-linux-x64.tar.gz
-rw-r--r-- 1 dhchen Corp_User 16768806 Aug 14 14:44 Python-2.7.10.tgz
創(chuàng)建用戶組和用戶
[root@sht-sgmhadoopdn-02 softwore]# groupadd appuser
[root@sht-sgmhadoopdn-02 softwore]#useradd -g appuser -G root -d /usr/local/cassandra tnuser
安裝JAVA
[root@sht-sgmhadoopdn-02 softwore]# tar xf jdk-8u111-linux-x64.tar.gz -C /usr/local/
[root@sht-sgmhadoopdn-02 local]# ln -s /usr/local/jdk1.8.0_111 /usr/local/java
[root@sht-sgmhadoopdn-02 local]# chown -R tnuser:appuser /usr/local/java
[root@sht-sgmhadoopdn-02 local]# /usr/local/java/bin/java -version
java version "1.8.0_111"
Java(TM) SE Runtime Environment (build 1.8.0_111-b14)
Java HotSpot(TM) 64-Bit Server VM (build 25.111-b14, mixed mode)
安裝python
[root@sht-sgmhadoopdn-02 local]# tar xf Python-2.7.10.tgz -C /usr/local
[root@sht-sgmhadoopdn-02 local]# cd Python-2.7.10
[root@sht-sgmhadoopdn-02 Python-2.7.10]# ./configure --prefix=/usr/local/python
[root@sht-sgmhadoopdn-02 Python-2.7.10]#make && make install
[root@sht-sgmhadoopdn-02 local]# chown -R tnuser:appuser /usr/local/python
[root@sht-sgmhadoopdn-02 local]# /usr/local/python/bin/python --version
Python 2.7.10
安裝cassandra
[root@sht-sgmhadoopdn-02 local]# tar xf /opt/softwore/apache-cassandra-2.1.18-bin.tar.gz -C /usr/local/
[root@sht-sgmhadoopdn-02 local]# ln -s /usr/local/apache-cassandra-2.1.18 /usr/local/cassandra
[root@sht-sgmhadoopdn-02 local]# chown -R tnuser:appuser /usr/local/apache-cassandra-2.1.18
[root@sht-sgmhadoopdn-02 local]# chown -R tnuser:appuser /usr/local/cassandra
#加入自啟動(dòng)(可以不做這一步)
[root@sht-sgmhadoopdn-02 local]# vim /etc/rc.local
su - tnuser -c "cd /usr/local/cassandra/bin/ && nohup ./cassandra "
設(shè)置環(huán)境變量
[root@sht-sgmhadoopdn-02 local]# su - tnuser
[tnuser@sht-sgmhadoopdn-02 ~]$ cat ~/.bash_profile
export CASSANDRA_HOME=/usr/local/cassandra
export JAVA_HOME=/usr/local/java
export PYTHON_HOME=/usr/local/python
PATH=$PYTHON_HOME/bin:$JAVA_HOME/bin:$CASSANDRA_HOME/bin:$CASSANDRA_HOME/tools/bin:$PATH:$HOME/bin:/usr/local/bin
export PATH
set umask to 022
umask 022
PS1=`uname -n`":"'$USER'":"'$PWD'":>"; export PS1
[tnuser@sht-sgmhadoopdn-02 ~]$ source .bash_profile
[tnuser@sht-sgmhadoopdn-02 ~]$ python -V
Python 2.7.10
[tnuser@sht-sgmhadoopdn-02 ~]$ java -version
java version "1.8.0_111"
Java(TM) SE Runtime Environment (build 1.8.0_111-b14)
Java HotSpot(TM) 64-Bit Server VM (build 25.111-b14, mixed mode)
創(chuàng)建相關(guān)目錄
[tnuser@sht-sgmhadoopdn-02 cassandra]$ mkdir -p /usr/local/cassandra/{data,commitlog,log,saved_caches}
設(shè)置配置文件:cassadnra.yaml
[tnuser@sht-sgmhadoopdn-02 conf]$ vim /usr/local/cassandra/conf/cassandra.yaml
cluster_name: 'mycluster'
data_file_directories:
- /usr/local/cassandra/data
commitlog_directory: /usr/local/cassandra/commitlog
saved_caches_directory: /usr/local/cassandra/saved_caches
- seeds: "172.16.101.59"
# Ex: "
listen_address: 172.16.101.59
native_transport_port: 9042
start_rpc: true
rpc_address: 0.0.0.0
rpc_port: 9160
broadcast_rpc_address: 172.16.101.59
設(shè)置配置文件: logback.xml
[tnuser@sht-sgmhadoopdn-02 conf]$ vim /usr/local/cassandra/conf/logback.xml
啟動(dòng)cassandra
[tnuser@sht-sgmhadoopdn-02 cassandra]$cassandra
[tnuser@sht-sgmhadoopdn-02 cassandra]$ netstat -nltup |grep -e 9042 -e 9160
tcp 0 0 0.0.0.0:9042 0.0.0.0:* LISTEN 24286/java
tcp 0 0 0.0.0.0:9160 0.0.0.0:* LISTEN 24286/java
[tnuser@sht-sgmhadoopdn-02 cassandra]$ lsof -Pnl|grep -e 9042 -e 9160
java 24286 503 72u IPv4 35165833 0t0 TCP *:9042 (LISTEN)
java 24286 503 73u IPv4 35165834 0t0 TCP *:9160 (LISTEN)
[tnuser@sht-sgmhadoopdn-02 ~]$ ps -ef |grep cassandra
tnuser 24286 1 2 18:00 pts/4 00:00:29 /usr/local/java/bin/java -ea -javaagent:/usr/local/cassandra/lib/jamm-0.3.0.jar -XX:+CMSClassUnloadingEnabled -XX:+UseThreadPriorities -XX:ThreadPriorityPolicy=42 -Xms1463M -Xmx1463M -Xmn200M -XX:+HeapDumpOnOutOfMemoryError -Xss256k -XX:StringTableSize=1000003 -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+CMSParallelRemarkEnabled -XX:SurvivorRatio=8 -XX:MaxTenuringThreshold=1 -XX:CMSInitiatingOccupancyFraction=75 -XX:+UseCMSInitiatingOccupancyOnly -XX:+UseTLAB -XX:CompileCommandFile=/usr/local/cassandra/conf/hotspot_compiler -XX:CMSWaitDuration=10000 -XX:+CMSParallelInitialMarkEnabled -XX:+CMSEdenChunksRecordAlways -XX:CMSWaitDuration=10000 -XX:+UseCondCardMark -Djava.net.preferIPv4Stack=true -Dcassandra.jmx.local.port=7199 -XX:+DisableExplicitGC -Dlogback.configurationFile=logback.xml -Dcassandra.logdir=/usr/local/cassandra/logs -Dcassandra.storagedir=/usr/local/cassandra/data -cp /usr/local/cassandra/conf:/usr/local/cassandra/build/classes/main:/usr/local/cassandra/build/classes/thrift:/usr/local/cassandra/lib/airline-0.6.jar:/usr/local/cassandra/lib/antlr-runtime-3.5.2.jar:/usr/local/cassandra/lib/apache-cassandra-2.1.18.jar:/usr/local/cassandra/lib/apache-cassandra-clientutil-2.1.18.jar:/usr/local/cassandra/lib/apache-cassandra-thrift-2.1.18.jar:/usr/local/cassandra/lib/commons-cli-1.1.jar:/usr/local/cassandra/lib/commons-codec-1.2.jar:/usr/local/cassandra/lib/commons-lang3-3.1.jar:/usr/local/cassandra/lib/commons-math4-3.2.jar:/usr/local/cassandra/lib/compress-lzf-0.8.4.jar:/usr/local/cassandra/lib/concurrentlinkedhashmap-lru-1.4.jar:/usr/local/cassandra/lib/disruptor-3.0.1.jar:/usr/local/cassandra/lib/guava-16.0.jar:/usr/local/cassandra/lib/high-scale-lib-1.0.6.jar:/usr/local/cassandra/lib/jackson-core-asl-1.9.2.jar:/usr/local/cassandra/lib/jackson-mapper-asl-1.9.2.jar:/usr/local/cassandra/lib/jamm-0.3.0.jar:/usr/local/cassandra/lib/javax.inject.jar:/usr/local/cassandra/lib/jbcrypt-0.3m.jar:/usr/local/cassandra/lib/jline-1.0.jar:/usr/local/cassandra/lib/jna-4.0.0.jar:/usr/local/cassandra/lib/json-simple-1.1.jar:/usr/local/cassandra/lib/libthrift-0.9.2.jar:/usr/local/cassandra/lib/logback-classic-1.1.2.jar:/usr/local/cassandra/lib/logback-core-1.1.2.jar:/usr/local/cassandra/lib/lz4-1.2.0.jar:/usr/local/cassandra/lib/metrics-core-2.2.0.jar:/usr/local/cassandra/lib/netty-all-4.0.44.Final.jar:/usr/local/cassandra/lib/reporter-config-2.1.0.jar:/usr/local/cassandra/lib/slf4j-api-1.7.2.jar:/usr/local/cassandra/lib/snakeyaml-1.11.jar:/usr/local/cassandra/lib/snappy-java-1.0.5.2.jar:/usr/local/cassandra/lib/ST4-4.0.8.jar:/usr/local/cassandra/lib/stream-2.5.2.jar:/usr/local/cassandra/lib/super-csv-2.1.0.jar:/usr/local/cassandra/lib/thrift-server-0.3.7.jar org.apache.cassandra.service.CassandraDaemon
登錄方式
[tnuser@sht-sgmhadoopdn-02 cassandra]$ cqlsh
cqlsh>
停止cassandra服務(wù)
#先找到cassandra對(duì)應(yīng)的進(jìn)程號(hào),然后kill
pgrep命令以名稱為依據(jù)從運(yùn)行進(jìn)程隊(duì)列中查找進(jìn)程,并顯示查找到的進(jìn)程id。
-u Only match processes whose real user ID is listed. Either the numerical or symbolical value may be used.
-f The pattern is normally only matched against the process name. When -f is set, the full command line is used.
[tnuser@sht-sgmhadoopdn-02 ~]$ pgrep -l -u tnuser
24286 java
25586 bash
[tnuser@sht-sgmhadoopdn-02 ~]$ pgrep -u tnuser -f cassandra
24286
[tnuser@sht-sgmhadoopdn-02 ~]$ pgrep -u tnuser -f cassandra|xargs kill -9
Error
(1)在啟動(dòng)cassand時(shí)候報(bào)錯(cuò):
[tnuser@sht-sgmhadoopdn-02 cassandra]$ cassandra
.......
ERROR:java.lang.RuntimeException: Unable to gossip with any seeds
.......
Solution:
修改配置文件
[tnuser@sht-sgmhadoopdn-02 cassandra]$ vim /usr/local/cassandra/conf/cassandra.yaml
- seeds: "127.0.0.1" 改為
- seeds: "172.16.101.59"
(2)在使用cqlsh登錄的時(shí)候報(bào)錯(cuò)
Darren2:tnuser:/usr/local/cassandra:>cqlsh
Traceback (most recent call last):
File "/usr/local/cassandra/bin/cqlsh.py", line 168, in
from cqlshlib import cql3handling, cqlhandling, pylexotron, sslhandling, cqlshhandling
File "/usr/local/cassandra/bin/../pylib/cqlshlib/sslhandling.py", line 20, in
import ssl
File "/usr/local/python/lib/python2.7/ssl.py", line 97, in
import _ssl # if we can't import it, let the error propagate
ImportError: No module named _ssl
原因:python中ssl模塊無(wú)法正常調(diào)用
Darren2:tnuser:/usr/local:>python
Python 2.7.10 (default, Oct 18 2017, 21:17:45)
[GCC 4.4.7 20120313 (Red Hat 4.4.7-4)] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import ssl
Traceback (most recent call last):
File "
File "/usr/local/python/lib/python2.7/ssl.py", line 97, in
import _ssl # if we can't import it, let the error propagate
[root@Darren2 local]# yum list installed | grep ssl
openssl.x86_64 1.0.1e-15.el6 @anaconda-CentOS-201311272149.x86_64/6.5
openssl098e.x86_64 0.9.8e-17.el6.centos.2
解決方法:
[root@Darren2 local]#yum install openssl-devel -y
重新安裝python;
Darren2:tnuser:/usr/local/cassandra:>python
>>> import ssl;
>>> import _ssl
>>> quit();
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。