textbelt/Dockerfile

85 lines
3.7 KiB
Docker
Raw Normal View History

# can use an alternative base image as well
FROM phusion/baseimage:0.9.19
# set your node version, if desired
RUN curl -sL https://deb.nodesource.com/setup_4.x | bash -
RUN apt-get install -y nodejs
# install other dependencies
# install a local redis server - per http://redis.io/topics/quickstart
RUN curl -O http://download.redis.io/redis-stable.tar.gz
RUN tar xvzf redis-stable.tar.gz
RUN mv redis-stable /opt/redis-stable
# for access to make
RUN apt-get install -y --reinstall build-essential
RUN cd /opt/redis-stable && make && cd ..
RUN rm redis-stable.tar.gz
RUN mkdir -p /etc/redis
RUN mkdir -p /var/redis
# make customizations to the redis conf as needed
RUN mkdir -p /var/redis/6379
RUN cp /opt/redis-stable/utils/redis_init_script /etc/init.d/redis_6379
RUN sed -i -- 's|daemonize no|daemonize yes|g' /opt/redis-stable/redis.conf
RUN sed -i -- 's|pidfile /var/run/redis.pid|pidfile /var/run/redis_6379.pid|g' /opt/redis-stable/redis.conf
#RUN sed -i -- 's|port 6379|port 8080|g' /opt/redis-stable/redis.conf
#RUN sed -i -- 's|loglevel notice|loglevel debug|g' /opt/redis-stable/redis.conf
RUN sed -i -- 's|logfile ""|logfile /var/log/redis_6379.log|g' /opt/redis-stable/redis.conf
RUN sed -i -- 's|dir ./|dir /var/redis/6379|g' /opt/redis-stable/redis.conf
RUN cp /opt/redis-stable/redis.conf /etc/redis/6379.conf
RUN cp /opt/redis-stable/src/redis-server /usr/local/bin/
RUN cp /opt/redis-stable/src/redis-cli /usr/local/bin/
RUN update-rc.d redis_6379 defaults
# now should be able to start redis with: /etc/init.d/redis_6379 start
# install mutt locally, and install it silently/non-interactively
ENV DEBIAN_FRONTEND noninteractive
RUN apt-get install -y mutt
# install a local nginx for reverse proxy / load balancing, or IP rate limiting?
#RUN apt-get update
#RUN apt-get install -y nginx
# any nginx customizations & running as service setup go here...
# TODO: to enable accurate IP rate limiting, the reverse proxy should be configured to set the `X-Real-IP` header
# install screen - in case want to start services manually in background and switch between them as windows via screen
RUN apt-get install -y screen
# Create app directory
RUN mkdir -p /opt/textbelt/
ENV HOME /opt/textbelt/
WORKDIR /opt/textbelt/
COPY package.json /opt/textbelt/
# Install node.js dependencies
RUN apt-get install -y git
RUN npm install
# Bundle app source
COPY . /opt/textbelt/
# (any) textbelt customizations (to save in docker image)
RUN sed -i -- "s|fromAddress = 'foo@bar.com'|fromAddress = 'me@mydomain.com'|g" /opt/textbelt/lib/text.js
#RUN rm /opt/textbelt/lib/text.js--
# Clean up APT when done.
RUN apt-get clean && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
EXPOSE 9090
# Use baseimage-docker's init process.
CMD ["/sbin/my_init"]
# now you can use try using the docker image
# - as a server: (then make REST calls to it to send message)
# run command : docker run --rm -it -p 9090:9090 typpo/textbelt node server/app.js
# - as node.js module/client:
# run command: docker run --rm -it typpo/textbelt node
# then copy/paste or type in the code to send message as shown README example
# or run command: docker run --rm -it typpo/textbelt node pathTo/yourScript.js
# assuming your script has the code that calls the textbelt module to send message
# or run command: docker run --rm -it -p 9090:9090 typpo/textbelt bash
# to be taken to the shell for you to debug and test things out
# e.g. start/stop/query redis, nginx, test/use mutt
# run textbelt as module in node shell, node script, or start textbelt server
# NOTE: if you use an external redis server and/or external reverse proxy / load balancer
# you will need to handle the network config and mapping such that the textbelt
# docker container can talk to those servers (which may or may not be in their own docker containers)