-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathDockerfile
90 lines (85 loc) · 3.71 KB
/
Dockerfile
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
FROM alpine:3.11
MAINTAINER YesInteractive- http://yes-interactive.com
# Install modules and updates
RUN apk update \
&& apk --no-cache add \
openssl \
apache2 \
apache2-ssl \
apache2-http2 \
git \
unzip \
# Install PHP from community
&& apk --no-cache --repository http://dl-4.alpinelinux.org/alpine/v3.11/community/ add \
php7=="7.3.22-r0" \
php7-apache2 \
php7-bcmath \
php7-bz2 \
php7-calendar \
php7-common \
php7-ctype \
php7-curl \
php7-dom \
php7-json \
php7-mbstring \
php7-mcrypt \
php7-memcached \
php7-mysqlnd \
php7-opcache \
php7-openssl \
php7-pdo \
php7-pdo_mysql \
php7-pdo_sqlite \
php7-phar \
php7-session \
php7-sockets \
php7-xml \
php7-xmlreader \
&& rm /var/cache/apk/* \
# Run required config / setup for apache
# Ensure apache can create pid file
#&& mkdir /run/apache2 \
# Fix group
&& sed -i -e 's/Group apache/Group www-data/g' /etc/apache2/httpd.conf \
# Fix ssl module
&& sed -i -e 's/LoadModule ssl_module lib\/apache2\/mod_ssl.so/LoadModule ssl_module modules\/mod_ssl.so/g' /etc/apache2/conf.d/ssl.conf \
&& sed -i -e 's/LoadModule socache_shmcb_module lib\/apache2\/mod_socache_shmcb.so/LoadModule socache_shmcb_module modules\/mod_socache_shmcb.so/g' /etc/apache2/conf.d/ssl.conf \
# Enable modules
&& sed -i -e 's/#LoadModule rewrite_module modules\/mod_rewrite.so/LoadModule rewrite_module modules\/mod_rewrite.so/g' /etc/apache2/httpd.conf \
# Change document root to /app
&& mkdir /app && chown -R apache:apache /app \
&& sed -i -e 's/\/var\/www\/localhost\/htdocs/\/app/g' /etc/apache2/httpd.conf \
&& sed -i -e 's/\/var\/www\/localhost\/htdocs/\/app/g' /etc/apache2/conf.d/ssl.conf \
# moved apache logging to stdout and stderr
&& sed -i -e 's/ErrorLog logs\/error.log/ErrorLog \/dev\/stderr/g' /etc/apache2/httpd.conf \
&& sed -i -e 's/CustomLog logs\/access.log combined/CustomLog \/dev\/stdout common/g' /etc/apache2/httpd.conf \
&& sed -i -e 's/ErrorLog logs\/ssl_error.log/ErrorLog \/dev\/stderr/g' /etc/apache2/conf.d/ssl.conf \
&& sed -i -e 's/TransferLog logs\/ssl_access.log/TransferLog \/dev\/stdout/g' /etc/apache2/conf.d/ssl.conf \
&& sed -i -e 's/CustomLog logs\/ssl_request.log/#CustomLog \/dev\/stdout/g' /etc/apache2/conf.d/ssl.conf \
# Change default ports
&& sed -i -e 's/Listen 80/Listen 8100/g' /etc/apache2/httpd.conf \
&& sed -i -e 's/443/8143/g' /etc/apache2/conf.d/ssl.conf \
# Allow for custom apache configs
&& mkdir /etc/apache2/conf.d/custom \
&& echo '' >> /etc/apache2/httpd.conf \
&& echo 'IncludeOptional /etc/apache2/conf.d/custom/*.conf' >> /etc/apache2/httpd.conf \
# Fix modules
&& sed -i 's#AllowOverride None#AllowOverride All#' /etc/apache2/httpd.conf \
&& sed -i -e 's/ServerRoot \/var\/www/ServerRoot \/etc\/apache2/g' /etc/apache2/httpd.conf \
&& mv /var/www/modules /etc/apache2/modules \
&& mv /var/www/run /etc/apache2/run \
&& mv /var/www/logs /etc/apache2/logs \
# Empty /var/www and add an index.php to show phpinfo()
&& rm -rf /var/www/* \
&& echo '<?php phpinfo(); ?>' > /app/phpinfo.php \
&& wget --header '' https://github.com/yesinteractive/kong-map/archive/main.zip -P /app \
&& unzip /app/main.zip -d /app \
&& rm -rf /app/main.zip \
&& cp -r /app/kong-map-main/. /app \
&& rm -rf /app/kong-map-main \
&& chmod 777 /app/controllers/deck/kong.yaml
WORKDIR /app
# Export http and https
EXPOSE 8100 8143
# Run apache in foreground
CMD ["/usr/sbin/httpd", "-D", "FOREGROUND"]