跳转到主要内容

标签(标签)

资源精选(342) Go开发(108) Go语言(103) Go(99) angular(82) LLM(75) 大语言模型(63) 人工智能(53) 前端开发(50) LangChain(43) golang(43) 机器学习(39) Go工程师(38) Go程序员(38) Go开发者(36) React(33) Go基础(29) Python(24) Vue(22) Web开发(20) Web技术(19) 精选资源(19) 深度学习(19) Java(18) ChatGTP(17) Cookie(16) android(16) 前端框架(13) JavaScript(13) Next.js(12) 安卓(11) typescript(10) 资料精选(10) NLP(10) 第三方Cookie(9) Redwoodjs(9) LLMOps(9) Go语言中级开发(9) 自然语言处理(9) 聊天机器人(9) PostgreSQL(9) 区块链(9) mlops(9) 安全(9) 全栈开发(8) ChatGPT(8) OpenAI(8) Linux(8) AI(8) GraphQL(8) iOS(8) 软件架构(7) Go语言高级开发(7) AWS(7) C++(7) 数据科学(7) whisper(6) Prisma(6) 隐私保护(6) RAG(6) JSON(6) DevOps(6) 数据可视化(6) wasm(6) 计算机视觉(6) 算法(6) Rust(6) 微服务(6) 隐私沙盒(5) FedCM(5) 语音识别(5) Angular开发(5) 快速应用开发(5) 提示工程(5) Agent(5) LLaMA(5) 低代码开发(5) Go测试(5) gorm(5) REST API(5) 推荐系统(5) WebAssembly(5) GameDev(5) CMS(5) CSS(5) machine-learning(5) 机器人(5) 游戏开发(5) Blockchain(5) Web安全(5) Kotlin(5) 低代码平台(5) 机器学习资源(5) Go资源(5) Nodejs(5) PHP(5) Swift(5) 智能体(4) devin(4) Blitz(4) javascript框架(4) Redwood(4) GDPR(4) 生成式人工智能(4) Angular16(4) Alpaca(4) SAML(4) JWT(4) JSON处理(4) Go并发(4) kafka(4) 移动开发(4) 移动应用(4) security(4) 隐私(4) spring-boot(4) 物联网(4) nextjs(4) 网络安全(4) API(4) Ruby(4) 信息安全(4) flutter(4) 专家智能体(3) Chrome(3) CHIPS(3) 3PC(3) SSE(3) 人工智能软件工程师(3) LLM Agent(3) Remix(3) Ubuntu(3) GPT4All(3) 软件开发(3) 问答系统(3) 开发工具(3) 最佳实践(3) RxJS(3) SSR(3) Node.js(3) Dolly(3) 移动应用开发(3) 编程语言(3) 低代码(3) IAM(3) Web框架(3) CORS(3) 基准测试(3) Go语言数据库开发(3) Oauth2(3) 并发(3) 主题(3) Theme(3) earth(3) nginx(3) 软件工程(3) azure(3) keycloak(3) 生产力工具(3) gpt3(3) 工作流(3) C(3) jupyter(3) 认证(3) prometheus(3) GAN(3) Spring(3) 逆向工程(3) 应用安全(3) Docker(3) Django(3) R(3) .NET(3) 大数据(3) Hacking(3) 渗透测试(3) C++资源(3) Mac(3) 微信小程序(3) Python资源(3) JHipster(3) 大型语言模型(2) 语言模型(2) 可穿戴设备(2) JDK(2) SQL(2) Apache(2) Hashicorp Vault(2) Spring Cloud Vault(2) Go语言Web开发(2) Go测试工程师(2) WebSocket(2) 容器化(2) AES(2) 加密(2) 输入验证(2) ORM(2) Fiber(2) Postgres(2) Gorilla Mux(2) Go数据库开发(2) 模块(2) 泛型(2) 指针(2) HTTP(2) PostgreSQL开发(2) Vault(2) K8s(2) Spring boot(2) R语言(2) 深度学习资源(2) 半监督学习(2) semi-supervised-learning(2) architecture(2) 普罗米修斯(2) 嵌入模型(2) productivity(2) 编码(2) Qt(2) 前端(2) Rust语言(2) NeRF(2) 神经辐射场(2) 元宇宙(2) CPP(2) 数据分析(2) spark(2) 流处理(2) Ionic(2) 人体姿势估计(2) human-pose-estimation(2) 视频处理(2) deep-learning(2) kotlin语言(2) kotlin开发(2) burp(2) Chatbot(2) npm(2) quantum(2) OCR(2) 游戏(2) game(2) 内容管理系统(2) MySQL(2) python-books(2) pentest(2) opengl(2) IDE(2) 漏洞赏金(2) Web(2) 知识图谱(2) PyTorch(2) 数据库(2) reverse-engineering(2) 数据工程(2) swift开发(2) rest(2) robotics(2) ios-animation(2) 知识蒸馏(2) 安卓开发(2) nestjs(2) solidity(2) 爬虫(2) 面试(2) 容器(2) C++精选(2) 人工智能资源(2) Machine Learning(2) 备忘单(2) 编程书籍(2) angular资源(2) 速查表(2) cheatsheets(2) SecOps(2) mlops资源(2) R资源(2) DDD(2) 架构设计模式(2) 量化(2) Hacking资源(2) 强化学习(2) flask(2) 设计(2) 性能(2) Sysadmin(2) 系统管理员(2) Java资源(2) 机器学习精选(2) android资源(2) android-UI(2) Mac资源(2) iOS资源(2) Vue资源(2) flutter资源(2) JavaScript精选(2) JavaScript资源(2) Rust开发(2) deeplearning(2) RAD(2)

