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…...

SpringBoot-17-MyBatis动态SQL标签之常用标签
文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…...
树莓派超全系列教程文档--(62)使用rpicam-app通过网络流式传输视频
使用rpicam-app通过网络流式传输视频 使用 rpicam-app 通过网络流式传输视频UDPTCPRTSPlibavGStreamerRTPlibcamerasrc GStreamer 元素 文章来源: http://raspberry.dns8844.cn/documentation 原文网址 使用 rpicam-app 通过网络流式传输视频 本节介绍来自 rpica…...
R语言AI模型部署方案:精准离线运行详解
R语言AI模型部署方案:精准离线运行详解 一、项目概述 本文将构建一个完整的R语言AI部署解决方案,实现鸢尾花分类模型的训练、保存、离线部署和预测功能。核心特点: 100%离线运行能力自包含环境依赖生产级错误处理跨平台兼容性模型版本管理# 文件结构说明 Iris_AI_Deployme…...
MySQL 隔离级别:脏读、幻读及不可重复读的原理与示例
一、MySQL 隔离级别 MySQL 提供了四种隔离级别,用于控制事务之间的并发访问以及数据的可见性,不同隔离级别对脏读、幻读、不可重复读这几种并发数据问题有着不同的处理方式,具体如下: 隔离级别脏读不可重复读幻读性能特点及锁机制读未提交(READ UNCOMMITTED)允许出现允许…...

【快手拥抱开源】通过快手团队开源的 KwaiCoder-AutoThink-preview 解锁大语言模型的潜力
引言: 在人工智能快速发展的浪潮中,快手Kwaipilot团队推出的 KwaiCoder-AutoThink-preview 具有里程碑意义——这是首个公开的AutoThink大语言模型(LLM)。该模型代表着该领域的重大突破,通过独特方式融合思考与非思考…...

微信小程序 - 手机震动
一、界面 <button type"primary" bindtap"shortVibrate">短震动</button> <button type"primary" bindtap"longVibrate">长震动</button> 二、js逻辑代码 注:文档 https://developers.weixin.qq…...
拉力测试cuda pytorch 把 4070显卡拉满
import torch import timedef stress_test_gpu(matrix_size16384, duration300):"""对GPU进行压力测试,通过持续的矩阵乘法来最大化GPU利用率参数:matrix_size: 矩阵维度大小,增大可提高计算复杂度duration: 测试持续时间(秒&…...

LINUX 69 FTP 客服管理系统 man 5 /etc/vsftpd/vsftpd.conf
FTP 客服管理系统 实现kefu123登录,不允许匿名访问,kefu只能访问/data/kefu目录,不能查看其他目录 创建账号密码 useradd kefu echo 123|passwd -stdin kefu [rootcode caozx26420]# echo 123|passwd --stdin kefu 更改用户 kefu 的密码…...
Python+ZeroMQ实战:智能车辆状态监控与模拟模式自动切换
目录 关键点 技术实现1 技术实现2 摘要: 本文将介绍如何利用Python和ZeroMQ消息队列构建一个智能车辆状态监控系统。系统能够根据时间策略自动切换驾驶模式(自动驾驶、人工驾驶、远程驾驶、主动安全),并通过实时消息推送更新车…...
前端高频面试题2:浏览器/计算机网络
本专栏相关链接 前端高频面试题1:HTML/CSS 前端高频面试题2:浏览器/计算机网络 前端高频面试题3:JavaScript 1.什么是强缓存、协商缓存? 强缓存: 当浏览器请求资源时,首先检查本地缓存是否命中。如果命…...