Skip to content

Commit

Permalink
Add installation instruction for Ubuntu 24.04
Browse files Browse the repository at this point in the history
  • Loading branch information
jburel committed Nov 4, 2024
1 parent 301c6ea commit ffbf21c
Show file tree
Hide file tree
Showing 6 changed files with 162 additions and 0 deletions.
52 changes: 52 additions & 0 deletions linux/install_ubuntu2404.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
#!/bin/bash

set -e -u -x

OMEROVER=${OMEROVER:-latest}
PGVER=${PGVER:-pg15}
ICEVER=${ICEVER:-ice36}

. settings.env

bash -eux step01_ubuntu_init.sh

# disable daemon restart pop-up:
# see https://stackoverflow.com/questions/73397110/how-to-stop-ubuntu-pop-up-daemons-using-outdated-libraries-when-using-apt-to-i
if [ ! -f /.dockerenv ]; then
echo "\$nrconf{restart} = 'a';" >> /etc/needrestart/needrestart.conf
fi

# install java
bash -eux step01_ubuntu_java_deps.sh

bash -eux step01_ubuntu_deps.sh

# install ice
bash -eux step01_ubuntu2404_ice_deps.sh

cat omero-ice36.env >> /etc/profile

# install Postgres
bash -eux step01_ubuntu2404_pg_deps.sh

bash -eux step02_all_setup.sh

bash -eux step03_all_postgres.sh

cp settings.env step04_all_omero.sh setup_omero_db.sh ~omero-server

bash -eux step01_ubuntu2404_ice_venv.sh
bash -eux step04_all_omero_install.sh

su - omero-server -c "OMEROVER=$OMEROVER ICEVER=$ICEVER bash -eux step04_all_omero.sh"
su - omero-server -c "bash setup_omero_db.sh"


#If you don't want to use the init.d scripts you can start OMERO manually:
#su - omero-server -c ". /home/omero-server/settings.env omero admin start"

bash -eux step06_ubuntu_daemon.sh

bash -eux step07_all_perms.sh

#service omero start
27 changes: 27 additions & 0 deletions linux/step01_ubuntu2404_ice_deps.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
#!/bin/bash

ICEVER=${ICEVER:-ice36}

echo $ICEVER
# Ice installation
if [ "$ICEVER" = "ice36" ]; then
#start-recommended
apt-get update && \
apt-get install -y -q \
db5.3-util \
bzip2 \
libdb++ \
libexpat1 \
libmcpp0 \
openssl \
mcpp \
zlib1g

cd /tmp
wget -q https://github.com/glencoesoftware/zeroc-ice-ubuntu2404-x86_64/releases/download/20240619/Ice-3.6.5-ubuntu2404-x86_64.tar.gz
tar xf Ice-3.6.5-ubuntu2404-x86_64.tar.gz
mv Ice-3.6.5 /opt/ice-3.6.5
echo /opt/ice-3.6.5/lib64 > /etc/ld.so.conf.d/ice-x86_64.conf
ldconfig
#end-recommended
fi
18 changes: 18 additions & 0 deletions linux/step01_ubuntu2404_ice_venv.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
#!/bin/bash

set -e -u -x

VENV_SERVER=${VENV_SERVER:-/opt/omero/server/venv3}
#start-ice-py
# Create a virtual env
python3 -mvenv $VENV_SERVER

# Upgrade pip
$VENV_SERVER/bin/pip install --upgrade pip

# Install the Ice Python binding
$VENV_SERVER/bin/pip install https://github.com/glencoesoftware/zeroc-ice-py-linux-x86_64/releases/download/20240202/zeroc_ice-3.6.5-cp312-cp312-manylinux_2_28_x86_64.whl

# Install server dependencies
$VENV_SERVER/bin/pip install omero-server
#end-ice-py
25 changes: 25 additions & 0 deletions linux/step01_ubuntu2404_pg_deps.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
#!/bin/bash

PGVER=${PGVER:-pg15}

if [ "$PGVER" = "pg14" ]; then
apt-get update
apt-get -y install postgresql
service postgresql start
elif [ "$PGVER" = "pg15" ]; then
#start-recommended
apt-get install -y gnupg
echo "deb http://apt.postgresql.org/pub/repos/apt noble-pgdg main" > /etc/apt/sources.list.d/pgdg.list
wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | apt-key add -
apt-get update
apt-get -y install postgresql-15
service postgresql start
#end-recommended
elif [ "$PGVER" = "pg16" ]; then
apt-get install -y gnupg
echo "deb http://apt.postgresql.org/pub/repos/apt noble-pgdg main" > /etc/apt/sources.list.d/pgdg.list
wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | apt-key add -
apt-get update
apt-get -y install postgresql-16
service postgresql start
fi
28 changes: 28 additions & 0 deletions linux/test/ubuntu2404/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
# Dockerfile for testing the OMERO Linux installation instructions
# Not intended for production use
FROM ubuntu:24.04
MAINTAINER [email protected]

ARG OMEROVER=latest
ARG JAVAVER=openjdk11
ARG ICEVER=ice36
ARG PGVER=pg14

RUN touch /.dockerenv

ENV TZ=Europe/London
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone

RUN echo 'APT::Install-Recommends 0;' > /etc/apt/apt.conf.d/01norecommends \
&& echo 'APT::Install-Suggests 0;' >> /etc/apt/apt.conf.d/01norecommends

ADD omero-install-test.zip /
RUN apt-get update && apt-get -y install unzip && unzip omero-install-test.zip

RUN cd omero-install-test && \
bash install_ubuntu2404.sh && \
bash docker_shutdown_ubuntu.sh
ADD run.sh /home/omero-server/run.sh

EXPOSE 80 4063 4064
CMD ["/bin/bash", "-e", "/home/omero-server/run.sh"]
12 changes: 12 additions & 0 deletions linux/test/ubuntu2404/run.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
#!/bin/bash

service postgresql start

#service crond start # Doesn't work in Docker
cron
service omero-server start
if [ -t 1 ] ; then
exec bash
else
exec tail -F /opt/omero/server/OMERO.server/var/log/*
fi

0 comments on commit ffbf21c

Please sign in to comment.