01-Ubuntu24.04LTS上安装PGSQL
目录
一、准备工作
1.1、系统要求
1.2 、更新 Ubuntu 系统
1.3 、安装依赖
1.4 、添加 PostgreSQL 16 软件源
二、安装 PostgreSQL 16 数据库
三、管理 PostgreSQL 服务
四、PostgreSQL 管理操作
4.1 、访问 Postgres 超级用户账户
4.2 、创建数据库并设置管理权限
4.3 、开启 PostgreSQL 16 远程访问
一、准备工作
安装 PostgreSQL 16 之前,需要做一些准备工作:
1.1、系统要求
硬件组件 | 最低要求 |
---|---|
处理器 | 2GHz 或更快的处理器 |
内存 | 4GB 或以上 |
磁盘空间 | 1024MB 硬盘空间(可能需要额外空间用于数据或支持组件) |
当前版本 | Ubuntu 24.04LTS |
1.2 、更新 Ubuntu 系统
在Ubuntu 中执行以下命令,更新系统软件包:
sudo apt update # 更新软件包列表
sudo apt upgrade # 升级软件包
1.3 、安装依赖
安装 PostgreSQL 16 运行所需的依赖包,这是确保数据库系统正常运行的基础:
sudo apt install dirmngr ca-certificates software-properties-common apt-transport-https lsb-release curl
1.4 、添加 PostgreSQL 16 软件源
1、导入 PostgreSQL GPG 密钥,确保下载的软件包安全可靠:
curl -fSsL https://www.postgresql.org/media/keys/ACCC4CF8.asc | gpg --dearmor | sudo tee /usr/share/keyrings/postgresql.gpg > /dev/null
2、根据需要,添加 PostgreSQL 16 仓库(选项其中一个):
- 适用于生产或日常使用的稳定仓库
稳定仓库是大多数用户,尤其是生产环境中的首选。它会定期更新,确保版本稳定和安全:
echo deb [arch=amd64,arm64,ppc64el signed-by=/usr/share/keyrings/postgresql.gpg] http://apt.postgresql.org/pub/repos/apt/ $(lsb_release -cs)-pgdg main | sudo tee /etc/apt/sources.list.d/postgresql.list
导入 PostgreSQL GPG 密钥,并添加 PostgreSQL 软件源
- 适用于开发者的测试仓库
如果正在进行开发或测试,可以使用快照或测试仓库。但请注意,由于测试版本可能不稳定,不适用于生产环境:
echo deb [arch=amd64,arm64,ppc64el signed-by=/usr/share/keyrings/postgresql.gpg] http://apt.postgresql.org/pub/repos/apt/ $(lsb_release -cs)-pgdg-snapshot main | sudo tee /etc/apt/sources.list.d/postgresql.list
- 包含最新功能的测试仓库
设置最新功能的测试仓库:
echo deb [arch=amd64,arm64,ppc64el signed-by=/usr/share/keyrings/postgresql.gpg] http://apt.postgresql.org/pub/repos/apt/ $(lsb_release -cs)-pgdg-testing main | sudo tee /etc/apt/sources.list.d/postgresql.list
3、更新软件包列表,让 Ubuntu 识别新添加的 PostgreSQL 16 软件源:
sudo apt update
二、安装 PostgreSQL 16 数据库
1、在Ubuntu 中执行以下命令,安装 PostgreSQL 16 服务器和客户端:
sudo apt install postgresql-client-16 postgresql-16
安装 PostgreSQL 16 服务器和客户端
2、安装完成后,检查 PostgreSQL 服务的状态:
sudo systemctl status postgresql
如果 PostgreSQL 服务已成功启动,你将会看到服务正在运行。
查看 PostgreSQL 服务是否已启动
三、管理 PostgreSQL 服务
安装完成后,我们可以对 PostgreSQL 服务进行管理操作:
- 检查服务状态
确认 PostgreSQL 服务是否正在运行。在「终端」中执行以下命令:
sudo systemctl status postgresql
- 启动、停止和重启服务
你也可以根据实际需要,手动启动、停止或重启 PostgreSQL 服务:
sudo systemctl start postgresql # 启动服务sudo systemctl stop postgresql # 停止服务sudo systemctl restart postgresql # 重启服务
- 设置开机自启动
为了提升使用便捷性,建议将 PostgreSQL 设置为系统启动时自动启动:
sudo systemctl enable postgresql # 设置开机自启动sudo systemctl disable postgresql # 禁用开机自启动
四、PostgreSQL 管理操作
4.1 、访问 Postgres 超级用户账户
1、在 PostgreSQL 中,postgres
是默认的超级用户,它对执行管理命令至关重要。要切换到这个账户,请执行:
sudo -i -u postgres
2、进入账户后,输入以下命令打开 PostgreSQL 命令行界面:
psql
3、当你看到postgres=#
提示符时,表示已经成功连接到 PostgreSQL 环境。
4、也可以使用以下命令直接访问 PostgreSQL(推荐)
sudo -u postgres psql
5、执行exit
随时退出 PostgreSQL 环境。
4.2 、创建数据库并设置管理权限
创建 PostgreSQL 数据库并设置管理权限
1、出于安全等因素考虑,通常我们并不直接使用postgres
帐户,而是创建新的 PostgreSQL 用户角色:
sudo su - postgres -c "createuser <用户名>" # 把 <用户名> 替换成你想要的用户名sudo su - postgres -c "createuser jackdb" # 把 <用户名> 替换成你想要的用户名
2、新用户创建一个数据库:
sudo su - postgres -c "createdb <数据库名>" # 把 <数据库名> 替换成你想要的数据库名称sudo su - postgres -c "createdb ai" # 把 <数据库名> 替换成你想要的数据库名称
3、授予用户访问数据库的权限:
sudo -u postgres psql
GRANT ALL PRIVILEGES ON DATABASE ai TO jackdb;
4.3 、开启 PostgreSQL 16 远程访问
默认情况下,PostgreSQL 只监听本地网络接口。如果需要远程连接 PostgreSQL,需要将其调整为其他指定的网络接口:
1、使用文本编辑器打开 PostgreSQL 配置文件:
sudo vi /etc/postgresql/16/main/postgresql.conf
2、在「Connection Settings」部分,找到listen_addresses = 'localhost'
,取消注释并根据你的需要进行修改:
- 如果只允许特定 IP 地址访问,就把
localhost
替换成该 IP 地址。 - 如果要允许所有网络连接,就改成
listen_addresses = '*'
。
开启 PostgreSQL 16 远程访问IP限制
3、修改pg_hba.conf文件
- 查找位置
sudo find / -name pg_hba.conf
- 修改配置文件pg_hba.conf
sudo vi /etc/postgresql/16/main/pg_hba.conf
增加一条数据
host all all 0.0.0.0/0 trust
4、保存配置文件,并重启 PostgreSQL 服务让修改生效:
sudo systemctl restart postgresql
5、查看数据库进程状态
sudo lsof -i :5432
相关文章:

