<div dir="ltr">Then there's the matter of NUMA node architecture. That's a whole other interesting challenge. You'd think Intel's Broadwell XEONs circa 2016 would with their 4-channel RAM would be blown away by EPYC's 8-channel RAM alas, it's not so simple because the EPYC 7551s have four chiplets/socket, each with 8 cores which each directly address two channels of the 8-channel RAM. Sure, any chiplet can reach all RAM in the node, but it must request that through other chiplets if it's not directly connected and that adds latency.<div>The XEON systems have one NUMA node/socket and XEONs are monolithic.</div><div>So when you write the code, to maximize performance, you want to pin the process to a core and allocate the lion's share of its storage locally to that process soas to ensure that most of the RAM addresses go to local RAM. For memory-bound processes this can jack up performance significantly.</div><div>Another technique would be to pin simultaneous jobs to NUMA nodes. In the EPYC's case, you would run 4 jobs/socket. That's another incentive to cram as much RAM in these nodes.</div><div>HPC seems like pure frustrating pleasure to me, akin to "hot rodding" cars and I'm wondering if there is a subculture in NCLUG who would be interested?</div><div>See you at the meeting tonight,</div><div>Thanks,</div><div>Phil</div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Tue, May 14, 2024 at 2:37 PM Phil Marsh <<a href="mailto:microcraftx@gmail.com">microcraftx@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"> Hi Bob,<div>I was able to get Jitsi working on my machine! And I was able to hold a meeting. This is that HP740 thin client machine which is so low-power it will always be left on to provide a gateway to the rest of my systems.</div><div>I think that initially, I had a bad ssl cert(s). I install them manually since I want to download just one certificate for all my systems.</div><div>While I greatly admire and appreciate open-source contributors, the only real major fault I see with a lot of open-source software is the difficulty in diagnosing problems. I'm not a network engineer, but rather a noob and network, certificate issues are complex for me as I'm still learning this. Good diagnostic messages could make this so much easier and I wouldn't think that would require that much extra code?</div><div>If/when I get involved with open-source I promise myself to be anal about including diagnostics for the users.</div><div><br></div><div>In other news, I'm busy setting up my four-node compute system and it appears that CSU surplus is a great source of cheap RAM. Yea, it's not state-of-art but my EPYCs top out at 2666MHz DDR4 anyway and it seems there is very little difference in 2400MHz RAM and 2133MT RAM in terms of my initial benchmarks. This could be due to the 2133MT RAM's CL of 15 vs. that of the 2400MT RAM CL=19. But I will need to bench it with my actual applications to be sure. I'm still trying to understand the performance implications of MT vs CL and few people online can explain this cogently. I suspect that CL/MT is the latency time to start the fetching or writing to RAM and if one is writing or fetching a series of sequential locations, the MT dominates because the CL time applies only to the first write or fetch? Why is this so hard for people to explain clearly?</div><div>Oops I shouldn't have let the secret out! Slowly stuffing this system and I have 256GB in one node already. Will try to get another node to 512GB for those really big electromagnetic simulations. Will be exciting to turn this four-headed beast loose on these!</div><div><br></div><div>If you need help with this, I'll be glad to help,</div><div>Best,</div><div>Phil</div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Wed, May 8, 2024 at 2:10 PM Bob Proulx <<a href="mailto:bob@proulx.com" target="_blank">bob@proulx.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Hi Phil,<br>
<br>
Phil Marsh wrote:<br>
> I'm trying to set up jitsi but the instructions appear not to work.<br>
> It just keeps disconnecting me when I try to log in.<br>
> Anyone have any luck with setting it up?<br>
<br>
I have set it up from scratch. A few times. Because my experience is<br>
that you can't upgrade a jitsi server. You can only set one up from<br>
scratch. If for any reason along the installation journey there is a<br>
problem then you can only discard the virtual machine, create a new<br>
pristine one, and then install for the first time again. It's a<br>
problem!<br>
<br>
I will provide my notes on setting up Jitsi but first will say that<br>
for last weekend's LibrePlanet the FSF decided not to use Jitsi but<br>
switched to using Galene instead. Among other things it is simpler<br>
and handles a high load of use better than Jitsi. You might check out<br>
Galene and see if it works better for you. However having said that I<br>
haven't myself set up Galene yet.<br>
<br>
<a href="https://galene.org/" rel="noreferrer" target="_blank">https://galene.org/</a><br>
<br>
My notes for setting up Jitsi follow. I am always installing this in<br>
a VM so that I can discard the VM and start again easily. Because<br>
Jitsi is very rigid. Rigid means fragile. Anything changes and the<br>
entire Jitsi system just fractures into breakage. So I only ever<br>
install Jitsi for the first time on a new server. That could be a<br>
container okay too.<br>
<br>
First I do a bunch of routine setup for the system. And also install<br>
nginx and set up https certificates via Let's Encrypt using the simple<br>
dehydrated client. I get all of that set up first. Then this. My<br>
notes reference <a href="http://jitsi.member.fsf.org" rel="noreferrer" target="_blank">jitsi.member.fsf.org</a> because that is the system I am<br>
setting up but change that to be the name of your system.<br>
<br>
#!/bin/sh<br>
<br>
# The goal of this script is to automate and document by this<br>
# automation the setup of Jitsi on the system.<br>
#<br>
# Copyright 2023 Bob Proulx <<a href="mailto:bob@proulx.com" target="_blank">bob@proulx.com</a>><br>
#<br>
# Licensed under the Apache License, Version 2.0 (the "License");<br>
# you may not use this file except in compliance with the License.<br>
# You may obtain a copy of the License at<br>
#<br>
# <a href="http://www.apache.org/licenses/LICENSE-2.0" rel="noreferrer" target="_blank">http://www.apache.org/licenses/LICENSE-2.0</a><br>
#<br>
# Unless required by applicable law or agreed to in writing, software<br>
# distributed under the License is distributed on an "AS IS" BASIS,<br>
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.<br>
# See the License for the specific language governing permissions and<br>
# limitations under the License.<br>
<br>
################################################################<br>
# Jitsi Setup<br>
<br>
# Jitsi wants the hostname to be a FQDN like in the BSD side of the<br>
# world and not a short name as is standard in the Trisquel, Mint,<br>
# Ubuntu, Devuan, Debian, part of the world.<br>
case $(hostname) in<br>
*.*) : okay, has dots ;;<br>
*) echo "Jitsi requires hostname to be a FQDN." 1>&2; exit 1;;<br>
esac<br>
<br>
# Jitsi wants the /etc/hosts to bind the FQDN to the public IP address<br>
# and not to a loopback address. (Jitsi does not like 127.0.1.1 as is<br>
# typically done.) Something that will look like this following line.<br>
# 93.184.216.34 <a href="http://jitsi3p.fsf.org" rel="noreferrer" target="_blank">jitsi3p.fsf.org</a> jitsi3p<br>
# Ensure this is the case in the event it was provisioned otherwise.<br>
<br>
# ip addr show will produce a line like this line<br>
# inet <a href="http://93.184.216.34/24" rel="noreferrer" target="_blank">93.184.216.34/24</a> brd 93.184.216.255 scope global eth0<br>
# Grab that line and extract the IP address from it.<br>
ipv4=$(ip addr show | awk '$1=="inet"&&$NF!="lo"{print$2}' | awk -F/ '{print$1;exit}')<br>
# Use this IPv4 address and the hostnames to construct the desired line.<br>
etchostsline="$ipv4 <a href="http://jitsi.member.fsf.org" rel="noreferrer" target="_blank">jitsi.member.fsf.org</a> jitsi $hostname $host"<br>
# Create a BRE Basic Regular Expression to look for this pattern but<br>
# ensure some flexibility ignoring differences of whitespace.<br>
etchostspattern=$(echo "$etchostsline" | sed 's/ /[[:space:]][[:space:]]*/')<br>
etchostspattern=$(echo "$etchostspattern" | sed 's/\./\\./g')<br>
if ! grep -q "$etchostspattern" /etc/hosts; then<br>
if grep -q "^[[:space:]]*$ipv4[[:space:]]" /etc/hosts; then<br>
# The IP address is there. Edit it in place.<br>
sed --in-place "s/^[[:space:]]*$ipv4[[:space:]].*/$etchostsline/" /etc/hosts<br>
else<br>
# The IP address is not there. Append it to the end.<br>
echo "$etchostsline" >> /etc/hosts<br>
fi<br>
fi<br>
# At this point the desired line exists in /etc/hosts even if it was<br>
# not initially provisioned this way.<br>
<br>
# Jitsi repositores use https transport.<br>
debian_install apt-transport-https<br>
<br>
# Ubuntu systems need the "universe" repository available.<br>
# apt-add-repository universe<br>
<br>
# Setup up prosody 3rd party repository. Have we gotten the key? If<br>
# not then get it and install it.<br>
pkfile="/etc/apt/keyrings/prosody-debian-packages.key"<br>
if [ ! -f "$pkfile" ]; then<br>
curl -sL <a href="https://prosody.im/files/prosody-debian-packages.key" rel="noreferrer" target="_blank">https://prosody.im/files/prosody-debian-packages.key</a> -o "$pkfile"<br>
fi<br>
# Jitsi wants to use $(lsb_release -sc) to get a release name like<br>
# "jammy" but Trisquel 11 will produce "aramo" there. Jitsi has a<br>
# repository for Ubuntu Jammy but not Trisquel Aramo. Use the Ubuntu<br>
# Jammy name for the repo and avoid using the Jitsi scripted way of<br>
# using $(lsb_release -sc) to get the name.<br>
pdsfile="/etc/apt/sources.list.d/prosody-debian-packages.list"<br>
if [ ! -f "$pdsfile" ]; then<br>
cat >"$pdsfile" <<'EOF'<br>
deb [signed-by=/etc/apt/keyrings/prosody-debian-packages.key] <a href="http://packages.prosody.im/debian" rel="noreferrer" target="_blank">http://packages.prosody.im/debian</a> jammy main<br>
EOF<br>
fi<br>
<br>
if [ ! -f /usr/share/keyrings/jitsi-keyring.gpg ]; then<br>
curl -sL <a href="https://download.jitsi.org/jitsi-key.gpg.key" rel="noreferrer" target="_blank">https://download.jitsi.org/jitsi-key.gpg.key</a> |<br>
gpg --dearmor > /usr/share/keyrings/jitsi-keyring.gpg<br>
fi<br>
if [ ! -f /etc/apt/sources.list.d/jitsi-stable.list ]; then<br>
cat >/etc/apt/sources.list.d/jitsi-stable.list <<EOF<br>
deb [signed-by=/usr/share/keyrings/jitsi-keyring.gpg] <a href="https://download.jitsi.org" rel="noreferrer" target="_blank">https://download.jitsi.org</a> stable/<br>
EOF<br>
fi<br>
<br>
# Jitsi documents using lua5.2 but of course we have lua5.4 instead.<br>
debian_install lua5.4<br>
<br>
privkey="/var/local/dehydrated/certs/<a href="http://jitsi.member.fsf.org/privkey.pem" rel="noreferrer" target="_blank">jitsi.member.fsf.org/privkey.pem</a>"<br>
if [ ! -f "$privkey" ]; then<br>
# No certificate exists. Bootstrap one.<br>
<br>
if [ ! -f /etc/nginx/sites-available/bootstrap-https ]; then<br>
cat >/etc/nginx/sites-available/bootstrap-https <<'EOF'<br>
server {<br>
server_name <a href="http://jitsi.member.fsf.org" rel="noreferrer" target="_blank">jitsi.member.fsf.org</a>;<br>
listen 80;<br>
listen [::]:80;<br>
location /.well-known { root /var/local/dehydrated/www; }<br>
root /var/www/html;<br>
index index.html index.nginx-debian.html;<br>
}<br>
EOF<br>
fi<br>
symlink ../sites-available/bootstrap-https /etc/nginx/sites-enabled/<br>
nginx -s reload<br>
# Sometimes there is a server or network error. That causes noise to<br>
# the cron mail. Instead retry just a little as the problems are<br>
# almost always transient glitches. Example of one problem.<br>
# ERROR: Problem connecting to server (get for <a href="https://acme-v02.api.letsencrypt.org/directory" rel="noreferrer" target="_blank">https://acme-v02.api.letsencrypt.org/directory</a>; curl returned with 6)<br>
logfile=/var/log/dehydrated/dehydrated.log<br>
count=3<br>
while [ $count -gt 0 ]; do<br>
count=$(($count - 1))<br>
# Run the dehydrated script as the user.<br>
su -s /bin/sh -c 'TMPDIR=/tmp dehydrated --cron' dehydrated >"$logfile" 2>&1<br>
if ! grep -q -i "^ERROR: Problem connecting to server" "$logfile"; then<br>
break<br>
fi<br>
sleep 15<br>
done<br>
# Example error message logged to file:<br>
# ERROR: Challenge is invalid! (returned: invalid) (result: {<br>
if grep -q -i error "$logfile"; then<br>
cat "$logfile" 1>&2<br>
exit 1<br>
fi<br>
# It worked and we got a certificate.<br>
# Discard the bootstrapping config and place in the real config.<br>
rm -f /etc/nginx/sites-enabled/bootstrap-https<br>
fi<br>
<br>
exit 0<br>
<br>
At this point I have not yet automated the next setup. I have to do<br>
this manually at this point.<br>
<br>
apt-get install jitsi-meet<br>
<br>
When it asks about certificates choose "I want to use my own<br>
certificate" and provide it with the path to our let's encrypt<br>
certificate.<br>
<br>
ssl_certificate /var/local/dehydrated/certs/<a href="http://jitsi.member.fsf.org/fullchain.pem" rel="noreferrer" target="_blank">jitsi.member.fsf.org/fullchain.pem</a>;<br>
ssl_certificate_key /var/local/dehydrated/certs/<a href="http://jitsi.member.fsf.org/privkey.pem" rel="noreferrer" target="_blank">jitsi.member.fsf.org/privkey.pem</a>;<br>
<br>
Configuring jitsi-videobridge2<br>
<br>
The value of the domain that is set in the Jitsi Videobridge installation.<br>
The domain of the current installation (e.g. <a href="http://meet.jitsi.com" rel="noreferrer" target="_blank">meet.jitsi.com</a>):<br>
<a href="http://jitsi.member.fsf.org" rel="noreferrer" target="_blank">jitsi.member.fsf.org</a><br>
<br>
Configuring jitsi-meet-web-config<br>
<br>
Jitsi Meet requires an SSL certificate. This installer can generate<br>
one automatically for your using "Let’s Encrypt". This is the<br>
recommended and simplest option for most installations. In the<br>
event you need to use a certificate of your own, you can configure<br>
its location which defaults to /etc/ssl/--domain.name--.key for the<br>
key and /etc/ssl/--domain.name--.crt for the certificate.<br>
If you are a developer and are only looking for a quick way to test<br>
basic Jitsi Meet functionality then this installer can also generate<br>
a self-signed certificate.<br>
SSL certificate<br>
Let's Encrypt certificates<br>
I want to use my own certificate <-- pick this one<br>
Generate a new self-signed certificate<br>
<br>
Configuring jitsi-meet-web-config<br>
<br>
The full path to the SSL key file on the server. If it has not been<br>
uploaded, now is a good time to do so.<br>
Full local server path to the SSL key file:<br>
<br>
/var/local/dehydrated/certs/<a href="http://jitsi.member.fsf.org/privkey.pem" rel="noreferrer" target="_blank">jitsi.member.fsf.org/privkey.pem</a><br>
<br>
Configuring jitsi-meet-web-config<br>
<br>
The full path to the SSL certificate file on the server. If you<br>
haven't uploaded it, now is a good time to upload it in another<br>
console. Full local server path to the SSL certificate file:<br>
<br>
/var/local/dehydrated/certs/<a href="http://jitsi.member.fsf.org/fullchain.pem" rel="noreferrer" target="_blank">jitsi.member.fsf.org/fullchain.pem</a><br>
<br>
Configuring jitsi-meet-web-config<br>
<br>
You can easily add dial-in support to your meetings. To allow this we<br>
would need your permission to create a free JaaS (Jitsi as a Service)<br>
account for you.<br>
Add telephony to your Jitsi meetings?<br>
No<br>
<br>
After installing jitsi-meet then replace the upstream index.html<br>
file with the FSF customized one. Install a dpkg diversion so that<br>
package upgrades won't overwrite our customized file.<br>
<br>
/usr/share/jitsi-meet/index.html<br>
<br>
dpkg-divert --divert /usr/share/jitsi-meet/index.html.upstream --rename /usr/share/jitsi-meet/index.html<br>
cp /usr/share/jitsi-meet/index.html.upstream /usr/share/jitsi-meet/index.html<br>
<br>
root@jitsi4p:~# dpkg -l | grep -e prosody -e jitsi<br>
ii jitsi-meet 2.0.9111-1 all WebRTC JavaScript video conferences<br>
ii jitsi-meet-prosody 1.0.7658-1 all Prosody configuration for Jitsi Meet<br>
ii jitsi-meet-web 1.0.7658-1 all WebRTC JavaScript video conferences<br>
ii jitsi-meet-web-config 1.0.7658-1 all Configuration for web serving of Jitsi Meet<br>
ii jitsi-videobridge2 2.3-61-g814bffd6-1 all WebRTC compatible Selective Forwarding Unit (SFU)<br>
ii lua-basexx 0.4.1-jitsi1 all baseXX encoding/decoding library for Lua<br>
ii lua-cjson:amd64 2.1.0.10-jitsi1 amd64 JSON parser/encoder for Lua<br>
ii prosody 0.12.4-1~jammy1 amd64 Lightweight Jabber/XMPP server<br>
<br>
root@jitsi4p:~# dpkg -l | grep -e prosody -e jitsi | awk '{print$2}'<br>
jitsi-meet<br>
jitsi-meet-prosody<br>
jitsi-meet-web<br>
jitsi-meet-web-config<br>
jitsi-videobridge2<br>
lua-basexx<br>
lua-cjson:amd64<br>
prosody<br>
<br>
At that point things are usually working. Hopefully. If it is not<br>
working I have found it really impossible to debug. Everything uses<br>
encryption everywhere between the different parts of itself. If<br>
anything changes anywhere then usually the entire system is broken and<br>
it is easier to discard the VM and then start again. Hence the need<br>
to have most of the setup scripted and automated.<br>
<br>
Bob<br>
</blockquote></div>
</blockquote></div>