在VMware虚拟机上部署polardb

免密登录到我们的虚拟机之后,要在虚拟机上部署polardb数据库,首先第一步要先克隆源码:

为了进SSH协议进行传输源码需要先进行下面的步骤:

将宿主机上的私钥文件复制到虚拟机上

复制代码
scp "C:\Users\waitw\.ssh\id_rsa" anne@192.168.198.132:/home/anne/.ssh/

权限设置:

复制代码
chmod 600 ~/.ssh/id_rsa

然后用SSH来传输polardb的源码。

复制代码
git clone -b POLARDB_15_STABLE git@github.com:ApsaraDB/PolarDB-for-PostgreSQL.git

更新包索引

复制代码
sudo apt update

更新所需要的包

复制代码
sudo apt install apt-transport-https ca-certificates curl software-properties-common

创建目录

复制代码
sudo mkdir -p /etc/apt/trusted.gpg.d/

添加Docker官方的gpg密钥

复制代码
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/trusted.gpg.d/docker.gpg

添加docker仓库

复制代码
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"

再次更新包索引

复制代码
sudo apt update

安装docker ce

复制代码
sudo apt install docker-ce

验证docker是否安装成功:

复制代码
sudo docker run hello-world

需要能连接到docker hub的网

接着我们拉取polardb的镜像:

复制代码
sudo docker pull polardb/polardb_pg_devel:ubuntu24.04

进入开发机器的源码目录

复制代码
 cd PolarDB-for-PostgreSQL/

此时我们已经在开发机器的源码目录中。从开发镜像上创建一个容器,将当前目录作为一个 volume 挂载到容器中,这样可以:

  • 在容器内的环境中编译源码

  • 在容器外(开发机器上)使用编辑器来查看或修改代码

    docker run -it
    -v $PWD:/home/postgres/polardb_pg
    --shm-size=512m --cap-add=SYS_PTRACE --privileged=true
    --name polardb_pg_devel
    polardb/polardb_pg_devel:ubuntu24.04
    bash

查找所有容器:

复制代码
sudo docker ps -a

启动容器并进入其shell

复制代码
sudo docker start d71e06b59566
sudo docker exec -it d71e06b59566 bash

进入容器后,为容器内用户获取源码目录的权限,然后编译部署 PolarDB-PG 实例。

复制代码
# 获取权限并编译部署
cd polardb_pg
sudo chmod -R a+wr ./
sudo chown -R postgres:postgres ./
./build.sh

# 验证
psql -c 'SELECT version();'
                                   version
----------------------------------------------------------------------
 PostgreSQL 15.x (PolarDB 15.x.x.x build xxxxxxxx) on {your_platform}
(1 row)

启动postgreSQL

复制代码
sudo -u postgres /usr/lib/postgresql/14/bin/pg_ctl start -D /home/anne/tmp_polardb_pg_15_base/data
相关推荐
Elastic 中国社区官方博客18 分钟前
Elasticsearch:你是说,用于混合搜索(hybrid search)
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
czlczl2002092526 分钟前
高并发下的 Token 存储策略: Redis 与 MySQL 的一致性
数据库·redis·mysql
虹科网络安全31 分钟前
艾体宝产品 | 基准测试:ArangoDB性能碾压Neo4j,速度最高提升8倍!
数据库·neo4j
哈哈老师啊32 分钟前
Springboot校园订餐管理系统k2pr7(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
JIngJaneIL32 分钟前
基于java+ vue学生选课系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot
石明亮(JT)36 分钟前
MySQL8.0电商金融交易系统SQL实战
数据库·mysql
amao99881 小时前
数据库管理系统DBMS
数据库·oracle
wdfk_prog1 小时前
Ubuntu 虚拟机根文件系统损坏故障的深度分析与修复
linux·数据库·ubuntu
DemonAvenger1 小时前
Redis发布订阅模式:打造实时消息通信系统的实践指南
数据库·redis·性能优化
sc.溯琛2 小时前
MySQL 入门实验:环境搭建与基础操作全攻略
数据库·mysql