在 Linux 中创建可执行文件
Posted
技术标签:
【中文标题】在 Linux 中创建可执行文件【英文标题】:Creating executable files in Linux 【发布时间】:2010-10-23 10:56:54 【问题描述】:我打算做的一件事是编写(非常简单的)Perl 脚本,我希望能够在不从终端显式调用 Perl 的情况下运行它们。我很感激,为此,我需要授予他们执行权限。使用 chmod 执行此操作很容易,但它似乎也是一个稍微费力的额外步骤。我想要的是以下两件事之一:
首先,有没有办法在保存文件时设置执行标志?目前我正在尝试使用 gedit 和 geany,但如果它具有此功能,我愿意切换到具有类似(或更好)功能的编辑器。
如果做不到这一点,有没有办法声明在特定目录中创建的所有文件都应该具有执行权限?
我的 umask 设置为 022,据我了解,这应该没问题,但似乎这些文件是作为文本文件(具有 666 个默认权限)而不是可执行文件(具有 777 个默认权限)创建的。
也许我只是懒惰,但我认为必须有一种比 chmod 更方便的方法,而不是对每个创建的单个脚本进行 chmod。
【问题讨论】:
您必须打印每个文件的输出。您必须导入每个文件的正确库。这似乎是编程过程中的另一个步骤,而且是危险的规避。 【参考方案1】:使文件可执行:
chmod +x 文件
找到perl的位置:
哪个perl
这应该返回类似
/bin/perl 有时是 /usr/local/bin
然后在脚本的第一行添加:
#!"path"/perl 上面的路径,例如
#!/bin/perl
然后就可以执行文件了
./文件
PATH 可能存在一些问题,因此您可能也想更改它...
【讨论】:
谢谢,但这不是我的问题。我已经养成了用#!/usr/bin/perl 开始我的脚本的习惯。一旦我给了脚本可执行权限,我就可以很好地运行脚本;我只是在寻找一种更简单的方法。 我可以推荐#!/usr/bin/env perl
吗? env
程序基本上在 PATH 上找到给定的参数(在本例中为“perl”)并运行它。当您将脚本发送给其他人时,它很有用 - 例如,我使用 Mac,而 Perl 位于 /opt/local/bin。【参考方案2】:
无需破解您的编辑器或切换编辑器。
相反,我们可以提供一个脚本来观察您的开发目录和 chmod 文件的创建过程。这就是我在附加的 bash 脚本中所做的。您可能想通读 cmets 并根据需要编辑“配置”部分,然后我建议将其放在您的 $HOME/bin/ 目录中并将其执行添加到您的 $HOME/.login 或类似文件中。或者你可以从终端运行它。
此脚本确实需要 inotifywait,它位于 Ubuntu 的 inotify-tools 包中,
sudo apt-get install inotify-tools
欢迎提出建议/编辑/改进。
#!/usr/bin/env bash
# --- usage --- #
# Depends: 'inotifywait' available in inotify-tools on Ubuntu
#
# Edit the 'config' section below to reflect your working directory, WORK_DIR,
# and your watched directories, WATCH_DIR. Each directory in WATCH_DIR will
# be logged by inotify and this script will 'chmod +x' any new files created
# therein. If SUBDIRS is 'TRUE' this script will watch WATCH_DIRS recursively.
# I recommend adding this script to your $HOME/.login or similar to have it
# run whenever you log into a shell, eg 'echo "watchdirs.sh &" >> ~/.login'.
# This script will only allow one instance of itself to run at a time.
# --- config --- #
WORK_DIR="$HOME/path/to/devel" # top working directory (for cleanliness?)
WATCH_DIRS=" \
$WORK_DIR/dirA \
$WORK_DIR/dirC \
" # list of directories to watch
SUBDIRS="TRUE" # watch subdirectories too
NOTIFY_ARGS="-e create -q" # watch for create events, non-verbose
# --- script starts here --- #
# probably don't need to edit beyond this point
# kill all previous instances of myself
SCRIPT="bash.*`basename $0`"
MATCHES=`ps ax | egrep $SCRIPT | grep -v grep | awk 'print $1' | grep -v $$`
kill $MATCHES >& /dev/null
# set recursive notifications (for subdirectories)
if [ "$SUBDIRS" = "TRUE" ] ; then
RECURSE="-r"
else
RECURSE=""
fi
while true ; do
# grab an event
EVENT=`inotifywait $RECURSE $NOTIFY_ARGS $WATCH_DIRS`
# parse the event into DIR, TAGS, FILE
OLDIFS=$IFS ; IFS=" " ; set -- $EVENT
E_DIR=$1
E_TAGS=$2
E_FILE=$3
IFS=$OLDIFS
# skip if it's not a file event or already executable (unlikely)
if [ ! -f "$E_DIR$E_FILE" ] || [ -x "$E_DIR$E_FILE" ] ; then
continue
fi
# set file executable
chmod +x $E_DIR$E_FILE
done
【讨论】:
在目录上设置一个umask不是更简单吗?【参考方案3】:您所描述的是处理此问题的正确方法。
你说过你想留在 GUI 中。您通常可以通过文件属性菜单设置执行位。如果您愿意,您还可以学习如何为上下文菜单创建自定义操作来为您执行此操作。这当然取决于您的桌面环境。
如果您使用更高级的编辑器,您可以编写保存文件时要执行的操作的脚本。例如(我只对 vim 非常熟悉),您可以将其添加到您的 .vimrc 中,以使任何以“#!/*/bin/*
”开头的新文件可执行。
au BufWritePost * if getline(1) =~ "^#!" | if getline(1) =~ "/bin/" | silent !chmod +x <afile> | endif | endif
【讨论】:
使用这个技巧,我遇到了这里提到的问题:bbs.archlinux.org/viewtopic.php?id=126304所以现在我使用稍微修改过的版本autocmd BufWritePost * if getline(1) =~ "^#!/bin/" | silent execute "!chmod a+x <afile>" | endif
【参考方案4】:
这真的没什么大不了的。您可以使用单个命令制作一个脚本:
chmod a+x *.pl
并在创建 perl 文件后运行脚本。或者,您可以使用如下命令打开文件:
touch filename.pl && chmod a+x filename.pl && vi filename.pl # choose your favorite editor
【讨论】:
我更多的是在寻找一种将所有内容都放入 GUI 的方法,但也许这是不可能的。这是安全问题吗? 是的,这是一个安全问题。如果 shell 默认开始创建所有可执行文件,这可能是一个大问题。 你可以制作一个简单的程序来为你做这件事。但老实说,您会尝试做一些其他在 UNIX 环境中编程的人不会真正做的事情。【参考方案5】:我认为您遇到的问题是,即使您可以在系统中设置自己的 umask 值,这也不允许您通过 gedit(或任何编辑器)显式控制在新文件上设置的默认权限你用)。
我相信这个细节是硬编码到 gedit 和大多数其他编辑器中的。您更改它的选项是(a)破解您自己的 gedit 模块或(b)找到一个文本编辑器,允许您设置新文件的默认权限首选项。 (对不起,我不知道。)
鉴于此,必须对文件进行 chmod 真的不是那么糟糕,对吧?
【讨论】:
以上是关于在 Linux 中创建可执行文件的主要内容,如果未能解决你的问题,请参考以下文章
无法在Dataflow SDK 2.1.0中创建可执行Jar