Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Updated script to work with node 5.x.x, ubuntu trusty #3

Open
wants to merge 15 commits into
base: master
Choose a base branch
from
57 changes: 40 additions & 17 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -1,23 +1,46 @@
# Yeoman with some generators and prerequisites
FROM ubuntu:saucy
MAINTAINER Kevin Littlejohn <[email protected]>
#Build an image that can run generator-gulp-angular
FROM ubuntu:trusty
MAINTAINER Ajay Ganapathy <[email protected]>
RUN apt-get -yq update && apt-get -yq upgrade
#
# Install pre-requisites
RUN apt-get -yq install python-software-properties software-properties-common \
python g++ make git ruby-compass libfreetype6
# Install node.js, then npm install yo and the generators
RUN add-apt-repository ppa:chris-lea/node.js -y \
&& apt-get -yq update \
RUN apt-get -yq install python-software-properties \
software-properties-common \
python \
g++ \
make \
git \
libfreetype6
#
# Install node.js, yo, gulp, bower, and generator-gulp-angular
RUN apt-get install -yq curl \
&& curl -sL https://deb.nodesource.com/setup_5.x | sudo -E bash - \
&& apt-get -yq install nodejs \
&& npm install yo -g \
&& npm install -g generator-webapp generator-angular
# Add a yeoman user because grunt doesn't like being root
RUN adduser --disabled-password --gecos "" yeoman; \
&& apt-get -yq update \
&& npm install -g yo \
gulp \
bower \
generator-gulp-angular \
modernizr \
&& npm update
#
# Add a yeoman user because yeoman doesn't like being root
RUN adduser --disabled-password --gecos "" --shell /bin/bash yeoman; \
echo "yeoman ALL=(ALL) NOPASSWD:ALL" >> /etc/sudoers
ENV HOME /home/yeoman
#
# set up a directory that will hold the files we sync from the host machine
RUN mkdir /home/yeoman/senior-studio-site \
# set up a directory for global npm packages that does not require root access
&& mkdir /home/yeoman/.npm_global \
&& chmod -R 777 /home/yeoman
ENV NPM_CONFIG_PREFIX /home/yeoman/.npm_global
WORKDIR /home/yeoman/senior-studio-site
VOLUME /home/yeoman/senior-studio-site
#
# allow the host machine to access browsersync on the guest machine
EXPOSE 3000-3001
#
# drop to yeoman user and a bash shell
USER yeoman
WORKDIR /home/yeoman
# Expose the port
EXPOSE 9000
# Always run as the yeoman user
CMD ['/bin/bash']
CMD ["/bin/bash"]
84 changes: 32 additions & 52 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,59 +1,39 @@
## yeoman


**Dockerfile** for base yeoman install, with a few generators pre-installed.

