AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 501312
Accepted
Avihai Marchiano
Avihai Marchiano
Asked: 2013-04-22 03:39:07 +0800 CST2013-04-22 03:39:07 +0800 CST 2013-04-22 03:39:07 +0800 CST

SSH 直接标准输入和粗壮进出 postgres 客户端

  • 772

我的本地可以连接到远程,但无法连接到数据库服务器。远程可以连接到 dbserver(使用 psql)。

我想从本地针对数据库运行 sql 脚本。

我正在寻找一种在远程打开 psql 并使用 ssh 将我的 stdin 和 stdout 定向到本地的方法。

现在在愚蠢的选择中我这样做:

ssh remote
psql -h db report
password
run my commands

我可以用这种方式在脚本中完成,但它的丑陋和 dosnt 允许我与 psql 进行交互式会话。

PSQL="PGPASSWORD=mypassword psql -h dbserver  -d report"
SQL="SELECT 1"
ssh remote "$PSQL --command 'COPY ($SQL) TO STDOUT WITH CSV;'"

Ps- Python 也可以。

ssh
  • 2 2 个回答
  • 4339 Views

2 个回答

  • Voted
  1. Best Answer
    Craig Ringer
    2013-04-22T05:26:44+08:002013-04-22T05:26:44+08:00

    使用带有后台无命令 ssh 会话的 ssh 端口转发:

    $ ssh -N -f -L 5433:localhost:5432 remoteserver
    

    然后你可以使用:

    $ psql -h localhost -p 5433
    

    psql\o、等命令\i将引用本地计算机上的文件。

    如果您出于脚本目的而尝试执行此操作,那么您可能希望使用 ssh 的-n选项和无密码的 ssh 密钥,其中设置了选项authorized_keys以防止生成 shell,因此您所能做的就是转发给定端口。这对于使用无密码密钥时的安全性非常重要。ssh-agent提供了一种更安全的替代方案,但它对于脚本编写来说比较笨拙。请记住,您的脚本需要记录它生成的后台 ssh 会话的进程 ID,并在任务结束时将其终止。有时使用 shell 作业控制比 ssh 自己的守护进程模式更容易;这样 shell 就会跟踪以 为背景的进程,&并且可以用 终止它kill %jobid。请参阅bash 作业控制. (您需要将端口转发 ssh 会话置于后台,以便脚本的执行可以继续并运行psql)。

    对于交互式使用,您只需调用远程psqlover ssh,在这种情况下,诸如\o, \i,\copy等命令将引用您 ssh 到的服务器的本地文件,而不是您的本地计算机:

    $ ssh remoteserver psql
    

    这也适用于脚本目的,但比端口转发安全性稍差,因为psql它是一个非常强大的程序,允许您读取和写入任意文件、生成 shell 等。您不能真正限制无密码 ssh 密钥可以做什么如果允许远程调用psql. 另一方面,写起来要简单得多:

    ssh remoteserver psql <<'__END__'
    BEGIN;
    INSERT INTO blah(a,b,c) VALUES (1,2,3);
    UPDATE otherblah SET x = 99, y = 912;
    COMMIT;
    __END__
    

    而不是处理后台 ssh 会话。实际上,这取决于您的优先事项。

    • 5
  2. Khaled
    2013-04-22T03:54:48+08:002013-04-22T03:54:48+08:00

    您可以在远程计算机上使用 iptables 将 postgresql 流量重定向到数据库服务器。例如:

    iptables -A PREROUTING -s your_machine_ip -p tcp --dport 5432 -j DNAT --to-destination db_server_ip
    

    当然,这需要远程机器的管理员权限。您还需要启用 IP 转发。

    从您的机器上,您只需连接到远程机器,它就会将您重定向到数据库服务器。这样您就不需要显示的 ssh 连接。

    请注意,您可能需要查看有关如何连接到数据库系统的安全问题,尤其是当您通过不受信任的网络远程执行此操作时。

    • 0

相关问题

  • 如何最好地设置 ssh 隧道以访问远程网络 (Linux)

  • SSH 和重定向

  • 通过 SSH 会话使用 NET USER 命令拒绝访问

  • SSH 服务器零日漏洞利用 - 保护自己的建议

  • ubuntu apt-get upgrade - 如何在 shell 中单击确定?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve