couchbase 集群搭建
CouchBase是一款开源的、分布式的、面向文档的NoSQL数据库,主要用于分布式缓存和数据存储领域,它是Apache CouchDB和MemBase这两个NoSQL数据库的合并的产物,而MemBase是基于Memcached的。因此CouchBase联合了CouchDB的简单可靠和Memcached的高性能,以及membase的可扩展性。
[TOC]
集群配置过程
安装 couchbase 7.2.4
- 所有节点:安装 couchbase-server-community 7.2.4
#.下载并安装
cd /d d:\
wget -c http://iso.sqlfans.cn/couchbase/wins/couchbase-server-community_7.2.4-windows_amd64.msi
start /wait couchbase-server-community_7.2.4-windows_amd64.msi /quiet
#.设置防火墙,示例内网为 10.30.0.0/255.255.0.0
netsh advfirewall firewall add rule name="permit_couchbase_unencrypt_8091" protocol=TCP dir=in remoteip=10.30.0.0/255.255.0.0 localport=4369,6060,8091-8094,9100-9105,9998-9999,11209-11215,18091-18093,21100-21299 action=allow
- 附:linux安装方式可参考如下:
cd /opt/
wget -c http://iso.sqlfans.cn/couchbase/couchbase-server-community-7.2.4-linux.x86_64.rpm
rpm -ivh couchbase-server-community-7.2.4-linux.x86_64.rpm
systemctl start couchbase-server
systemctl status couchbase-server
netstat -lnpt | grep 8091
创建一个集群
- 第1步,在主节点上(示例
10.30.3.144
)用 chrome浏览器 打开http://10.30.3.144:8091/ui/index.html
,点击Setup New Cluster
- 第2步,配置集群信息,示例集群名为
sqlfans
管理员账号为Administrator
密码为Admin_147
- 第3步,勾选 我接受,然后点击
Configure Disk, Memory, Services
- 第4步,配置当前节点的ip地址(示例
10.30.3.144
)及数据目录(示例d:/couchbase/data
),并完成安装
将新节点加入老集群
- 第1步,用 chrome 浏览器打开集群节点的控制台,示例
http://10.30.3.144:8091/ui/index.html
,在Servers
标签页点击 ADD SERVER 按钮,输入新节点的ip地址(示例10.30.3.145
),将其加入该集群
- 第2步,添加新节点之后,再点击右上角的 Rebalance 按钮完成新节点的数据同步
创建bucket及user
- 第1步,用 chrome 浏览器打开集群节点的控制台,示例
http://10.30.3.144:8091/ui/index.html
,在Bucket
标签页点击 ADD BUCKET 按钮,输入新bucket的名称(示例web_prd
)并分配内存(示例2048
MB)
- 第2步,创建bucket之后,在
Security
标签页点击 ADD USER 按钮,输入新user的名称(示例user_prd
)及密码,并勾选对指定bucket(示例web_prd
)的权限
遇到的问题
场景1:集群添加新节点报错
- 报错1:集群添加新节点之后,执行 Rebalance 之后报错 CPU with SSE4.2 extensions is required,启用新节点的 SSE 4.2 指令集(pve请修改cpu的Type为host)即可
Service 'memcached' exited with status 1. Restarting. Messages:
2024-07-10T10:10:16.610950+08:00 CRITICAL Failed to initialise - CPU with SSE4.2 extensions is required - terminating.
- 报错2:集群新节点启用SSE 4.2指令集并重启之后,报错 invalid UTF-8 byte at index 38: 0xDA,将 couchbase 版本由 7.6.0 更换为 7.2.4
Service 'memcached' exited with status 255. Restarting. Messages:
2024-07-10T10:16:11.272519+08:00 CRITICAL Failed to create required listening socket:
"{"family":"inet","host":"*","port":11210,"system":false,"tag":"","tls":false,"type":"mcbp"}".
Errors: [json.exception.type_error.316] invalid UTF-8 byte at index 38: 0xDA. Terminating.
场景2:找回web登录密码
- 不知道密码的情况下重置,示例 新密码为
Admin_147
cd /d C:\"Program Files"\Couchbase\Server\bin
couchbase-cli reset-admin-password -c 127.0.0.1:8091 -u Administrator -p Admin_147 --new-password Admin_147
- 已知密码的情况下重置,示例 新密码为
Admin_258
cd /d C:\"Program Files"\Couchbase\Server\bin
couchbase-cli reset-admin-password -c 127.0.0.1:8091 -u Administrator -p Admin_147 --new-password Admin_258
场景3:以特定账号启动couchbase服务
- 以特定账号启动couchbase服务,示例账号
couchbase
密码AdMin_147
net user couchbase AdMin_147 /add /Y /expires:never
net localgroup administrators couchbase /add
takeown /f "%ProgramFiles%\Couchbase" /a /r
icacls "%ProgramFiles%\Couchbase" /t /grant:r couchbase:f
#.自动脚本会启动失败,手动修改服务的启动账号就好了
net stop CouchbaseServer
sc config CouchbaseServer obj= ".\couchbase" password= "AdmMin_147"
net start CouchbaseServer
sc config CouchbaseServer start= auto
场景4:利用 couchbase-cli 管理数据库
- couchbase-cli server-list 查看 节点状态
couchbase-cli server-list -c 127.0.0.1:8091 -u Administrator -p Admin_147
- couchbase-cli user-manage 管理 只读账号
#.只能创建1个只读账号,示例名称 user_readonly 密码 123456
couchbase-cli user-manage -c 127.0.0.1:8091 --set --ro-username=user_readonly --ro-password=123456 -u Administrator -p Admin_147
#.查询只读账号
couchbase-cli user-manage -c 127.0.0.1:8091 --list -u Administrator -p Admin_147
#.删除只读账号
couchbase-cli user-manage -c 127.0.0.1:8091 --delete --ro-username=user_readonly -u Administrator -p Admin_147