# Dockerized-Yeoman
This dockerfile builds a container with [yeoman](http://yeoman.io), [generator-gulp-angular](https://github.com/swiip/generator-gulp-angular#readme). I wrote this dockerfile because yeoman does not run as the root, and default docker containers run executables as root. This means that if you spin up a docker container and then try to run yeoman, [it will fail](https://github.com/yeoman/yeoman.github.io/issues/282).
### Installation

1. Install [Docker](https://www.docker.io/).

2. `docker run -i -t silarsis/yeoman`

(alternatively, build from github: `docker build -t="silarsis/yeoman" github.com/silarsis/yeoman`)
1. [Set up Docker on Mac OS X.](https://docs.docker.com/mac/ "Docker for Mac Quick Start")
2. Open the Docker CLI from within Kitematic ![Cursor pressing the ‘docker CLI’ button in the lower-left-hand corner of the kitematic window](https://i.imgur.com/quKAxcG.gif)
3. Then change the directory to the `yeoman-docker` folder in this project's root:
```shell
cd ~/my-repository/yeoman-docker
```
Replace `my-repository` with project's root. This folder should contain a file named `dockerfile`.

4. Build the docker image with the following command:
```shell
docker build .
```
The output of this command should look like [this](https://asciinema.org/a/36633).
5. Once the docker image has built, run it:
```shell
docker run -dit my-image-hash
```
Replace `my-image-hash` with the unique identifier that docker gave to your image after building it e.g. [`fa817ac6674d`](https://asciinema.org/a/36633?t=10&autoplay=0).

### Usage

`docker run -i -t silarsis/yeoman`

This will run the container and log you in as the "yeoman" user, ready to "yo".

`docker run -i -t silarsis/yeoman -c grunt serve`

This will run the grunt server inside the container.

### Notes

"sudo" works - if you need root, `sudo -s` will get you there.

The default grunt port (9000) is exposed by default.

Docker hints:

- `docker start -a -i <containerid>` will restart a stopped container and re-attach you to the bash process
- `docker inspect -format '{{ .NetworkSettings.IPAddress }}' <containerid>` will give you the IP address of the currently running container
- `docker run -P -i -t silarsis/yeoman` will map port 9000 to a port on the host, and `docker port <containerid> 9000` will show you what port that ends up on

This Dockerfile should provide a good base image for development work - as an example, based on the [Docker Node.js example](http://docs.docker.io/en/latest/examples/nodejs_web_app/), you could have a Dockerfile that looks like (**untested**, assumes your code is in the same directory as your Dockerfile):

```
FROM silarsis/yeoman
MAINTAINER Kevin Littlejohn "[email protected]"
ADD . /src
RUN cd /src; npm install
EXPOSE 9000
USER yeoman
CMD ["grunt", "serve"]
1. Sync your project's root folder to the docker container's shared volume with Kitematic ![Cursor switching to the docker container’s ‘settings’ tab, then selecting the ‘volumes’ sub-tab, and finally pressing the ‘change’ button next to the volume to connect](https://i.imgur.com/tdJd9qV.gif)
2. Map the docker container ports to the docker host. In this docker container, ports `3000` and `3001` are exposed. Port `3000` is where browser sync serves the site, and port `3001` is where it serves its own control panel. To keep things simple, you might want to map the port on the docker container to the same port number in Kitematic, *i.e.* port `3000` on the docker container maps to the IP address and port `192.168.99.100:3000` in Kitematic, and port `3001` maps to `192.168.99.100:3001`. However, if those ports are already mapped to another application, such as a MongoDB server or docker container, you can map them to whatever available ports you have.![Cursor selecting docker container, then ‘settings’ tab, then ‘ports’ sub-tab, then entering port numbers 3000 and 3001 in the text input fields underneath the ‘MAC IP:PORT’ header](https://i.imgur.com/r2cv7zE.gif)
3. Shell into the docker container. ![Cursor pressing the ‘exec’ button in kitematic](https://i.imgur.com/krIbsQg.gif)
3. serve the site with the following command:
```shell
gulp serve
```
4. Find the IP Address to which the site is being served in kitematic, and enter it into your browser’s URL bar to navigate to the running site. ![`gulp serve` command entered into the docker container shell, followed by cursor switching to the ‘settings’ tab and ‘ports’ sub-tab before hovering over the IP address listed under ‘configure ports’ ](https://i.imgur.com/uT14x81.gif)

and run with `docker build -t <username>/yeoman-dev .`; `docker run -P -d <username>/yeoman-dev`


In application source, put in Gruntfile.js hostname:0.0.0.0 for expose port 9000 on the host for any IP:
### Roadmap
This is not a full-fledged project with semantic versioning. However, I might add the following features later if it is convenient for me:
- bash completions
- automatically run `npm install && bower install` on container startup as yeoman user, before dropping to a shell.

connect: {
options: {
port: 9000,
// Change this to '0.0.0.0' to access the server from outside.
hostname: '0.0.0.0',
livereload: 35729
},
> If you take the time to add these features, just send me a PR and I’ll merge them in!