Local web browsing
Advantages of browsing local files as web pages over plain files include improved file formatting, multimedia integration, interactive
and dynamic navigation. Suppose for instance our directory contains a README.md
(as in a GitHub repository) which can be converted to
README.html
via pandoc
, then we can browse our directory as files + web page with README.html
(allowing for explicit file
download), or a web page when index.html
is created as a symbolic link to README.html
(files are invisible unless explicit links are
given inside).
To proceed, we first start the web service, which is simply done (through the default Python 3.6.8) as follows:
python3 -m http.server 8080 &
assuming port number 8080 is available, e.g. lsof -i :8080
gives no output.
An almost equally simpler approach is also possible,
npm install -g http-server
http-server &
The firefox
browser available at /usr/bin/firefox
is dysfunctional, and when started many temporary files are generated which can be removed with
# only remove those dated on Dec 3:
ll -rt | grep "Dec 3" | awk '{print "rm -fr "$NF}' | bash
Several alternatives are described below.
Chromium
We are then capable to work with ceuadmin/chromium
:
module load ceuadmin/chromium
chrome http://localhost:8080 &
using profile at ~/.config/chromium.
It might be helpful to clear browse history when chrome
is repeatedly used, or to start a new profile, e.g.,
chrome --user-data-dir=/tmp/jhz22 http://localhost:8080 &
Microsoft Edge
This is also ready to use,
module load ceuadmin/edge
edge http://localhost:8080 &
where the customized edge
works properly, unlike its aliases microsoft-edge
and microsoft-edge-stable
.
Note the profile is ~/.config/microsoft-edge, and the option --user-data-dir
also applies since it is also based on Chromium.
Cytoscape
This is an earlier attempt but somewhat clumsy.
module load ceuadmin/Cytoscape/3.9.1
Cytoscape &
using Tools
–> Open web page
for http://127.0.0.1:8080
.
Default browser(s)
A list of options is as follows,
xdg-settings set default-web-browser chromium.desktop
xdg-settings set default-web-browser microsoft-edge.desktop
xdg-settings set default-web-browser firefox.desktop
xdg-settings set default-web-browser google-chrome.desktop
For Microsoft Edge above, we see microsoft-edge.desktop
at /usr/share/applications
, and an attempt is made as follows,
export src=/usr/local/Cluster-Apps/ceuadmin/edge/130.0.2849.56-1/usr/share/applications/
export dest=~/.local/share/applications
cp ${src}/microsoft-edge.desktop ${dest}
cd ${dest}
sed -i "s|/usr/bin/microsoft-edge|${src}/microsoft-edge --no-sandbox|" ${dest}/microsoft.desktop
export XDG_CURRENT_DESKTOP=GNOME
xdg-settings set default-web-browser microsoft-edge.desktop
xdg-settings get default-web-browser
Non-CSD3 browser(s)
This approach seems less problematic with user-data-dir
mentioned above. We can again set up tunneling from CSD3 with
python3 -m http.server 8000 &
hostname
Once succeeded, we establish the connection elsewhere.
ssh -4 -L 8080:127.0.0.1:8000 -fN jhz22@${hostname}.hpc.cam.ac.uk
where hostname from CSD3 and ${hostname} have to be the same. We can then browse http://127.0.0.1:8080
.