자세한 CODIS 설치 및 배포

CODIS GitHub의가에 대해 설명 매우 넓은뿐만 아니라 / 영어 중국어 설치, 그러한 기사와, 그래서 약간의 구덩이가있을 것이다, 단계가 설치 GitHub의에 따릅니다.

이전 기사에서 "레디 스 실제 모니터링 도구 목록" , 우리는 그래픽의와 패널 및 관리 도구를 CODIS, 레디 스 일반적인 모니터링 도구를 소개합니다. 그래서 그러한 기사. 데스크톱 시스템 : Centos7.

V 소개

CODIS는 , 연결 및 CODIS 프록시 기본 레디 스 서버 유의 한 차이 (지원되지 않는 명령의 목록)에 대한 연결이, 레디 스 같은 상위 응용 프로그램 독립형 사용 CODIS으로 사용할 수있는 상위 계층 애플리케이션을위한 분산 레디 스 솔루션입니다 요청을 전달하는 모든 백 등 기본, 논스톱 데이터 마이그레이션, 모든 것, 클라이언트의 전면에 투명, 당신은 단순히 메모리가 무한 레디 스 서비스를 연결 다시 생각할 수 있습니다.

  • CODIS 프록시 (CODIS 프록시)
  • 관리자 코드 (코드-설정)
  • 레디 스 코드 (코드 서버)
  • 동물원의 관리자

CODIS 프록시 프록시 서비스 인 레디 스 클라이언트 연결, CODIS 프록시, 비즈니스, 그것은 여러 CODIS는 프록시 배포 할 수는 레디 스 프로토콜을 달성 (단지 Twemproxy 같은) 차이를 작동하지 않고 기본 레디 스 자체, CODIS 프록시 자체가 비 상태입니다.

CODIS-설정 자체는 HTTP 서버와 함께 제공되는 데이터 마이그레이션 작업. CODIS-설정을 시작 프록시 노드를 추가 / 삭제 / 추가 레디 스 노드를 삭제, 지원 등 CODIS 관리 도구이며, 대시 보드를 시작합니다, 사용자가 직접 할 수 브라우저에서 실행 CODIS 클러스터를 관찰.

CODIS 서버가 원자 슬롯의 명령과 데이터 마이그레이션 지점 CODIS 레디 스 프로젝트의 유지 보수 및 개발 2.8.13에 따라 추가 지원입니다. 위 프록시 CODIS 및 CODIS-설정 및 레디 스 상호 작용의이 버전이 제대로 작동하려면 CODIS 실행합니다.

CODIS 사육사 데이터 테이블에 따라 메타 정보를 저장하고, 라우팅 노드 CODIS 프록시는 CODIS - 구성 명령은 각 사육사 가능한 CODIS 프록시에 동기하여 개시된다.

제품의 다른 제품 이름, 구성이 충돌하지 않습니다, 다른 제품 구분에 따른 CODIS 네임 스페이스를 지원합니다.

CODIS 차트

자세한 CODIS 설치 및 배포

네트워크에서 사진, 침입 삭제.

V 특성

  • 셀프 밸런싱
  • 아주 사용하기 쉬운
  • 패널 및 관리 도구 그래픽
  • 레디 스 압도적 지원, 완벽하게 호환 twemproxy 명령
  • 레디 스 네이티브 클라이언트를 지원합니다
  • 안전하고 투명한 데이터 마이그레이션, 당신은 쉽게 추가하고 필요에 따라 노드를 삭제할 수 있습니다
  • 이 명령 줄 인터페이스를 제공합니다
  • 편안하고 API를

방지하기 위해 바퀴를 중복을 작성합니다. 에서 "정보"섹션 위 바이두 백과 사전 발췌.

V 설치 단계

1.1 설치로 이동

1.1.1 다운로드 아카이브를 이동

최신 환경 습관 라인에서 최신 버전 1.12.5 여기에서 우리는 최신 버전을 사용, 이동합니다. 업데이트의 최신 버전은 여기에서 볼 수 있습니다. https://golang.org/dl/

wget https://storage.googleapis.com/golang/go1.12.5.linux-amd64.tar.gz

1.1.2 압축 풀림 보관 이동

tar -zxvf go1.12.5.linux-amd64.tar.gz

1.1.3 환경 변수를 설정할

자세한 CODIS 설치 및 배포

같이, 설치 디렉토리입니다 이동 /usr/local

vim /etc/profile

자세한 CODIS 설치 및 배포

export GOROOT=/usr/local/go   #设置为go安装的路径
export GOPATH=/usr/local/gopath  #默认安装包的路径
export PATH=$PATH:$GOROOT/bin:$GOPATH/bin

更新/etc/profile, wq 保存,使用 source /etc/profile 命令可以使新建立的环境变量立刻生效而不用重新启动系统。

자세한 CODIS 설치 및 배포

1.1.4 helloword go go go

新建一个go文件,然后运行。

자세한 CODIS 설치 및 배포

package main
    import "fmt"

    func main(){
        fmt.Printf("hello,world\n")
 }

1.2 安装JDK