category

介绍

PostgreSQL或Postgres是一个关系数据库管理系统,提供SQL查询语言的实现。它符合标准,具有许多高级功能,如可靠的事务和无读锁的并发性。

本指南演示了如何在Ubuntu 20.04服务器上快速启动和运行Postgres,从安装PostgreSQL到设置新用户和数据库。如果你更喜欢关于安装和管理PostgreSQL数据库的更深入的教程,请参阅如何在Ubuntu 20.04上安装和使用PostgreSQL。

使用DigitalOcean托管数据库简化PostgreSQL数据库的创建。几分钟内创建一个Postgres数据库,让DigitalOcean处理数据迁移、升级、维护和安全。

 

先决条件

要遵循本教程,您将需要一台Ubuntu 20.04服务器,该服务器已按照我们的Ubuntu 20.04初始服务器设置指南进行配置。完成本必备教程后,您的服务器应具有具有sudo权限的非root用户和基本防火墙。

步骤1——安装PostgreSQL

要安装PostgreSQL,首先刷新服务器的本地包索引:

  • sudo apt update

然后,安装Postgres包以及一个-concontib包,该包添加了一些额外的实用程序和功能:

  • sudo apt install postgresql postgresql-contrib

 

确保服务已启动:

  • sudo systemctl start postgresql.service

 

步骤2——使用PostgreSQL角色和数据库

默认情况下,Postgres使用一个名为“角色”的概念来处理身份验证和授权。在某些方面,这些用户和组类似于普通Unix风格的用户和组。

安装后,Postgres被设置为使用ident身份验证,这意味着它将Postgres角色与匹配的Unix/Linux系统帐户相关联。如果Postgres中存在角色,则具有相同名称的Unix/Linux用户名可以作为该角色登录。

安装过程创建了一个名为postgres的用户帐户,该帐户与默认的postgres角色相关联。有几种方法可以利用这个帐户访问Postgres。一种方法是通过运行以下命令切换到服务器上的postgres帐户:  

  • sudo -i -u postgres


然后,您可以通过运行以下命令访问Postgres提示符:

  • psql


这将使您登录到PostgreSQL提示符,从这里您可以立即自由地与数据库管理系统交互。

要退出PostgreSQL提示,请运行以下操作:

  • \q

这将使您返回到postgres Linux命令提示符。要返回到常规系统用户,请运行exit命令:

  • exit

连接到Postgres提示符的另一种方法是直接使用sudo作为Postgres帐户运行psql命令:

  1. sudo -u postgres psql

这将使您直接登录到Postgres,而不需要中间的bash-shell。

同样,您可以通过运行以下程序退出交互式Postgres会话:

  • \q

第3步——创建新角色

如果您是以postgres帐户登录的,则可以通过运行以下命令创建新角色:

  • createuser --interactive

相反,如果您更喜欢在不从普通帐户切换的情况下对每个命令使用sudo,请运行:

  • sudo -u postgres createuser --interactive

无论哪种方式,脚本都会提示您做出一些选择,并根据您的响应,执行正确的Postgres命令,根据您的规范创建用户。

Output

Enter name of role to add: sammy Shall the new role be a superuser? (y/n) y

步骤4——创建新数据库

Postgres身份验证系统默认情况下做出的另一个假设是,对于用于登录的任何角色,该角色都将拥有一个可以访问的同名数据库。

这意味着,如果您在上一节中创建的用户名为sammy,则该角色将尝试连接到默认情况下也称为“sammy”的数据库。您可以使用createdb命令创建适当的数据库。

如果您是以postgres帐户登录的,您需要键入以下内容:

  • createdb sammy

相反,如果您更喜欢在不从正常帐户切换的情况下对每个命令使用sudo,则可以运行:

  • sudo -u postgres createdb sammy

步骤5——打开具有新角色的Postgres提示

要使用基于ident的身份验证登录,您需要一个与您的Postgres角色和数据库同名的Linux用户。

如果没有匹配的Linux用户,可以使用adduser命令创建一个。您必须从具有sudo权限的非root帐户(即不以postgres用户身份登录)执行此操作:

  • sudo adduser sammy

一旦此新帐户可用,您可以通过运行以下操作切换并连接到数据库:

  • sudo -i -u sammy
  • psql

或者,您可以内联执行此操作:

  • sudo -u sammy psql

假设所有组件都已正确配置,此命令将自动登录。

如果希望用户连接到其他数据库,可以通过如下方式指定数据库来实现:

  • psql -d postgres

登录后,您可以通过运行以下程序来检查当前连接信息:

  • \conninfo
Output

You are connected to database "sammy" as user "sammy" via socket in "/var/run/postgresql" at port "5432".

结论

现在,您已经在Ubuntu 20.04服务器上安装了PostgreSQL。如果您想了解更多关于Postgres的信息以及如何使用它,我们鼓励您查看以下指南:

  • 关系数据库管理系统的比较
  • 练习使用SQL运行查询
文章链接