我有一个为Windows编写的应用程序,正在移植到Linux(具体来说是Ubuntu)。问题是我一直只使用Linux,却从未真正为它开发过。更具体地说,我不了解系统的基本布局。例如,我应该在哪里安装软件?我希望所有用户都可以访问它,但是我需要对该区域具有写权限才能编辑我的数据文件。此外,如何通过编程方式确定软件的安装位置(而不只是从何处调用)?在Windows中,我使用注册表找到具有所有相关信息的配置文件,但是Linux中没有注册表。谢谢!
最佳答案
The Filesystem Hierarchy Standard(名称不正确-这不是标准)对您非常有帮助;它清楚地描述了管理员对数据存放位置的偏好。
由于您是第一次打包软件,因此我建议您少做任何事情。 Debian,Ubuntu,Red Hat,SuSE,Mandriva,Arch,Annvix,Openwall,PLD等都有各自关于如何最好地打包软件的特质。
建筑
最好的选择是提供一个源tarball,该源tarball可以构建并希望这些发行版的用户或打包者为您选择并打包。用户下载压缩包,解压缩,编译和安装可能会很好。
对于构建软件, make(1)
是通常的标准。还存在其他工具,但是该工具随处可见,并且非常合理。 (即使语法是 cranky 。)用户也希望能够运行:make ; make install
或./configure ; make ; make install
,以默认情况下将软件构建并安装到/usr/local
中。 (./configure
是autotools工具链的一部分;特别适合提供./configure --prefix=/opt/foo
以允许用户使用一个命令行参数来更改软件的安装位置。我会尽量避免使用自动工具,但有时会避免使用自动工具使用便携式软件比不使用便携式软件更容易编写。)
包装
如果您确实想提供一站式打包,那么Debian Policy Manual将提供有关如何打包软件的规范规则。 Debian New Maintainers Guide将提供一种更友好,更温和的演练,介绍为Debian和Debian衍生的系统构建软件包所独有的工具。
Ubuntu's Packaging Guide可能包含特定于Ubuntu的详细信息。 (我还没看过。)
配置
当涉及到应用程序的配置文件时,通常文件存储在/etc/<foo>
中,其中<foo>
表示程序/软件包。有关名称解析的详细信息,请参见/etc/resolv.conf
,有关包含文件系统及其安装位置的设备列表,请参见/etc/fstab
,对于/etc/sudoers
配置,请参见sudo(8)
,对于/etc/apt/
软件包管理系统,请参见apt(8)
。
有时,应用程序还提供按用户的配置。这些配置文件通常存储在~/.foorc
或~/.foo/
中,以防整个目录比文件有用。 (请参见~/.vim/
,~/.mozilla/
,~/.profile
等)
如果您还想提供-c <filename>
命令行选项来告诉您的程序使用非标准的配置文件,则有时会非常方便。 (特别是如果您的用户可以运行foo -c /dev/null
以完全默认的配置启动。)
数据文件
用户将其数据存储在其主目录中。您无需为此做任何事情;只需确保使用getenv("HOME")
启动目录导航框,或通过sprintf(config_dir, "%s/%s/config", getenv("HOME"), ".application");
或类似方法加载配置文件。 (除了大多数目录中的主目录和/tmp/
外,他们无权写任何地方。)
有时,所有数据都可以存储在隐藏文件或目录中。例如,ssh(1)
将其所有数据保留在~/.ssh/
中。通常,用户希望从ssh-keygen(1)
中获得默认的kry名称,以便ssh-agent(1)
可以找到麻烦最少的 key 。 (默认情况下,它使用~/.ssh/id_rsa
。)shotwell(1)
照片管理器提供了托管的体验,类似于Apple的iPhoto.app
。它使用户可以选择一个起始目录,但可以根据需要组织其中的文件和目录。
如果您的应用程序是通用程序,则可能会让用户选择自己的文件名。如果他们想将数据直接存储到安装在/dev
或/media
中的内存棒或安装在/automount/blah
中的远程文件系统,他们的主目录,在机器上服务的内容的/srv/
目录或/tmp/
中,请让他们使用。用户可以根据自己的数据选择合理的文件名和目录。用户已经具有适当的权限,这取决于用户。 (不要尝试为用户提供在没有特权的位置写信息的机制。)
应用程序文件的安装和所有权
有两种在Linux系统上安装应用程序的常用方法:
root
或bin
或adm
或某些类似帐户拥有。程序以用户执行时的运行方式运行,因此它们获得了用户创建和读取文件的特权。如果将它们与分发打包文件打包在一起,则可执行文件通常将驻留在/usr/bin/
中,库将驻留在/usr/lib/
中,非对象文件(图像,模式等)将驻留在/usr/share/
中。 (/bin/
和/lib/
适用于早期启动或救援环境所需的应用程序。/usr
可能是网络中所有计算机通用的,在启动过程的后期以只读方式安装。)(有关详细信息,请参阅FHS。)如果程序未打包,则
/usr/local/
将作为起点:/usr/local/bin/
,/usr/local/lib/
,/usr/local/share/
等。某些管理员更喜欢/opt/
。 ~/bin/
目录,在此目录中存储他们编写的Shell脚本或程序,或者链接到~/Local/<foo>/
目录中的程序中。 (这个名称没有什么魔术。这只是我几年前想到的第一件事。其他人选择其他名称。)这是./configure --prefix=~/Local/blah
付钱的地方。)关于windows - 如何设计与Windows有关的Linux软件?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/6555299/