01-Ubuntu24.04LTS上安装PGSQL
目录 一、准备工作 1.1、系统要求 1.2 、更新 Ubuntu 系统 1.3 、安装依赖 1.4 、添加 PostgreSQL 16 软件源 二、安装 PostgreSQL 16 数据库 三、管理 PostgreSQL 服务 四、PostgreSQL 管理操作 4.1 、访问 Postgres 超级用户账户 4.2 、创建数据库并设置管理权限 4…...

Esp32使用micropython基于espnow实现语音对讲机
ESP-NOW协议介绍 ESP-NOW 是乐鑫自主研发的无连接通信协议,具有短数据包传输功能。该协议使多个设备能够以简单的方式相互通信。ESP-NOW 支持以下功能: 加密和未加密的单播通信; 混合加密和未加密的对等设备; 最多可携带 250 字节 的有效载荷; 发送回调功能,可以设置用于…...
Docker 容器隔离关键技术:SELinux
Docker 容器隔离关键技术:SELinux SELinux(Security-Enhanced Linux) 是 Linux 内核中的一项安全机制,用于实现强制访问控制(MAC)。Docker 利用了 SELinux 来增强容器的隔离性,通过对文件、进程…...

Java并发07之ThreadLocal
文章目录 1 ThreadLocal原理2 内部结构3 内存泄露问题4 entry的key为什么被设计为弱引用 1 ThreadLocal原理 ThreadLocal类用来提供线程内部的局部变量。这种变量在多线程环境下访问时能保证各个线程的变量相对独立于其他线程内的变量。ThreadLocal实例通常来说都是private st…...

