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 / 问题

问题[shell-scripting](server)

Martin Hope
serverstackqns
Asked: 2022-04-08 22:21:30 +0800 CST

shell 脚本中 set-hostname 和 mv 命令的变量

  • 0

我在 Shell 中有以下脚本:

read n
for ((i=1;i<=$n;i++))
do
echo "Connecting to $publicip"
ssh -i ./key.txt root@$publicip 'hostnamectl set-hostname autotest$i.domain.com && mv /etc/letsencrypt/live/autotest.domain.com /etc/letsencrypt/live/autotest$i.domain.com && reboot'
done

mv 命令使用上述命令中的变量。但这似乎不起作用。我得到一个错误是 mv: cannot move '/etc/letsencrypt/live/autotest.domain.com' to a subdirectory of its own, '/etc/letsencrypt/live/autotest.domain.com/autotest.domain.com'当我检查另一台服务器以查看主机名是否已更改时,即使设置主机名似乎也不起作用(尤其是使用变量)。围绕变量尝试了很多东西,比如添加“”和 {} 等,但没有任何效果。

有人可以在这方面帮助我。

linux shell hostname shell-scripting mv
  • 1 个回答
  • 214 Views
Martin Hope
Ramon Smits
Asked: 2022-02-26 01:51:19 +0800 CST

运行在 shell 中作为脚本运行的命令

  • 0

在 shell 中运行以下命令可以正常运行:

