海量数据库安装部署初体验

文章目录


前言

今天受所长邀请体验一下海量数据库

于是我到官网上找安装包结果没找到。。。。

最后问了所长原本在学堂里
https://education.vastdata.com.cn/pc/#/index/classroomDetails?id=3aec5445ae


一、环境准备

项目 配置
操作系统 OracleLinux7.9
CPU架构 x86_64
内存 8GB
硬盘 32G

没有centos7.9的镜像,OracleLinux7.9应该也可以吧,尝试一下

操作系统信息

sql 复制代码
cat /etc/os-release

二、安装前准备

1.关闭防火墙

sql 复制代码
sudo systemctl status firewalld.service
sudo systemctl stop firewalld.service
sudo systemctl disable firewalld.service

2.关闭透明大页

如果不关闭THP(Transparent Huge Pages,透明大页),可能会对数据库性能产生负面影响。

a. 查看 service 文件。

sql 复制代码
vi /etc/systemd/system/disable-thp.service

b. 编辑文件,添加以下内容。

sql 复制代码
[Unit]
Description=Disable Transparent Huge Pages (THP)
 
[Service]
Type=simple
ExecStart=/bin/sh -c "echo 'never' > /sys/kernel/mm/transparent_hugepage/enabled && echo 'never' > /sys/kernel/mm/transparent_hugepage/defrag"
 
[Install]
WantedBy=multi-user.target

c. 修改完成后,执行命令加载系统服务,并设置开机自启动。

sql 复制代码
systemctl daemon-reload
systemctl start disable-thp
systemctl enable disable-thp

d. 查看THP状态,当返回结果均为always madvise [never]时表示成功设置透明大页永久关闭。

sql 复制代码
cat /sys/kernel/mm/transparent_hugepage/enabled
cat /sys/kernel/mm/transparent_hugepage/defrag

3.配置时区

sql 复制代码
timedatectl set-timezone Asia/Shanghai
cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime

4.配置IPC参数

如果删除数据库服务器使用的IPC资源(共享内存段和信号量),可能引发数据库宕机,所以需要设置参数RemoveIPC=no。

a. 查看配置文件logind.conf,确认已设置RemoveIPC=no。

sql 复制代码
vi /etc/systemd/logind.conf

b. 查看文件systemd-logind.service,确认已设置RemoveIPC=no。

sql 复制代码
vi /usr/lib/systemd/system/systemd-logind.service

c. 重新加载配置参数。

sql 复制代码
systemctl daemon-reload
systemctl restart systemd-logind

d. 检查修改是否生效。

sql 复制代码
loginctl show-session | grep RemoveIPC
systemctl show systemd-logind | grep RemoveIPC

5.配置内核参数

a. 查看内核参数配置文件。

sql 复制代码
vi /etc/sysctl.conf

b. 编辑配置文件,将内核信息写入文件。以下示例仅供参考,可根据实际内存等情况进行设置。

sql 复制代码
fs.aio-max-nr=1048576
fs.file-max= 76724600
kernel.sem = 4096 2097152000 4096 512000
kernel.shmall = 1572864         # pages,  80% MEM or higher
kernel.shmmax = 4294967296     # bytes,  50% MEM or higher
kernel.shmmni = 819200
net.core.netdev_max_backlog = 10000
net.core.rmem_default = 262144
net.core.rmem_max = 4194304
net.core.wmem_default = 262144
net.core.wmem_max = 4194304
net.core.somaxconn = 4096
net.ipv4.tcp_fin_timeout = 5
vm.dirty_background_bytes = 409600000 
vm.dirty_expire_centisecs = 3000
vm.dirty_ratio = 80
vm.dirty_writeback_centisecs = 50
vm.overcommit_memory = 0
vm.swappiness = 0
net.ipv4.ip_local_port_range = 40000 65535
fs.nr_open = 20480000

c. 重载配置,使其在不关机的情况下生效。

sql 复制代码
sysctl -p

6.关闭SELinux

a. 查看配置文件

sql 复制代码
vi /etc/selinux/config

编辑配置文件,将 SELINUX=enforcing 修改为 SELINUX=disabled。

修改完成之后需要重启系统让修改生效。

sql 复制代码
reboot

三、数据库安装

1.创建数据库用户

创建数据库安装用户 vastbase,设定初始密码

sql 复制代码
useradd -m vastbase 
passwd vastbase

2.创建数据库数据目录

sql 复制代码
mkdir -p /home/vastbase/data/vastbase
chmod 700 /home/vastbase/data/vastbase
chown -R vastbase:vastbase /home/vastbase/data/vastbase

3.创建数据库软件目录

sql 复制代码
mkdir -p /home/vastbase/local/vastbase
chown -R vastbase:vastbase /home/vastbase

4.修改资源限制

a. 查看配置文件

sql 复制代码
vi /etc/security/limits.conf

b. 在文件末尾添加以下内容,保存退出

sql 复制代码
vastbase soft nproc unlimited
vastbase hard nproc unlimited
vastbase soft stack unlimited
vastbase hard stack unlimited
vastbase soft core unlimited
vastbase hard core unlimited
vastbase soft memlock unlimited
vastbase hard memlock unlimited
vastbase soft nofile 1024000
vastbase hard nofile 1024000

5.解压安装包

sql 复制代码
mkdir -p /soft/vb
cd /soft/vb
tar -xvf Vastbase-installer-2.2_Build15-centos_7-x86_64.tar.gz
chown -R vastbase:vastbase /soft/vb/
chmod -R 775 /soft/vb/

6.运行安装程序

切换到数据库安装用户vastbase

sql 复制代码
su - vastbase

运行安装程序

sql 复制代码
cd /soft/vb/vastbase-installer/
./vastbase_installer

7.数据库安装



写入一下授权文件

sql 复制代码
echo "license_path='/soft/vb/vastbase_license' " >> $PGDATA/postgresql.conf

7.常用命令

sql 复制代码
##启动数据库服务
vb_ctl start

##停止数据库服务
vb_ctl stop

##重启数据库服务
vb_ctl restart

##显示数据库状态
vb_ctl status

##查看数据库版本
select version();

##查看帮助
\h

##查看用户列出所有用户的权限信息
\du

##查看当前用户
\c 
或 
select current_user;SELECT SESSION_USER, CURRENT_USER;

##退出
\q

##查看数据库、所有者、字符集
\l

##切换数据库
\c  datahub

##切换用户
\c  - system

##列举表
\dt

##查看表结构
\d users

##查看索引
\di

##查看角色属性
\du or \dg

##开启扩展显示
\x

##查看当前数据存储目录
show data_directory;

##查看文件路径
show config_file;
show hba_file;
show ident_file;

##查看用户列表
SELECT * FROM pg_user;

##查询pg_roles系统视图查看用户权限
SELECT * FROM pg_roles;

##查看用户属性
SELECT * FROM pg_authid;

##查看数据库角色
SELECT * FROM PG_ROLES;

##查看数据库时间
SELECT now;
SELECT sysdate;
SELECT CURRENT_TIMESTAMP;
SELECT CURRENT_DATE;
SELECT CURRENT_TIME;

总结

这次在 Oracle Linux 7.9 上安装 Vastbase ,需要注意两点:系统依赖补齐 和 内存参数调优。前期安装器能正常运行,但会因为缺少 perl、libicu、tcl、bzip2 等依赖导致安装中断。还有一点是 memory out of limit 启动失败问题,原因是默认模板配置中 shared_buffers、wal_buffers、max_connections 等参数过大,需要修改。

总体体验下来海量的安装不复杂,由于我是用的Oracle Linux可能阻力会多一些,正常centos应该不会出现这些问题。

相关推荐
墨风如雪17 小时前
甲骨文云(Oracle Cloud)最新注册防坑记录:被ABC了怎么办?
服务器
道清茗18 小时前
【RH294知识点汇总】第 9 章 《 自动执行 Linux 管理任务 》常见问题
linux·运维·服务器
Flying pigs~~19 小时前
RAG智慧问答项目
数据库·人工智能·缓存·微调·知识库·rag
北方的流星19 小时前
华三路由器NAT配置
运维·网络·华三
misL NITL19 小时前
mysql之如何获知版本
数据库·mysql
许彰午20 小时前
CacheSQL(二):主从复制——OpLog 环形缓冲区与故障自动恢复
java·数据库·缓存
数据法师20 小时前
开源情报收集工具GhostTrack深度测评:IP、手机号、用户名的合规信息查询方案
网络·网络协议·tcp/ip
2401_8323655221 小时前
JavaScript中rest参数(...args)取代arguments的优势
jvm·数据库·python
2301_7796224121 小时前
Go语言怎么用信号量控制并发_Go语言semaphore信号量教程【入门】
jvm·数据库·python
丑八怪大丑21 小时前
Java网络编程
linux·服务器·网络