- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在编写一个脚本来设置 debian 安装,这个错误让我很沮丧:
问题:
cp "$BASHRC" "$HOME"/.bashrc
给出:
+ sudo -u billy bash
cp: cannot stat '': No such file or directory
or
cp: missing opereand
这是脚本:
这些文件在脚本所在的当前目录中...
17 BASHRC=.bashrc
18 NANORC=.nanorc
19 BASHRCROOT=.bashrcroot
#!/bin/bash -x
2
3 SCRIPTNAME=`basename "$0"`
4
5 if [ "$#" -eq 0 ]
6 then
7 echo "No arguments supplied"
8 echo "Usage: $SCRIPTNAME user1name user2name\(optional\) user3name\(optional\)"
9 fi
10
11 echo "Here starts the party, "
12 echo "This program should be run as root, please wait"
13 echo "Setting up server.........."
14
15 DIRBASHRCROOT="$HOME"/.bashrcroot
16 DIRBASHRC="$HOME"/.bashrc
17 BASHRC=.bashrc
18 NANORC=.nanorc
19 BASHRCROOT=.bashrcroot
20 ROOT=root
21 USER1="$1"
22 USER2="$2"
23 USER3="$3"
24
25 ################ Users and access settings #####################
26 #echo username1 ALL=(username2) NOPASSWD: /bin/bash /path/to/svn >> /etc/sudoers
27 #echo `users` | grep "$1" && echo User $1 exists
28 #sudo -u username2 -H sh -c "cd /home/$USERNAME/$PROJECT; svn update"
29 #useradd -m -s /bin/bash "$different_user"
30 #id -u $USER1
31 checkIfUser()
32 {
33 for name in "$@"
34 do
35 if id -u "$name" #>/dev/null 2>&1
36 then
37 echo 'User: "$name" exists....setting up now\!'
38 else
39 echo 'User: "$name" does not exists....creating now\!'
40 useradd -m -s /bin/bash "$name" #>/dev/null 2>&1
41 fi
42 done
43 }
44 checkIfUser $1 $2 $3
45 ################ NANO SYNTAX-HIGHLIGHTING #####################3
46 sleep 3
47
48
49
50
51
52 if [ "$UID" != 0 ]
53 then
54 sudo -u "$ROOT" bash <<'EOF'
55 sleep 5
56 git clone https://github.com/nanorc/nanorc.git
57 sleep 5
58 cd nanorc
59 make install-global
60 sleep 5
61 cp "$NANORC" /etc/nanorc
62
63 if [ "$?" = 0 ]
64 then
65 echo "Implementing a custom nanorc file succeeded\!"
66 fi
67EOF
68 else
69 git clone https://github.com/nanorc/nanorc.git
70 sleep 5
71 cd nanorc
72 sleep 5
73 make install-global
74 sleep 5
75 cp "$NANORC" /etc/nanorc
76
77 if [ "$?" = 0 ]
78 then
79 echo "Implementing a custom nanorc file succeeded\!"
80 fi
81 fi
82
83 echo "Finished setting up nano\!"
84 ################ LS_COLORS SETTINGS #############################
86 if [ "$UID" != 0 ]
87 then
88 sudo -u "$ROOT" bash <<'EOF'
89 cp "$BASHRCROOT" "$HOME"/.bashrc
90 wget https://raw.github.com/trapd00r/LS_COLORS/master/LS_COLORS -O "$HOME"/.dircolors
91 echo 'eval $(dircolors -b $HOME/.dircolors)' >> "$HOME"/.bashrc
92 . "$HOME"/.bashrc
93 echo "Here is LS_COLORS in action: "
94 ls -l "$HOME"/
95 EOF
96 else
97 cp "$BASHRCROOT" $(eval echo "$HOME"/.bashrc)
98 sleep 5
99 wget https://raw.github.com/trapd00r/LS_COLORS/master/LS_COLORS -O "$HOME"/.dircolors
100 sleep 5
101 echo 'eval $(dircolors -b $HOME/.dircolors)' >> "$HOME"/.bashrc
102 sleep 5
103 . "$HOME"/.bashrc
104 echo "Here is LS_COLORS in action: "
105 sleep 5
106 ls -l "$HOME"/
107 fi
108 if [ ! -z "$USER1" ]
109 then
110 sudo -u "$USER1" bash <<'EOF'
111 sleep 5
THESE GUY'S ARE THE CULPRIT↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓
112 cp "$BASHRC" "$HOME"/.bashrc
HERE IS THE PROBLEM ↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑
113 sleep 5
114 wget https://raw.github.com/trapd00r/LS_COLORS/master/LS_COLORS -O "$HOME"/.dircolors
sleep 5
116 echo 'eval $(dircolors -b $HOME/.dircolors)' >> "$HOME"/.bashrc
117 . "$HOME"/.bashrc
118 sleep 5
119 echo "Here is LS_COLORS in action: "
120 ls -l "$HOME"/
121 EOF
122 fi
123
124 if [ ! -z "$USER2" ]
125 then
126 sudo -u "$USER2" bash <<'EOF'
127 cp "$BASHRC" "$HOME"/.bashrc
128 wget https://raw.github.com/trapd00r/LS_COLORS/master/LS_COLORS -O "$HOME"/.dircolors
129 echo 'eval $(dircolors -b $HOME/.dircolors)' >> "$HOME"/.bashrc
130 . "$HOME"/.bashrc
131 echo "Here is LS_COLORS in action: "
132 ls -l "$HOME"/
133 EOF
134 fi
135
136 if [ ! -z "$USER3" ]
137 then
138 sudo -u "$USER3" bash <<'EOF'
139 sleep 5
140 cp "$BASHRC" "$HOME"/.bashrc
141 sleep 5
142 wget https://raw.github.com/trapd00r/LS_COLORS/master/LS_COLORS -O "$HOME"/.dircolors
sleep 5
142 wget https://raw.github.com/trapd00r/LS_COLORS/master/LS_COLORS -O "$HOME"/.dircolors
143 sleep 5
144 echo 'eval $(dircolors -b $HOME/.dircolors)' >> "$HOME"/.bashrc
145 sleep 5
146 . "$HOME"/.bashrc
147 echo "Here is LS_COLORS in action: "
148 ls -l "$HOME"/
149 EOF
150 fi
151 echo "Finished setting up LS_COLORS on your files and directories\!"
问题:
这似乎是什么问题,最佳实践和解决方案是什么?
最佳答案
您正在通过 sudo 启动另一个 bash。 BASHRC 是局部变量,子进程不可见。
由于 sudo 会出现另一个问题:如果/etc/sudoers 包含选项 Defaults env_reset
,那么 sudo 将丢弃几乎所有环境变量(PATH 除外)。
如果将 <<'EOF' 更改为 << EOF,您可以控制哪些变量将在 sudo 之前扩展,哪些在 sudo 之后扩展:
#!/bin/sh
EARLY_EXPANSION=foo
export LATER_EXPANSION=bar
bash <<EOF
echo "$EARLY_EXPANSION \$LATER_EXPANSION"
sleep 5
echo $(date) \$(date)
EOF
关于linux - 为什么我不断收到 "cp: cannot stat ' ' : No such file or directory"or "cp: missing opereand" in my bash script,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51905689/
当我尝试构建我的项目时,我遇到了这样的错误: FAILURE: Build failed with an exception. * What went wrong: Execution failed
我正在尝试从 Here 构建适用于 linux 3.7 内核的 Mali 驱动程序. 有一个单独的构建脚本,例如, #!/bin/bash export KDIR=/path/to/kernel/di
有没有一种方法可以使用普通的 lisp 创建目录。我想先创建一个文件夹,然后将我的 .txt .png 文件放入其中。我知道首先我可以在外部创建文件夹,然后使用 with-open-file 等在目录
Visual Studio 提示每次编译警告 MSB8029:中间目录或输出目录不能位于临时目录下,因为它可能导致增量构建出现问题。 我正在检查项目并更改了输出目录和中间目录,但我仍然在我的解决方案中
Visual Studio 提示每次编译警告 MSB8029:中间目录或输出目录不能位于临时目录下,因为它可能导致增量构建出现问题。 我正在检查项目并更改了输出目录和中间目录,但我仍然在我的解决方案中
我的客户安装了 Keycloak 以从 AWS Cognito 代理用户。 我需要这个 Keycloak 来代理来自 Azure Active Directory 的用户。 客户拥有 AAD 的 OF
我想从 macOS 上 parallel 命令的所有潜力中受益(似乎存在 2 个版本,GNU 和 Ole Tange 的版本,但我不确定)。 使用以下命令: parallel -j8 find {}
我需要实现一个 Active Directory(本地)管理器,用户可以在其中执行所有任务,例如添加用户、删除用户、分配许可证和分配组等。用户有用户名、密码和域 Controller 名称,所以他只需
我正在编写一个使用PHP adLDAP库与Active Directory交互的应用程序。 为了测试该应用程序,我需要使用Active Directory架构的本地LDAP DB以及示例数据。 我已经
我有一个包含两个域 AA.RR.COM 和 BB.RR.COM 的 Active Directory 林,其中包含用户和组。我需要搜索两个域中的用户,同时查询其中一个域(例如 AA.RT.COM)如何
我使用 Proxy-Address 属性作为确定用户电子邮件地址的主要方法(我只关心以“SMTP:”或“smtp:”为前缀的地址,此外,我使用以大写字母为前缀的地址SMTP 来确定主地址 - 这不是
这个问题不太可能对任何 future 的访客有帮助;它只与一个较小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,通常不适用于全世界的互联网受众。如需帮助使此问题更广泛适用,visit the
所以我有一个目录 - 让我们说/dir/。在里面我有这些文件夹-/目录/fold1//目录/fold2//dir/fold3/ 这些文件夹 (fold1,2,3) 中的每一个都可能包含一个名为 foo
我正在使用 PHPmotion 在我本地的 ubuntu 机器上。 优步上传者在 phpmotion 中用于将文件上传到服务器。这是使用 perl 脚本(位于“ www/cgi-bin ”)上传文件。
我正在为我的公司开发一个基于 Web 的 Intranet。我只想知道用户使用事件目录登录详细信息登录应用程序是一件好事,还是我应该与应用程序数据库一起创建登录名。如果有什么比这更好的,请提出建议。这
我们有带有 AD 模块 1.0.4 的 Sitecore 6.5。 DEPARTMENT\SitecoreUsers AD 组中的用户可以登录 Sitecore,但 DEPARTMENT\Siteco
我使用的 AD 设置具有存储为(多个)安全组成员的用户。 我正在使用读取用户的 memberof 属性的软件来计算访问权限。 在 AD Explorer 中,我可以看到用户的 memberof 属性显
我们有一个在 .NET 上编写的 SaaS 应用程序,我们需要为我们的客户提供各种 SSO 方法。 不久前,我们对 OpenID 进行了标准化,希望这会成为一个通用标准,让我们不必支持不同的标准。不幸
我有 .Net 代码可以读取/写入我们本地的 Active Directory 域。阅读部分已经过测试并且工作正常,但我想测试“写作”部分。我的应用程序将修改事件目录中的一些用户配置文件,但我不想在实
我正在运行一个 ASP.NET 4.0 应用程序,它使用用户名(即 HttpContext.Current.Request.LogonUserIdentity.Name.ToString())来管理对
我是一名优秀的程序员,十分优秀!