ssh user@machine systemctl status my-service.service
ssh user@machine sudo systemctl stop my-service.service
scp -r ./my-service/* user@machine:/home/user/my-service
ssh user@machine chmod +x /home/user/my-service/my-service
ssh user@machine sudo systemctl start my-service.service
ssh user@machine sudo systemctl status my-service.service

但是,将其放在deploy.sh文件中会导致上述任何一项都无法执行。

错误:

  • 无效的单元名称“my-service”被转义为“my-service\x0d”(也许你应该使用systemd-escape?)
  • 找不到单元 my-service\x0d.service。
  • 无效的单位名称“my-service.service”被转义为“my-service.service\x0d”(也许你应该使用systemd-escape?)
  • 无法停止 my-service\x0d.service:未加载单元 my-service.service\x0d.service。: 没有这样的文件或目录nlock/
  • chmod: 无法访问'/home/user/my-service/my-service'$'\r': 没有这样的文件或目录
  • 无效的单位名称“my-service.service”被转义为“my-service.service\x0d”(也许你应该使用systemd-escape?)
  • 无法启动 my-service.service\x0d.service:未找到单元 my-service.service\x0d.service。无效的单位名称“my-service.service”被转义为“my-service.service\x0d”(也许你应该使用systemd-escape?)
  • 找不到单元 my-service.service\x0d.service。

有的被打散了。这似乎与逃避有关。出于某种原因,在行尾添加一个空格使其有点工作,但仍然不是没有错误。

谷歌搜索错误显示了一些关于使用的命中--并将其与尾随空格一起添加使得一些命令工作但仍然给出转义错误。

linux shell escaping shell-scripting
  • 1 个回答
  • 189 Views
Martin Hope
ihorc
Asked: 2022-02-21 01:20:28 +0800 CST

在 bash 脚本中使用带有列号的 awk

  • 0

我正在使用这样的命令从以下位置获取一些连接nf_conntrack:

awk '($3 == "tcp") && ($6 != "TIME_WAIT") && ($10 == "dport=1234")' /proc/net/nf_conntrack

如何在 bash 脚本中使用此命令并向其添加脚本参数?如果我这样做:

awk '($3 == "tcp") && ($6 != "TIME_WAIT") && ($10 == "dport=$1")' /proc/net/nf_conntrack

它将假设所有$1, $3, $6,... 都是脚本参数并且失败。如何将awk列号与脚本参数分开以正确使用此命令?

bash awk shell-scripting
  • 1 个回答
  • 180 Views
Martin Hope
Maxime
Asked: 2021-12-11 11:41:44 +0800 CST

Ansible blockinfile 模块 - 插入插入代码行

  • 0

我尝试使用 Ansible blockinfile模块插入代码行(shell 脚本)。

name: Customized prompt
blockinfile:
path: /etc/profile.d/customized_prompt.sh
create: yes
block: |

#!/bin/bash

# customized prompt normal user and root

if (( "$(id -u)" == "1000" ))
then
    PS1="[\u@\H \w]$ "
elif (( "$(id -u)" == "0" ))
then
    PS1="[\u@\H \w]# "
fi

我有这个 Ansible 错误

[admin@srvansible /etc/ansible]$ ansible-playbook playbook_prompt.yml --ask-become-pass
BECOME password: 
ERROR! We were unable to read either as JSON nor YAML, these are the errors we got from each:
JSON: Expecting value: line 1 column 1 (char 0)

Syntax Error while loading YAML.
could not find expected ':'

The error appears to be in '/etc/ansible/roles/utilities/tasks/main.yml': line 14, column 4, but may
be elsewhere in the file depending on the exact syntax problem.

The offending line appears to be:

if (( "$(id -u)" == "1000" ))
then
^ here

我需要帮助:)

谢谢你

ansible ansible-playbook shell-scripting
  • 1 个回答
  • 295 Views
Martin Hope
Zareh Kasparian
Asked: 2021-11-06 03:21:11 +0800 CST

“command.sh > /dev/null 2>&1”与“command.sh 2>&1 >/dev/null”有什么区别

  • 0

我的 crontab 上有许多 shell 和 python 脚本,它们以以下任一结尾:

command.sh > /dev/null 2>&1

或者

command.sh 2>&1 >/dev/null

我知道:

> 用于重定向

/dev/null是一个黑洞,任何发送的数据都会被丢弃

2是标准错误的文件描述符

>用于重定向

&是文件描述符的符号(没有它,以下 1 将被视为文件名)

1是标准输出的文件描述符

因此command.sh >/dev/null 2>&1将我的程序的输出重定向到/dev/null。包括标准错误和标准输出。

两者都有相同的结果并且工作正常,但是为什么有些人使用第一种类型而有些人使用另一种呢?

linux scripting shell-scripting
  • 1 个回答
  • 166 Views
Martin Hope
kindleuptake
Asked: 2021-10-02 09:39:38 +0800 CST

如何以编程方式将 nginx 配置指令设置为 nginx.conf?

  • 0

我正在尝试制作一个 shell 脚本来自动安装一个 Web 应用程序,并且该脚本需要client_max_body_size在某个时候设置为更大的大小。

当然,可以使用 nano 设置此指令,但这不是我想要的。该脚本应该能够自行在 http 部分中设置该指令的值。


该脚本需要在/etc/nginx/nginx.conf.

我在 nginx 文档中有这个例子,但我不知道如何将它修改为我的用例:

nginx -g "pid /var/run/nginx.pid; worker_processes sysctl -n hw.ncpu;"

nginx shell-scripting
  • 1 个回答
  • 546 Views
Martin Hope
jhericks
Asked: 2021-09-24 16:29:02 +0800 CST

为什么`ps -x | grep foo` 是否包含 grep 命令?

  • 1

我知道它确实(通常)包括 grep 进程,并且我知道添加 | grep -v grep或 grepping[f]oo会阻止它,但我的问题更多是关于我猜的操作顺序。

例如,在这个人为的例子中,我看到了几个 grep 进程:

% ps -x | grep login | grep login | grep login | grep login
 2475 ??         0:00.03 /usr/libexec/loginitemregisterd
 2115 ttys004    0:00.04 login -fp jasonerickson
29715 ttys004    0:00.00 grep login
29716 ttys004    0:00.00 grep login
29717 ttys004    0:00.00 grep login
29718 ttys004    0:00.00 grep login

这告诉我ps -x必须在该行最后执行,因为它列出了所有后续的 grep 命令。但是,它并不一致。有时它会列出 4 或 3 或 2 个,甚至没有 grep 进程。这对我来说意味着它并不总是最后的。

这是怎么回事?

shell shell-scripting ps
  • 2 个回答
  • 1571 Views
Martin Hope
northport
Asked: 2021-09-16 22:39:00 +0800 CST

cURL POST bash 脚本将单引号添加到带空格的变量中

  • 0

前 3 个变量将始终没有空格。第四个“ slacksitename”有空格

ip=“x.x.x.x"
record_name=“demo.xyz"
slackuri:”WEBHOOK"
slacksitename:”123 Main St"

使用 cURL 调用时

curl -X POST -H 'Content-type: application/json' --data '{"text":"’$slacksitename': '$ip' '$record_name' DDNS updated.”}’ $slackuri

输出如下:

curl -X POST -H 'Content-type: application/json' --data '{"text":"123' Main 'St: x.x.x.x demo.xyz DDNS updated."}' https://hooks.slack.com/services/……..
curl: (6) Could not resolve host: Main
curl: (3) unmatched close brace/bracket in URL position 59:
St: x.x.x.x demo.xyz DDNS updated."

有谁知道它为什么要添加单引号123' Main 'St?以及我如何将整个变量视为一个字符串而不是拆分它(这就是我认为它正在做的事情)?

谢谢

更新:已解决^^

跟进:

这可能与原始问题的思路相同:

我有一个变量,它是我想通过 cURL 发送的 JSON 输出。我假设问题再次是引号,但 JSON 输出可能会改变(引号数)。有没有办法在消息中用新行发送带有 cURL 的原始数据?谢谢

DUMPING RESULTS:\n{"result":{"id":"ppbkbz2ezmxen11vvpi65chsro1vki5y","zone_id":"unuM0sR1gSrQ37r9fGC1sYKFZOP0DzJM","zone_name":"demo.xyz","name":"1.demo.xyz","type":"A","content":"x.x.x.x","proxiable":true,"proxied":false,"ttl":1,"locked":false,"meta":{"auto_added":false,"managed_by_apps":false,"managed_by_argo_tunnel":false,"source":"primary"},"created_on":"2020-06-14T19:13:57.096688Z","modified_on":"2021-10-16T16:57:49.269274Z"},"success":true,"errors":[],"messages":[]}."
linux bash curl shell-scripting
  • 2 个回答
  • 3472 Views
Martin Hope
solveit
Asked: 2021-08-04 21:24:49 +0800 CST

如何删除grepped iptables

  • 1

我有 iptables 从cali-

 root@Ubuntu-18-VM:~# iptables -S | grep -oP '(?<!^:)cali-[^ ]+'
    cali-FORWARD
    cali-INPUT
    cali-OUTPUT
    cali-cidr-block
    cali-from-hep-forward
    cali-from-host-endpoint
    cali-from-wl-dispatch
    cali-from-wl-dispatch-5
    cali-fw-cali2847b154969
    cali-fw-cali4bb24809f90
    cali-fw-cali531f8f2e712
    cali-fw-cali5a82b3ff301
    cali-pri-_CVSZITRyIpEmH8AB6H
    cali-pri-_HayIXLB85hzHkIhWER
    cali-pri-_PTRGc0U-L5Kz7V6ERW
    cali-pri-_u2Tn2rSoAPffvE7JO6
    cali-pri-kns.kube-system
    cali-pro-_CVSZITRyIpEmH8AB6H
    cali-pro-_HayIXLB85hzHkIhWER
    cali-pro-_PTRGc0U-L5Kz7V6ERW
    cali-pro-_u2Tn2rSoAPffvE7JO6
    cali-pro-kns.kube-system
    cali-to-hep-forward
    cali-to-host-endpoint
    cali-to-wl-dispatch
    cali-to-wl-dispatch-5
    cali-tw-cali2847b154969
    cali-tw-cali4bb24809f90
    cali-tw-cali531f8f2e712
    cali-tw-cali5a82b3ff301
    cali-wl-to-host

如何删除这 31 个 iptables ?在 grep 之后我应该添加什么删除命令,以便该iptables -S命令不显示cali-iptables ?

linux bash iptables linux-networking shell-scripting
  • 1 个回答
  • 109 Views
Martin Hope
myNewAccount
Asked: 2021-04-15 13:44:19 +0800 CST

在 profile.d 中的 CentOS 8 上,我是否需要将与环境变量相关的脚本添加到 .sh 和 .csh 文件中?

  • 0

我需要添加与代理服务器相关的环境变量,以允许我的 node.js 应用程序与 Google Cloud 上的 reCAPTCHA Enterprise 通信。

当我通过访问 Google Cloud API 运行脚本时,尽管已成功启用与 Google Cloud的代理通信。但是,展望未来,我需要在启动时提供代理支持。

export GRPC_VERBOSITY=DEBUG  
export GRPC_TRACE=handshaker

export HTTP_PROXY=http://localhost:3128
export http_proxy=http://localhost:3128
export https_proxy=http://localhost:3128
export HTTPS_PROXY=http://localhost:3128

当我检查我的profile.d目录时,我注意到它同时具有.sh和.csh文件。例如,

colorgrep.csh
colorgrep.sh
colorls.csh
colorls.sh
colorxzgrep.csh
colorxzgrep.sh
colorzgrep.csh
colorzgrep.sh
csh.local
gawk.csh
gawk.sh
lang.csh
lang.sh
less.csh
less.sh
nano.sh
sh.local
which2.csh
which2.sh

我是否需要将与代理相关的脚本复制并粘贴到单个.sh文件中,还是应该将它们也添加到.csh文件中?也可以进行简单的复制和粘贴,还是需要更改格式?

centos bash environment-variables shell-scripting
  • 1 个回答
  • 138 Views

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