forked from UhuruSoftware/origin-server
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDockerfile
56 lines (47 loc) · 2.96 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
# openshift-origin-broker
#
# To build, cd into the origin-server source directory and run:
# docker build -rm -t openshift-origin-broker .
#
# To run origin-broker:
# docker run -d -i -t -e "MONGO_HOST_PORT=<mongo_host_port>" -e "AUTH_SALT=<broker_auth_salt>" -p <port_on_host>:443 openshift-origin-broker
# Where MONGO_HOST_PORT and AUTH_SALT are the config values as defined in broker.conf and <port_on_host> is the port you want to map
# You can get an AUTH_SALT by running "openssl rand -base64 64"
# Any values defined in broker.conf can be overridden by passing additional -e flags during the run command, alternatively you can
# modify the broker.conf file in your source and re-build instead of passing -e flags.
#
# To run oo-* admin commands:
# docker run -rm -i -t -e "MONGO_HOST_PORT=<mongo_host_port>" -e "AUTH_SALT=<broker_auth_salt>" openshift-origin-broker /bin/bash --login
# Where MONGO_HOST_PORT and AUTH_SALT are the config values as defined in broker.conf
FROM fedora
RUN yum -y install which gcc-c++ openssl-devel readline libyaml-devel readline-devel zlib zlib-devel openssl
# Install and setup ruby 1.9.3 using rvm and install bundler
RUN curl -L --connect-timeout 30 get.rvm.io | bash -s stable
RUN /bin/bash --login -c "rvm install 1.9.3"
RUN /bin/bash --login -c "rvm use 1.9.3 --default"
RUN /bin/bash --login -c "gem install bundler"
# Setup default ssl key and cert
RUN openssl req -new -x509 -nodes -out /etc/pki/tls/certs/localhost.crt -keyout /etc/pki/tls/private/localhost.key -batch
# BROKER_SOURCE tells the broker to include gems based on source locations
ENV BROKER_SOURCE 1
# OPENSHIFT_ENABLE_ENV_CONFIG tells the broker to check for config values as environment variables before checking the broker.conf file
ENV OPENSHIFT_ENABLE_ENV_CONFIG 1
# Add all necessary source from origin-server
ADD util /usr/sbin
ADD common /var/www/openshift/common
ADD admin-console /var/www/openshift/admin-console
ADD broker-util /var/www/openshift/broker-util
ADD plugins /var/www/openshift/plugins
ADD broker /var/www/openshift/broker
ADD controller /var/www/openshift/controller
# Copy configuration files to expected locations
RUN mkdir -p ~/.openshift && cp /var/www/openshift/broker/misc/docker_broker_plugins.rb ~/.openshift/broker_plugins.rb
RUN mkdir -p /etc/openshift && cp -r /var/www/openshift/broker/conf/* /etc/openshift/
RUN cp /var/www/openshift/plugins/dns/bind/conf/openshift-origin-dns-bind.conf.example /etc/openshift/plugins.d/openshift-origin-dns-bind.conf
RUN cp /var/www/openshift/plugins/msg-broker/mcollective/conf/openshift-origin-msg-broker-mcollective.conf.example /etc/openshift/plugins.d/openshift-origin-msg-broker-mcollective.conf
# Install broker oo-* scripts
RUN cp /var/www/openshift/broker-util/oo-* /usr/sbin/ && chmod 750 /usr/sbin/oo-*
RUN cp /var/www/openshift/broker-util/lib/* /usr/local/rvm/rubies/ruby-1.9.3-*/lib/ruby/1.9.1/
WORKDIR /var/www/openshift/broker
RUN /bin/bash --login -c "bundle install"
CMD /bin/bash --login -c "bundle exec rails s puma"