【单细胞数据库】癌症单细胞数据库CancerSEA
数据库地址:home (hrbmu.edu.cn) Cite Huating Yuan, Min Yan, Guanxiong Zhang, Wei Liu, Chunyu Deng, Gaoming Liao, Liwen Xu, Tao Luo, Haoteng Yan, Zhilin Long, Aiai Shi, Tingting Zhao, Yun Xiao, Xia Li, CancerSEA: a cancer single-cell state atlas…...
Rsa加解密 + 签名验签
Rsa加解密 概述聚合算法名称(用于创建加密器)基本概念填充方式分块加密 基本使用生成密钥加解密创建加密器设置模式(加密)、公钥对明文加密,并对结果进行Base64编码对以上结果,进行解密 设置模式࿰…...

bugku-web-留言板1
大小写绕过也不行 <ScRipt>ALeRt(“XSS”);</sCRipT> 双写绕过可以 <scscriptript>alert(z)</scscriptript> 改变大小写 在测试过程中,我们可以改变测试语句的大小写来绕过XSS规则: 比如:<script>alert(“xs…...

进程状态的学习
进程状态就是 task_struct 内的一个整数 状态间是可以进行转化的 运行: 每一个框都是进程的task_struct,都有唯一的pcb和pid来标识它的唯一性 让CPU选择一个进程去运行,本质是选择一个进程的PCB去运行,task_struct里一定有内存指…...

Vue 2.0->3.0学习笔记(Vue 3 (四)- Composition API 的优势)
Vue 2.0->3.0学习笔记(Vue 3 (四)- Composition API 的优势) Composition API 的优势1. Options API 存在的问题2. Composition API 的优势 Composition API 的优势 1. Options API 存在的问题 笔记 使用传统OptionsA…...
close and shutdown?
背景:我们要讲述的是网络编程中常用的两个API: #include <unistd.h> int close(int fd); #include <sys/socket.h> int shutdown(int sockfd, int how); 以及TCP的半连接,半打开。 shutdown函数的行为依赖第二个参数区分…...
PostgreSQL + hasura + Apollo + GraphQL + React + Antd
技术栈 PostgreSQL hasura Apollo GraphQL React Antd 适用于复杂的查询,快速开发 环境安装 安装PostgreSQL hasura,使用docker安装 使用 Docker Compose 部署时,它会同时启动两个容器PostgreSQL和 Hasura GraphQL ,如下 version: "3.6" serv…...
Android笔记【10】
一、前言 学习课程时,对于自己不懂的点的记录。 二、内容 学习一段代码: val drawerState rememberDrawerState(DrawerValue.Closed)val scope rememberCoroutineScope()Scaffold (topBar{TopAppBar(navigationIcon {IconButton(onClick {scope.lau…...

Leetcode打卡:N皇后
执行结果:通过 题目:51 N皇后 按照国际象棋的规则,皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。 n 皇后问题 研究的是如何将 n 个皇后放置在 nn 的棋盘上,并且使皇后彼此之间不能相互攻击。 给你一个整数 n &#…...

Linux内核4.14版本——ccf时钟子系统(3)——ccf一些核心结构体
目录 1. struct clk_hw 2. struct clk_ops 3. struct clk_core 4. struct clk_notifier 5. struct clk 6. struct clk_gate 7. struct clk_divider 8. struct clk_mux 9. struct clk_fixed_factor 10. struct clk_fractional_divider 11. struct clk_multiplier 12…...

[Deep Learning] 深度学习中常用函数的整理与介绍(pytorch为例)
文章目录 深度学习中常用函数的整理与介绍常见损失函数1. L2_loss | nn.MSELoss()公式表示:特点:应用:缺点:主要参数:示例用法:注意事项: 2. L1 Loss | nn.L1Loss数学定义:特点&…...
【ETCD】etcd简单入门之单节点部署etcd
etcd 是一个分布式可靠的键值存储系统,用于分布式系统中最关键的数据,主要特点包括: 简单:具有明确的、面向用户的 API(gRPC) 安全:自动 TLS 支持,并可选的客户端证书认证 快速&am…...
Cadence基础语法
03-Cadence基础语法 0 Cadence基础语法入门:流程编排语言的新星 Cadence是由Uber开发的一种领域特定语言(Domain-Specific Language,DSL),专门用于编写可扩展的长时间运行的业务流程。它是Temporal工作流引擎的核心组…...

GAMES101虚拟机使用教程与探讨
写在前面 环境配置请参考作业0的pdf,本文章主要对于配置好环境后怎么使用以及遇到的问题进行探讨(要是有更方便的使用方式欢迎在评论区讨论),自己刚开始用的时候也折腾了好久,希望能为后来学习的小伙伴节约一点工具使…...

王道考研编程题总结
我还在完善中,边复习边完善(这个只是根据我自身总结的) 一、 线性表 1. 结构体 #define MaxSize 40 typedef struct{ElemType data[MaxSize];int length; }SqList 2. 编程题 1. 删除最小值 题意 :从顺序表中删除…...
算法2--滑动窗口
滑动窗口 滑动窗口经典例题长度最小的子数组无重复字符的最长子串[最大连续1的个数 III](https://leetcode.cn/problems/max-consecutive-ones-iii/description/)[将 x 减到 0 的最小操作数](https://leetcode.cn/problems/minimum-operations-to-reduce-x-to-zero/description…...

CTF show Web 红包题第六弹
提示 1.不是SQL注入 2.需要找关键源码 思路 进入页面发现是一个登录框,很难让人不联想到SQL注入,但提示都说了不是SQL注入,所以就不往这方面想了 先查看一下网页源码,发现一段JavaScript代码,有一个关键类ctfs…...

高等数学(下)题型笔记(八)空间解析几何与向量代数
目录 0 前言 1 向量的点乘 1.1 基本公式 1.2 例题 2 向量的叉乘 2.1 基础知识 2.2 例题 3 空间平面方程 3.1 基础知识 3.2 例题 4 空间直线方程 4.1 基础知识 4.2 例题 5 旋转曲面及其方程 5.1 基础知识 5.2 例题 6 空间曲面的法线与切平面 6.1 基础知识 6.2…...

12.找到字符串中所有字母异位词
🧠 题目解析 题目描述: 给定两个字符串 s 和 p,找出 s 中所有 p 的字母异位词的起始索引。 返回的答案以数组形式表示。 字母异位词定义: 若两个字符串包含的字符种类和出现次数完全相同,顺序无所谓,则互为…...
关于 WASM:1. WASM 基础原理
一、WASM 简介 1.1 WebAssembly 是什么? WebAssembly(WASM) 是一种能在现代浏览器中高效运行的二进制指令格式,它不是传统的编程语言,而是一种 低级字节码格式,可由高级语言(如 C、C、Rust&am…...
uniapp中使用aixos 报错
问题: 在uniapp中使用aixos,运行后报如下错误: AxiosError: There is no suitable adapter to dispatch the request since : - adapter xhr is not supported by the environment - adapter http is not available in the build 解决方案&…...
LangChain知识库管理后端接口:数据库操作详解—— 构建本地知识库系统的基础《二》
这段 Python 代码是一个完整的 知识库数据库操作模块,用于对本地知识库系统中的知识库进行增删改查(CRUD)操作。它基于 SQLAlchemy ORM 框架 和一个自定义的装饰器 with_session 实现数据库会话管理。 📘 一、整体功能概述 该模块…...
Python Einops库:深度学习中的张量操作革命
Einops(爱因斯坦操作库)就像给张量操作戴上了一副"语义眼镜"——让你用人类能理解的方式告诉计算机如何操作多维数组。这个基于爱因斯坦求和约定的库,用类似自然语言的表达式替代了晦涩的API调用,彻底改变了深度学习工程…...

淘宝扭蛋机小程序系统开发:打造互动性强的购物平台
淘宝扭蛋机小程序系统的开发,旨在打造一个互动性强的购物平台,让用户在购物的同时,能够享受到更多的乐趣和惊喜。 淘宝扭蛋机小程序系统拥有丰富的互动功能。用户可以通过虚拟摇杆操作扭蛋机,实现旋转、抽拉等动作,增…...

AI语音助手的Python实现
引言 语音助手(如小爱同学、Siri)通过语音识别、自然语言处理(NLP)和语音合成技术,为用户提供直观、高效的交互体验。随着人工智能的普及,Python开发者可以利用开源库和AI模型,快速构建自定义语音助手。本文由浅入深,详细介绍如何使用Python开发AI语音助手,涵盖基础功…...
MFE(微前端) Module Federation:Webpack.config.js文件中每个属性的含义解释
以Module Federation 插件详为例,Webpack.config.js它可能的配置和含义如下: 前言 Module Federation 的Webpack.config.js核心配置包括: name filename(定义应用标识) remotes(引用远程模块࿰…...