没有安装Java JDK的朋友可以直接看这里。《CentOS安装Java JDK》

1.3 安装ZooKeeper

1.3.1 下载ZooKeeper压缩包

wget http://mirrors.hust.edu.cn/apache/zookeeper/zookeeper-3.4.13/zookeeper-3.4.13.tar.gz

1.3.2 解压ZooKeeper压缩包

tar -zxvf zookeeper-3.4.13.tar.gz

1.3.3 删除ZooKeeper压缩包

rm -f zookeeper-3.4.13.tar.gz

1.3.4 拷贝配置文件

cd /usr/local/zookeeper-3.4.13/conf

cp zoo_sample.cfg zoo.cfg

vim zoo.cfg

자세한 CODIS 설치 및 배포

这个zoo.cfg是zookeeper的配置文件,这里我搭的是单机版,如果想搭集群版也是通过修改配置文件即可。

# The number of milliseconds of each tick
tickTime=2000
# The number of ticks that the initial
# synchronization phase can take
initLimit=10
# The number of ticks that can pass between
# sending a request and getting an acknowledgement
syncLimit=5
# the directory where the snapshot is stored.
# do not use /tmp for storage, /tmp here is just
# example sakes.
dataDir=/usr/local/zookeeper-3.4.13/data    #这里最好自己设置
# the port at which the clients will connect
clientPort=2181
# the maximum number of client connections.
# increase this if you need to handle more clients
#maxClientCnxns=60
#
# Be sure to read the maintenance section of the
# administrator guide before turning on autopurge.
#
# http://zookeeper.apache.org/doc/current/zookeeperAdmin.html#sc_maintenance
#
# The number of snapshots to retain in dataDir
#autopurge.snapRetainCount=3
# Purge task interval in hours
# Set to "0" to disable auto purge feature
#autopurge.purgeInterval=1
server.1=cnblogs01:8888:9888         #这里修改为自己的主机名或者IP
server.2=cnblogs02:8888:9888
server.3=cnblogs03:8888:9888

创建/usr/local/zookeeper-3.4.13/data文件夹,新建一个myid,写入1

mkdir data

vim myid

1.3.5 启动ZooKeeper

/usr/local/zookeeper-3.4.13/bin/zkServer.sh start

자세한 CODIS 설치 및 배포

1.4 安装Codis

1.4.1 安装Codis

Codis 源代码需要下载到 $GOPATH/src/github.com/CodisLabs/codis

mkdir -p $GOPATH/src/github.com/CodisLabs

cd $_ && git clone https://github.com/CodisLabs/codis.git -b release3.2

1.4.2 编译Codis

cd $GOPATH/src/github.com/CodisLabs/codis

make

直接通过 make 进行编译,这里报了个错 ./autogen.sh:行5: autoconf: 未找到命令

자세한 CODIS 설치 및 배포

安装autoconf

yum install autoconf

安装autoconf之后,继续通过 make 编译。

자세한 CODIS 설치 및 배포

dashboard,proxy,admin,ha,fe这些codis的组件编译完成了。

注意的是,目录结构一定要是,gopath的自己的定义,单后后面的目录需要新建,必须和官网一样,不一样,要报错。 $GOPATH/src/github.com/CodisLabs/

1.4.3 启动codis-dashboard

使用 codis-dashboard-admin.sh 脚本启动 dashboard,并查看 dashboard 日志确认启动是否有异常。

./admin/codis-dashboard-admin.sh start

tail -100 ./log/codis-dashboard.log.2019-05-26 注意:2019-05-26为当前日期。

자세한 CODIS 설치 및 배포

자세한 CODIS 설치 및 배포

1.4.3 启动codis-proxy

使用 codis-proxy-admin.sh 脚本启动 codis-proxy,并查看 proxy 日志确认启动是否有异常。

./admin/codis-proxy-admin.sh start

tail -100 ./log/codis-proxy.log.2019-05-26

자세한 CODIS 설치 및 배포

1.4.4 启动codis-server

使用 codis-server-admin.sh 脚本启动 codis-server,并查看 redis 日志确认启动是否有异常。

./admin/codis-server-admin.sh start

tail -100 /tmp/redis_6379.log

查看日志如下图所示,启动codis时报错提示:

21875:M 26 May 20:51:24.154 * Increased maximum number of open files to 10032 (it was originally set to 1024).
21875:M 26 May 20:51:24.154 # Creating Server TCP listening socket 127.0.0.1:6379: bind: Address already in use

자세한 CODIS 설치 및 배포

因为Redis默认端口号就是6379,由于之前(centos安装Redis)设置了本机默认开机启动Redis,所以6379已被占用。

解决方案

如下图所示,修改 /usr/local/gopath/src/github.com/CodisLabs/codis/config/redis.conf 配置文件的端口号。改为6380

자세한 CODIS 설치 및 배포

자세한 CODIS 설치 및 배포

修改端口号以后再通过 ./admin/codis-server-admin.sh start 启动codis-server。

tail -100 /tmp/redis_6379.log 查看日志如下:

자세한 CODIS 설치 및 배포

