-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathDockerfile.external-db
69 lines (52 loc) · 2.29 KB
/
Dockerfile.external-db
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
FROM ubuntu:22.04
ENV DEBIAN_FRONTEND=noninteractive
# Instalando fontes que o PEC utiliza para impressão
RUN apt-get update && apt-get install -y \
locales \
&& locale-gen "pt_BR.UTF-8" \
&& dpkg-reconfigure --frontend=noninteractive locales \
&& apt-get install -y \
wget apt-utils gnupg2 software-properties-common file libfreetype6 ntp ttf-mscorefonts-installer fontconfig
RUN fc-cache -fv
RUN chmod -R 777 /usr/share/fonts/truetype/msttcorefonts
# Adicionar chave pública diretamente da URL correta
RUN wget -O - https://apt.corretto.aws/corretto.key | gpg --dearmor -o /usr/share/keyrings/corretto-keyring.gpg
# Adicionar o repositório do Corretto, vinculando à chave
RUN echo "deb [signed-by=/usr/share/keyrings/corretto-keyring.gpg] https://apt.corretto.aws stable main" | tee /etc/apt/sources.list.d/corretto.list
# Atualizar repositórios e instalar o Corretto 17 LTS
RUN apt-get update && apt-get install -y java-17-amazon-corretto-jdk
# Enable all repositories
RUN sed -i 's/# deb/deb/g' /etc/apt/sources.list
# Instalações para uso do cron e configurações para utilização do systemd
RUN apt-get update && \
apt-get install --no-install-recommends -y \
dbus systemd systemd-cron rsyslog iproute2 python-is-python3 python3 python3-apt sudo bash ca-certificates && \
apt-get clean && \
rm -rf /usr/share/doc/* /usr/share/man/* /var/lib/apt/lists/* /tmp/* /var/tmp/*
ARG JAR_FILENAME
ARG HTTPS_DOMAIN
ARG DB_URL
ARG POSTGRES_PASS
ARG POSTGRES_USER
# Promovendo ARGS para ENV para uso no install.sh que roda dentro do entrypoint
ENV JAR_FILENAME=${JAR_FILENAME}
ENV DB_URL=${DB_URL}
ENV POSTGRES_PASS=${POSTGRES_PASS}
ENV POSTGRES_USER=${POSTGRES_USER}
ENV HTTPS_DOMAIN=${HTTPS_DOMAIN}
# criando diretórios para uso posterior
RUN mkdir -p /opt/e-SUS/webserver/chaves
RUN mkdir /backups
RUN mkdir -p /var/www/html
WORKDIR /var/www/html
# ATENÇÃO: Esse é um Dockerfile de instalação e não de atualização
# Removendo arquivos de configuração anteriores, para instalar do zero.
RUN if [ -f /etc/pec.config ]; then rm /etc/pec.config; fi
COPY ./${JAR_FILENAME} ${JAR_FILENAME}
COPY ./install.sh .
# Copiando arquivos de backup
COPY *.sql /backups
COPY *.backup /backups
COPY entrypoint.sh /entrypoint.sh
RUN chmod +x /entrypoint.sh
ENTRYPOINT ["/entrypoint.sh"]