在Ubuntu 18.04上安装和配置pgAdmin 4服务器模式的方法
前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。
简介
pgAdmin 是一个针对 PostgreSQL 及其相关数据库管理系统的开源管理和开发平台。它使用 Python 和 jQuery 编写,支持 PostgreSQL 中的所有功能。您可以使用 pgAdmin 从编写基本的 SQL 查询到监视数据库和配置高级数据库架构等各种操作。
在本教程中,我们将演示如何在 Ubuntu 18.04 服务器上安装和配置最新版本的 pgAdmin,通过 Web 浏览器访问 pgAdmin,并将其连接到服务器上的 PostgreSQL 数据库。
先决条件
要完成本教程,您需要:
- 运行 Ubuntu 18.04 的服务器。该服务器应具有一个具有 sudo 权限的非 root 用户,并配置了
ufw
防火墙。如果需要帮助设置,请参考我们的《Ubuntu 18.04 初始服务器设置指南》。 - 已安装并配置 Nginx 作为
http://unix:/tmp/pgadmin4.sock
的反向代理,按照《如何在 Ubuntu 22.04 上配置 Nginx 作为反向代理》中的第 1 和 2 步进行设置。 - 在服务器上安装了 PostgreSQL。您可以按照我们的《如何在 Ubuntu 18.04 上安装和使用 PostgreSQL》指南进行设置。在按照该指南操作时,务必创建一个新角色和数据库,因为您需要这两者来连接 pgAdmin 到您的 PostgreSQL 实例。
- 在服务器上安装了 Python 3 和
venv
。请按照《如何在 Ubuntu 18.04 服务器上安装 Python 3 并设置编程环境》安装这些工具并设置虚拟环境。
步骤 1 — 安装 pgAdmin 及其依赖项
截至本文撰写时,pgAdmin 的最新版本是 pgAdmin 4,而通过官方 Ubuntu 软件仓库提供的最新版本是 pgAdmin 3。尽管 pgAdmin 3 不再受支持,项目维护人员建议安装 pgAdmin 4。在本步骤中,我们将介绍在虚拟环境中安装最新版本的 pgAdmin 4(正如项目开发团队建议的),并使用 apt
安装其依赖项的过程。
首先,如果您最近没有更新过服务器的软件包索引,请更新:
sudo apt update
接下来,安装以下依赖项。这些包括 libgmp3-dev
,一个多精度算术库;libpq-dev
,其中包括与 PostgreSQL 后端通信的头文件和静态库:
sudo apt install libgmp3-dev libpq-dev
然后,创建一些目录,用于存储 pgAdmin 的会话数据、存储数据和日志:
sudo mkdir -p /var/lib/pgadmin4/sessions
sudo mkdir /var/lib/pgadmin4/storage
sudo mkdir /var/log/pgadmin4
接下来,将这些目录的所有权更改为您的非 root 用户和组。这是必要的,因为当前这些目录的所有者是您的 root 用户,但我们将从您的非 root 用户拥有的虚拟环境中安装 pgAdmin,并且安装过程中会在这些目录中创建一些文件。但在安装完成后,我们将把所有权更改为 www-data 用户和组,以便可以提供给 Web:
sudo chown -R sammy:sammy /var/lib/pgadmin4
sudo chown -R sammy:sammy /var/log/pgadmin4
接下来,打开您的虚拟环境。转到您的编程环境所在的目录并激活它。按照先决条件 Python 3 教程的命名约定,我们将转到 environments
目录并激活 my_env
环境:
cd environments/
source my_env/bin/activate
激活虚拟环境后,最好确保您的系统上安装了最新版本的 pip
。默认 Ubuntu 18.04 软件仓库中提供的 pip
版本是 9.0.1,而最新版本是 21.0.1。如果您按照先决条件 Python 安装教程中的步骤安装了 python3-pip
包,但尚未将其升级到最新版本,那么在下一步配置 pgAdmin 时将会遇到问题。
要将 pip
升级到最新版本,请运行以下命令:
python -m pip install -U pip
接下来,将 pgAdmin 4 源代码下载到您的计算机上。要找到最新版本的源代码,请转到 pgAdmin 4(Python Wheel)下载页面。单击最新版本(本文撰写时为 v6.10),然后在下一页单击pip的链接。从文件浏览器页面,复制以 .whl
结尾的文件链接,这是 Python 发行版中使用的标准构建包格式。然后返回到您的终端并运行以下 wget
命令,确保用您从 PostgreSQL 网站复制的链接替换,以将 .whl
文件下载到您的服务器:
wget https://ftp.postgresql.org/pub/pgadmin/pgadmin4/v6.10/pip/pgadmin4-6.10-py3-none-any.whl
接下来,使用以下命令安装 wheel
包,这是 wheel 打包标准的参考实现。作为 Python 库,该包用作构建 wheel 的扩展,并包括用于处理 .whl
文件的命令行工具:
python -m pip install wheel
然后使用以下命令安装 pgAdmin 4 包:
python -m pip install pgadmin4-6.10-py3-none-any.whl
接下来,安装 Gunicorn,这是一个 Python WSGI 服务器,将在本教程后面与 Nginx 一起用于提供 pgadmin
Web 接口:
python -m pip install gunicorn
这样就完成了安装 pgAdmin 及其依赖项。但在将其连接到数据库之前,您需要对程序的配置进行一些更改。
步骤 2 — 配置 pgAdmin 4
虽然 pgAdmin 已经安装在您的服务器上,但仍然有一些步骤需要进行,以确保它具有所需的权限和配置,以便正确提供 Web 接口。
pgAdmin 的主配置文件 config.py
在任何其他配置文件之前被读取。它的内容可以用作进一步配置设置的参考点,这些设置可以在 pgAdmin 的其他配置文件中指定,但为了避免意外错误,您不应该直接编辑 config.py
文件。我们将向一个新文件添加一些配置更改,命名为 config_local.py
,该文件将在主配置文件之后被读取。
现在使用您喜欢的文本编辑器创建此文件。在这里,我们将使用 nano
:
nano my_env/lib/python3.10/site-packages/pgadmin4/config_local.py
在您的编辑器中,添加以下内容:
LOG_FILE = '/var/log/pgadmin4/pgadmin4.log'
SQLITE_PATH = '/var/lib/pgadmin4/pgadmin4.db'
SESSION_DB_PATH = '/var/lib/pgadmin4/sessions'
STORAGE_DIR = '/var/lib/pgadmin4/storage'
SERVER_MODE = True
这里是这五个指令的作用:
LOG_FILE
:定义了 pgAdmin 日志将存储的文件。SQLITE_PATH
:pgAdmin 将用户相关数据存储在一个 SQLite 数据库中,该指令将 pgAdmin 软件指向此配置数据库。由于此文件位于持久目录/var/lib/pgadmin4/
下,因此在升级后不会丢失用户数据。SESSION_DB_PATH
:指定用于存储会话数据的目录。STORAGE_DIR
:定义了 pgAdmin 将存储其他数据(如备份和安全证书)的位置。SERVER_MODE
:将此指令设置为True
告诉 pgAdmin 以服务器模式运行,而不是桌面模式。
请注意,每个文件路径都指向您在步骤 1 中创建的目录。
添加这些行后,保存并关闭文件。如果您使用的是 nano
,请按 CTRL + X
,然后按 Y
,最后按 ENTER
。
配置完成后,运行 pgAdmin 设置脚本以设置您的登录凭据:
python my_env/lib/python3.10/site-packages/pgadmin4/setup.py
运行此命令后,您将看到一个提示,询问您的电子邮件地址和密码。这将作为您以后访问 pgAdmin 时的登录凭据,因此请务必记住或记下您在此输入的内容:
. . .
输入用于初始 pgAdmin 用户帐户的电子邮件地址和密码:电子邮件地址:sammy@example.com
密码:
重新输入密码:
至此,pgAdmin 已经完全配置好。但是,该程序尚未从您的服务器上提供服务,因此无法访问。为了解决这个问题,我们将配置 Gunicorn 和 Nginx 来提供 pgAdmin,以便您可以通过 Web 浏览器访问其用户界面。
步骤 3 — 启动 Gunicorn 并配置 Nginx
您将使用 Gunicorn 作为 Web 应用程序来提供 pgAdmin。但是,作为应用程序服务器,Gunicorn 只能在本地访问,无法通过互联网访问。为了使其可以远程访问,您需要使用 Nginx 作为反向代理。
完成设置 Nginx 作为反向代理的先决条件后,您的 Nginx 配置文件将包含以下内容:
server {listen 80;listen [::]:80;server_name your_domain www.your_domain;location / {proxy_pass http://unix:/tmp/pgadmin4.sock;include proxy_params;}
}
这个反向代理配置使您的 Gunicorn 服务器可以在本地浏览器中访问。使用以下命令启动您的 Gunicorn 服务器与 pgAdmin 应用程序:
gunicorn --bind unix:/tmp/pgadmin4.sock --workers=1 --threads=25 --chdir ~/environments/my_env/lib/python3.10/site-packages/pgadmin4 pgAdmin4:app
[2022-08-29 00:19:11 +0000] [7134] [INFO] Starting gunicorn 20.1.0
[2022-08-29 00:19:11 +0000] [7134] [INFO] Listening at: unix:/tmp/pgadmin4.sock (7134)
[2022-08-29 00:19:11 +0000] [7134] [INFO] Using worker: gthread
[2022-08-29 00:19:11 +0000] [7135] [INFO] Booting worker with pid: 7135
通过 Gunicorn 作为应用程序服务器并通过您的 Nginx 反向代理进行访问,您现在可以在 Web 浏览器中访问 pgAdmin 了。
步骤 4 — 访问 pgAdmin
在本地机器上,打开你喜欢的网络浏览器,然后输入你服务器的 IP 地址:
http://your_server_ip
输入后,会出现一个类似下面的登录界面:
!pgAdmin 登录界面
输入在第 2 步中定义的登录凭据,然后你将进入 pgAdmin 欢迎界面:
!pgAdmin 欢迎页面
现在你已经确认可以访问 pgAdmin 界面,剩下的就是将 pgAdmin 连接到你的 PostgreSQL 数据库。不过,在这之前,你需要对你的 PostgreSQL 超级用户进行一些微小的配置。
步骤 5 — 配置你的 PostgreSQL 用户
如果你按照先决条件 PostgreSQL 教程进行了操作,那么你应该已经在服务器上安装了 PostgreSQL,并设置了一个新的超级用户角色和数据库。
在 PostgreSQL 中,默认情况下,你使用“身份验证协议”或“ident”身份验证方法来认证数据库用户。这意味着 PostgreSQL 会获取客户端的 Ubuntu 用户名,并将其用作允许的数据库用户名。在许多情况下,这可以提供更高的安全性,但也可能在你希望外部程序(如 pgAdmin)连接到你的数据库时出现问题。为了解决这个问题,我们将为这个 PostgreSQL 角色设置一个密码,这样 pgAdmin 就可以连接到你的数据库了。
从你的终端,以超级用户角色打开 PostgreSQL 提示符:
sudo -u sammy psql
在 PostgreSQL 提示符下,更新用户配置,设置一个你选择的强密码:
ALTER USER sammy PASSWORD 'password';
然后退出 PostgreSQL 提示符:
\q
接下来,回到你的浏览器中的 pgAdmin 4 界面,找到左侧的 Browser 菜单。右键单击 Servers 以打开上下文菜单,将鼠标悬停在 Create 上,然后单击 Server…。
!创建服务器上下文菜单
这将在你的浏览器中弹出一个窗口,在其中你将输入有关你的服务器、角色和数据库的信息。
在 General 选项卡中,输入此服务器的名称。这可以是任何你喜欢的名称,但最好是一些描述性的内容。在我们的示例中,服务器的名称是 Sammy-server-1
。
!创建服务器 - General 选项卡
接下来,点击 Connection 选项卡。在 Host name/address 字段中,输入 localhost
。Port 应该默认设置为 5432
,这对于这个设置来说是有效的,因为这是 PostgreSQL 使用的默认端口。
在 Maintenance database 字段中,输入你想要连接的数据库的名称。请注意,这个数据库必须已经在你的服务器上创建好。然后,在 Username 和 Password 字段中,分别输入你之前配置的 PostgreSQL 用户名和密码。
!创建服务器 - Connection 选项卡
其他选项卡中的空字段是可选的,只有在你有特定设置需要时才需要填写它们。点击 Save 按钮,数据库将出现在 Browser 菜单下的 Servers 中。
你已成功将 pgAdmin4 连接到你的 PostgreSQL 数据库。你可以在 pgAdmin 仪表板上执行几乎任何你在 PostgreSQL 提示符上可以执行的操作。为了说明这一点,我们将通过 Web 界面创建一个示例表,并向其中填充一些示例数据。
步骤 6 — 在 pgAdmin 仪表板中创建表
从 pgAdmin 仪表板中,找到窗口左侧的 Browser 菜单。单击 Servers (1) 旁边的加号(+)以展开其中的树形菜单。接下来,单击上一步中添加的服务器(在我们的示例中为 Sammy-server-1)左侧的加号,然后展开 Databases、你添加的数据库的名称(在我们的示例中为 sammy),然后展开 Schemas (1)。你应该会看到如下所示的树形菜单:
!展开的 Browser 树形菜单
右键单击 Tables,然后将鼠标悬停在 Create 上,单击 Table…。
!创建表上下文菜单
这将打开一个 Create-Table 窗口。在这个窗口的 General 选项卡下,为表输入一个名称。这可以是任何你喜欢的名称,但为了简单起见,我们将其称为 table-01。
!创建表 - General 选项卡
然后转到 Columns 选项卡,并单击窗口右上角的加号(+)以添加一些列。在添加列时,你需要为其指定一个 Name 和一个 Data type,如果数据类型要求,你可能还需要选择一个 Length。
此外,官方的 PostgreSQL 文档指出,向表添加主键通常是最佳实践。主键 是一个约束,指示可以用作表中行的特殊标识符的特定列或列集。这不是必需的,但如果你想将一个或多个列设置为主键,可以将右侧的开关从 No 切换到 Yes。
点击 Save 按钮以创建表。
!创建表 - 打开主键的 Columns 选项卡
到目前为止,你已经创建了一个表,并向其中添加了一些列。不过,这些列还没有包含任何数据。要向新表添加数据,右键单击 Browser 菜单中表的名称,将鼠标悬停在 Scripts 上,然后单击 INSERT Script。
!INSERT 脚本上下文菜单
这将在仪表板上打开一个新面板。在顶部,你将看到一个部分填充的 INSERT
语句,其中包含适当的表和列名称。请用一些虚拟数据替换问号(?),确保你添加的数据与你为每列选择的数据类型相匹配。请注意,你还可以通过在新的括号组中添加每行来添加多行数据,每组括号之间用逗号分隔,如下例所示。
如果愿意,可以用以下示例 INSERT
语句替换部分填充的 INSERT
脚本:
INSERT INTO public."table-01"(col1, col2, col3)VALUES ('Juneau', 14, 337), ('Bismark', 90, 2334), ('Lansing', 51, 556);
!示例 INSERT 语句
点击侧向三角形图标(▶)以执行 INSERT
语句。请注意,在较旧版本的 pgAdmin 中,执行图标是一个闪电图标(⚡)。
要查看表和其中的所有数据,再次右键单击 Browser 菜单中你的表的名称,将鼠标悬停在 View/Edit Data 上,然后选择 All Rows。
!查看/编辑数据,所有行上下文菜单
这将在仪表板上打开另一个新面板,在下面的 Data Output 选项卡中,你可以查看表中保存的所有数据。
!查看数据 - 示例数据输出
到此为止,你已成功通过 pgAdmin Web 界面创建了一个表,并向其中填充了一些数据。当然,这只是你可以使用 pgAdmin 创建表的一种方法。例如,你也可以使用 SQL 而不是本步骤中描述的基于 GUI 的方法来创建和填充表。
结论
在本指南中,您学习了如何从 Python 虚拟环境安装 pgAdmin 4,配置它,使用 Gunicorn 和 Nginx 将其提供给 Web,并且如何将其连接到 PostgreSQL 数据库。此外,本指南还介绍了一种用于创建和填充表的方法,但 pgAdmin 不仅仅可以用于创建和编辑表格。
要了解如何充分利用 pgAdmin 的所有功能,我们鼓励您查阅该项目的文档。您也可以通过我们社区关于 PostgreSQL 的教程了解更多信息。
相关文章:
在Ubuntu 18.04上安装和配置pgAdmin 4服务器模式的方法
前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。 简介 pgAdmin 是一个针对 PostgreSQL 及其相关数据库管理系统的开源管理和开发平台。它使用 Python 和 jQuery 编写,支持 P…...

NiFi :1 初识这把“十年一剑”的利器
--->更多内容,请移步“鲁班秘笈”!!<--- “现在AI和数据处理密不可分,80%的企业可以利用Apache NiFi轻松解决复杂的数据问题,快速完成场景建设。犹如花上百来块钱在家享受一顿不亚于五星级西餐厅的法式大餐。对…...

Pyside6实战教程专栏目录
Pyside6实战教程🚀 专栏目录介绍 本专栏将详细地向Python开发者展示如何利用PySide6框架创建功能丰富的桌面应用程序。无论你是刚刚接触GUI编程的新手,还是希望快速提升自己技能水平的进阶用户,本文都将为你提供一系列简单易懂的教程…...
【Dash】使用 Dash Design Kit (DDK) 创建图表
一、Styling Your App The examples in the previous section used Dash HTML Components to build a simple app layout, but you can style your app to look more professional. This section will give a brief overview of the multiple tools that you can use to enhan…...

C++ 几何算法 - 向量点乘,叉乘及其应用
一:点乘介绍 1. 向量点乘: 2. 向量点乘的性质: 3. 向量点乘公式: 4. 向量的点乘的属性: (1):向量与自身做点乘,会得到向量长度的平方: (2…...

Taro学习记录(具体项目实践)
一、安装taro-cli 二、项目文件 三、项目搭建 1、Eslint配置 在项目生成的 .eslintrc 中进行配置 {"extends": ["taro/react"], //一个配置文件,可以被基础配置中的已启用的规则继承"parser": "babel/eslint-parser…...

ICML 2024 | 矛与盾的较量!北大提出提示无关数据防御保护算法PID
文章链接:https://arxiv.org/pdf/2406.15305 代码地址:https://github.com/PKU-ML/Diffusion-PID-Protection 亮点直击 本文在实证观察中发现,保护阶段和利用阶段之间的提示不匹配可能会削弱当前数据保护算法的有效性。本文深入探讨了利用LDM…...
Oracle聚合函数LISTAGG和WM_CONCAT简介
目录 Oracle聚合函数LISTAGG和WM_CONCAT简介LISTAGG 函数1.语法2.示例3.去除重复值 WM_CONCAT 函数1.语法2.示例3.去除重复值 比较1.性能2.排序与分隔符3.去除重复值 Oracle聚合函数LISTAGG和WM_CONCAT简介 在处理数据库中的数据聚合任务时,我们经常需要将多行数据…...
【Unity】多种寻路算法实现 —— BFS,DFS,Dijkstra,A*
本实验寻路算法均基于网格实现,整体称呼为Grid,单个瓦片称之为Tile 考虑程序处理的简洁性,所有算法使用同一种Tile,且权值点,A*所需的记录数值也全部放在Tile中记录 前排贴上代码仓库链接: GitHub - Sir…...

十大游戏设计软件:创意实现的利器
在数字娱乐的多彩世界里,游戏设计无疑是一项充满创意与技术挑战的艺术。随着技术的进步,游戏设计师的手中拥有了一系列强大的工具,它们让想象中的世界得以呈现,让玩家的体验更加丰富和真实。本文将带你走进游戏设计的幕后…...

Pandas高级操作:多级索引、窗口函数、数据透视表等
在数据处理和分析中,pandas库提供了强大的功能,支持从简单到复杂的数据操作。本文将介绍一些pandas的高级操作,包括多级索引(MultiIndex)、窗口函数(Window Functions)、数据透视表与复杂聚合、数据合并与连接、高级数据变换以及时间序列数据的高级处理。 1. 多级索引(…...

mysql源码编译启动debug
对于没有C语言基础的同学来说,想看看源码,在搞定编辑器做debug的时候就被劝退了,发生点啥了,完全看不懂,不知道从哪里入手去做debug;我为了看看 mysql 的 insert buffer 到底存的是索引页还是数据页&#x…...

吴恩达机器学习-C1W3L2-逻辑回归之S型函数
可选实验:逻辑回归 在这个不评分的实验中,你会 探索sigmoid函数(也称为logistic函数)探索逻辑回归;哪个用到了s型函数 import numpy as np %matplotlib widget import matplotlib.pyplot as plt from plt_one_addpt_onclick import plt_one_addpt_onclick from l…...

P-one新增火焰图-为性能测试开启新视野
随着软件业务流程的日益复杂,传统的性能测试方法已经难以满足对性能问题精准定位的需求。测试人员需要一种更加直观、全面的方式来分析软件在运行过程中的性能表现,以便快速准确地找到性能瓶颈并进行优化。因此,我们在性能测试平台P-One中加入…...

CTF-web基础 TCP/UDP协议
传输层协议由TCP/UDP协议组成,来控制信息的传输,二者有什么区别呢,TCP比较靠谱,但是UDP速度比较快一点。 TCP协议 Transmission Control protocol, 三次握手:先给服务器传输询问要发消息,然后…...
sql常用语法总结
SQL(Structured Query Language,结构化查询语言)是一种用于管理和操作关系数据库的标准编程语言。本文用来记录一些接触到的sql语句,随着学习不断进行更新: 选择数据 - SELECT 语句用于从数据库表中检索数据。 SELECT column1, column2 FROM table_name;插入数据 - INSERT…...
实验八 题目描述 从键盘上输入任意一个整数(正负数皆可),判断该整数的绝对值是否为回文数。
实验八 题目描述 从键盘上输入任意一个整数(正负数皆可),判断该整数的绝对值是否为回文数。[提示:取数的绝对值,然后使用用循环语句从该绝对值的末位开始至最高位,重新构造一个数,…...
IsaacLab | Workflow 中 rsl_rl 的 play.py 脚本精读
如是我闻: 在用IsaacLab 做强化学习实验时,回顾已训练好的模型需要调用workflow中的play.py脚本,以下是对rsl_rl的play.py脚本的逐行精读。 1. 版权声明和文件描述 # Copyright (c) 2022-2024, The Isaac Lab Project Developers. # All ri…...
PYTHON专题-(8)我错了该怎么整?
什么是异常处理? 异常处理是一种机制,用于在程序执行期间发生错误或异常时,对发生的异常进行捕获、处理和恢复,以确保程序能够继续执行或正确地终止。异常处理可以包括捕获异常、处理异常,以及执行相应的操作来处理异常…...
【自然资源】设施农业用地的学习梳理
【自然资源】设施农业用地的学习梳理 什么是设施农业用地? 2019年12月17日,自然资源部 、农业农村部印发的《关于设施农业用地管理有关问题的通知》规定:设施农业用地包括农业生产中直接用于作物种植和畜禽水产养殖的设施用地。其中&#x…...
脑机新手指南(八):OpenBCI_GUI:从环境搭建到数据可视化(下)
一、数据处理与分析实战 (一)实时滤波与参数调整 基础滤波操作 60Hz 工频滤波:勾选界面右侧 “60Hz” 复选框,可有效抑制电网干扰(适用于北美地区,欧洲用户可调整为 50Hz)。 平滑处理&…...
Java如何权衡是使用无序的数组还是有序的数组
在 Java 中,选择有序数组还是无序数组取决于具体场景的性能需求与操作特点。以下是关键权衡因素及决策指南: ⚖️ 核心权衡维度 维度有序数组无序数组查询性能二分查找 O(log n) ✅线性扫描 O(n) ❌插入/删除需移位维护顺序 O(n) ❌直接操作尾部 O(1) ✅内存开销与无序数组相…...

Swift 协议扩展精进之路:解决 CoreData 托管实体子类的类型不匹配问题(下)
概述 在 Swift 开发语言中,各位秃头小码农们可以充分利用语法本身所带来的便利去劈荆斩棘。我们还可以恣意利用泛型、协议关联类型和协议扩展来进一步简化和优化我们复杂的代码需求。 不过,在涉及到多个子类派生于基类进行多态模拟的场景下,…...
电脑插入多块移动硬盘后经常出现卡顿和蓝屏
当电脑在插入多块移动硬盘后频繁出现卡顿和蓝屏问题时,可能涉及硬件资源冲突、驱动兼容性、供电不足或系统设置等多方面原因。以下是逐步排查和解决方案: 1. 检查电源供电问题 问题原因:多块移动硬盘同时运行可能导致USB接口供电不足&#x…...
linux 错误码总结
1,错误码的概念与作用 在Linux系统中,错误码是系统调用或库函数在执行失败时返回的特定数值,用于指示具体的错误类型。这些错误码通过全局变量errno来存储和传递,errno由操作系统维护,保存最近一次发生的错误信息。值得注意的是,errno的值在每次系统调用或函数调用失败时…...
相机Camera日志分析之三十一:高通Camx HAL十种流程基础分析关键字汇总(后续持续更新中)
【关注我,后续持续新增专题博文,谢谢!!!】 上一篇我们讲了:有对最普通的场景进行各个日志注释讲解,但相机场景太多,日志差异也巨大。后面将展示各种场景下的日志。 通过notepad++打开场景下的日志,通过下列分类关键字搜索,即可清晰的分析不同场景的相机运行流程差异…...

前端开发面试题总结-JavaScript篇(一)
文章目录 JavaScript高频问答一、作用域与闭包1.什么是闭包(Closure)?闭包有什么应用场景和潜在问题?2.解释 JavaScript 的作用域链(Scope Chain) 二、原型与继承3.原型链是什么?如何实现继承&a…...
Java线上CPU飙高问题排查全指南
一、引言 在Java应用的线上运行环境中,CPU飙高是一个常见且棘手的性能问题。当系统出现CPU飙高时,通常会导致应用响应缓慢,甚至服务不可用,严重影响用户体验和业务运行。因此,掌握一套科学有效的CPU飙高问题排查方法&…...

echarts使用graphic强行给图增加一个边框(边框根据自己的图形大小设置)- 适用于无法使用dom的样式
pdf-lib https://blog.csdn.net/Shi_haoliu/article/details/148157624?spm1001.2014.3001.5501 为了完成在pdf中导出echarts图,如果边框加在dom上面,pdf-lib导出svg的时候并不会导出边框,所以只能在echarts图上面加边框 grid的边框是在图里…...

PydanticAI快速入门示例
参考链接:https://ai.pydantic.dev/#why-use-pydanticai 示例代码 from pydantic_ai import Agent from pydantic_ai.models.openai import OpenAIModel from pydantic_ai.providers.openai import OpenAIProvider# 配置使用阿里云通义千问模型 model OpenAIMode…...