You are not logged in.
On my system, /srv/http is a symlink (http -> mnt/http), not a directory.
I got an error during package upgrade:
upgraded libutil-linux (2.29.2-1 -> 2.29.2-2)
error: cannot remove /srv/http/ (Not a directory)
The symlink was deleted and an empty http directory created.
I reverted this manually, http seems to work again.
Would i have to manually repair other things because of broken upgrade?
Offline
Not likely... pacman changes a while back makes it hate symlinks as I recall. You're probably fine.
CPU-optimized Linux-ck packages @ Repo-ck • AUR packages • Zsh and other configs
Offline
You'll have to do this every time. Or fix your broken setup (use mount/bind mount instead of symlinks).
Online
Thanks! Changed my setup to bind mounts.
(Btw, is there something wrong with using symlinks? - I mean they are widely-used in the system, e.g. /bin -> /usr/bin, /lib[64] -> /usr/lib ... )
Offline
There is nothing wrong with symlinks. There is something wrong with replacing files and directories owned by core packages.
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline
There is nothing wrong with symlinks. There is something wrong with replacing files and directories owned by core packages.
... but the /srv/http directory is not owned by the libutil-linux package, nor the apache package?
Offline
Quotation from /etc/httpd/conf/httpd.conf :
#
# DocumentRoot: The directory out of which you will serve your
# documents. By default, all requests are taken from this directory, but
# symbolic links and aliases may be used to point to other locations.
#
DocumentRoot "/srv/http"
<Directory "/srv/http">
#
# Possible values for the Options directive are "None", "All",
# or any combination of:
# Indexes Includes FollowSymLinks SymLinksifOwnerMatch ExecCGI MultiViews
#
# Note that "MultiViews" must be named *explicitly* --- "Options All"
# doesn't give it to you.
#
# The Options directive is both complicated and important. Please see
# http://httpd.apache.org/docs/2.4/mod/core.html#options
# for more information.
#
Options Indexes FollowSymLinks
#
# AllowOverride controls what directives may be placed in .htaccess files.
# It can be "All", "None", or any combination of the keywords:
# AllowOverride FileInfo AuthConfig Limit
#
AllowOverride None
#
# Controls who can get stuff from this server.
#
Require all granted
</Directory>
... so /srv/http is typically a pure data directory, which can contain symlinks.
So should pacman replace such a symlink on its own?
Offline
% pacman -Qo /srv/http
/srv/http/ is owned by filesystem 2017.03-2
Online
pacman -Qo
Thanks, i missed this pacman option ...
But the question remains - should /srv/http be forced to be a directory, although apache allows a symlink?
Or is it considered to be bad style to use a symlink for the DocumentRoot?
(Should this directory entry be preinstalled at all? I think, apache is not necessarily installed on a system?)
Offline
/srv/http isn't limited to apache only, other webservers can use it too.
Though, according to FHS, there isn't any standard about the subdirectories of /srv: http://refspecs.linuxfoundation.org/FHS … 03s17.html
Offline
Also apache is fine with document root being a directory or a symlink to a directory. That really says nothing about /srv/http as apache is fine with the document root being /srv/http or /var/http or /mnt/http (why not just do this for your case) or damn near anywhere else. Apache doesn't decide where your document root needs to be - you just need to tell it where it is so it can serve those files.
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline
/srv/http isn't limited to apache only, other webservers can use it too.
... but still, why should it be preinstalled and enforced to be a directory, instead of being installed by each individual webserver package, only if needed?
Though, according to FHS, there isn't any standard about the subdirectories of /srv: http://refspecs.linuxfoundation.org/FHS … 03s17.html
And it says also:
Distributions must take care not to remove locally placed files in these directories without administrator permission. [20]
---
[20] This is particularly important as these areas will often contain both files initially installed by the distributor, and those added by the administrator.
Although, of course, removing a user created symlink is nothing like overwriting an existing config file containing complex changes or deleting valuable data, this is still a bit counterintuitive.
(Pacman could check, if the symlink points to a valid directory, and then leave it, maybe showing a warning? Then to get rid of the warning, one could choose an alternative configuration.)
Offline
Also apache is fine with document root being a directory or a symlink to a directory. That really says nothing about /srv/http as apache is fine with the document root being /srv/http or /var/http or /mnt/http (why not just do this for your case) or damn near anywhere else. Apache doesn't decide where your document root needs to be - you just need to tell it where it is so it can serve those files.
Of course, the document root is configurable, but it seems to be an unexpected and unneccessary restriction for configuration (which seems to me to be a bit of a contradiction to the archlinux philosophy, trying to be clean and close to the original software?).
(The original error occured just because i simply didn't expect a symlink to cause a problem, thinking the /srv/http directory was created through the first run of httpd or something like that, and not being a fixed part of a core package.)
(Btw i changed my config (again) to use /mnt/http as document root, it works fine now, thanks! :-)
Offline
x33a wrote:/srv/http isn't limited to apache only, other webservers can use it too.
... but still, why should it be preinstalled and enforced to be a directory, instead of being installed by each individual webserver package, only if needed?
Because, in that case the different webserver packages will have to conflict with each other, which isn't the case right now.
Offline