注意:如果redis.conf中对应的logfile也改成6380的话,查看日志就得用 tail -100 /tmp/redis_6380.log

1.4.5 启动codis-fe

使用 codis-fe-admin.sh 脚本启动 codis-fe,并查看 fe 日志确认启动是否有异常。

./admin/codis-fe-admin.sh start

tail -100 ./log/codis-fe.log.2019-05-26

1.5 通过fe添加group

通过web浏览器访问集群管理页面(fe地址:127.0.0.1:9090) 选择我们刚搭建的集群 codis-demo,在 Proxy 栏可看到我们已经启动的 Proxy, 但是 Group 栏为空,因为我们启动的 codis-server 并未加入到集群 添加 NEW GROUP,NEW GROUP 行输入 1,再点击 NEW GROUP 即可 添加 Codis Server,Add Server 行输入我们刚刚启动的 codis-server 地址,添加到我们刚新建的 Group,然后再点击 Add Server 按钮即可,如下图所示:

자세한 CODIS 설치 및 배포

1.6 通过fe初始化slot

新增的集群 slot 状态是 offline,因此我们需要对它进行初始化(将 1024 个 slot 分配到各个 group),而初始化最快的方法可通过 fe 提供的 rebalance all slots 按钮来做,如下图所示,点击此按钮,我们即快速完成了一个集群的搭建。

자세한 CODIS 설치 및 배포

1.7 通过 ansible 快速部署集群

使用 ansible 可快速在单机、多机部署多套 codis 集群。 ansible 文件夹包含了部署 codis 集群的 playbook,根据自己部署环境修改 groups_var/all 文件里参数,修改 hosts 文件添加部署的环境 IP 即可。 ansible 安装也及其简单,各部署机器无需安装任何额外的 agent,彼此之间通过 ssh 通信。

git clone https://github.com/ansible/ansible.git -b stable-2.3
cd ./ansible
source ./hacking/env-setup
cd $codis_dir/ansible
ansible-playbook -i hosts site.yml

v集群配置

2.1 添加Redis实例

这里再分别添加6381、6382两个Redis实例。

cp config/redis.conf config/redis6381.conf

cp config/redis.conf config/redis6382.conf

分别更新6381、6382.conf的port、pidfile和logfile

vim config/redis6381.conf

更新之后,启动新增的两个Redis实例。

./bin/codis-server ./config/redis6381.conf

./bin/codis-server ./config/redis6382.conf

자세한 CODIS 설치 및 배포

按照上面add server的方法(如下图)添加两个实例,注意,若未执行 ./bin/codis-server ./config/redis6381.conf ,添加时会报错。

자세한 CODIS 설치 및 배포

刚添加进来的默认状态是NO:ONE,如下图,点击小扳手(SLAVEOF 127.0.0.1:6380)。

자세한 CODIS 설치 및 배포

测试效果:

자세한 CODIS 설치 및 배포

注意:如上图,开启集群管理之后,6380可读可写,81和82只有只读权限。

2.2 创建新的分组

按照上面步骤继续创建7380和7381.

자세한 CODIS 설치 및 배포

在Codis • Dashboard(http://ip:9090/#codis-demo)中添加新的分组和server成员。

자세한 CODIS 설치 및 배포

v博客总结

本篇文章只聊了codis,不聊集群,如果对集群感兴趣的可以看看之前的一篇文章。《详解Redis Cluster集群》

本文"安装步骤"段落,大面积采用的是Codis github上的介绍,该段落也可以去github看看。当然本文中也加入了一些github上没有说的太清楚或者不太好理解的细节。

이 문서가 직접 springboot 도입 CODIS을 소개하려고했지만, 문서는 매우 길고, 그것은 편리 레이아웃이 아니다. 그래서 springboot에 당신은 여기에서 볼 수 있습니다. "SpringBoot은 (쉰아홉) 통합 CODIS 물론 고급" .

기타 참조 :


저자 : 오빠라고 불러 머리를하십시오
에서 아웃 : http://www.cnblogs.com/toutou/
저자에 관하여 : 프로젝트 개발 기반 플랫폼에 초점을 맞 춥니 다. 질문이나 제안이 있다면, 나에게 많은 계몽하십시오!
면책 조항 :이 문서에는, 저자 및 블로그 공원 전체에 속하는 다시 인쇄에 오신 것을 환영합니다,하지만이 부분에 의해 선언 된 저자의 동의없이 유지하고 명백한 위치에 원래 기사 페이지의 링크를 제공해야합니다.
이로써 선언 : 모든 의견과 비공개 메시지 처음에 응답 할 것이다. 우리는 크게 또한 정확한 오류 및 일반적인 진행 상황을 정원을 환영합니다. 또는 직접 개인 편지 I
연대 블로거에가 : 당신이 기사가 도움이 생각한다면, 당신은 문서의 오른쪽 아래를 클릭 할 수 있습니다 [ 추천 ] 은. 원래 저자 계속 쓰기와 최대 전력을 준수하는 것이 좋습니다!

추천

출처www.cnblogs.com/toutou/p/install_codis.html