Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bezhermoso/jekyll-nginx-proxy-with-docker-demo
Companion to Docker: A Minimalist's Choice
https://github.com/bezhermoso/jekyll-nginx-proxy-with-docker-demo
docker jekyll nginx nginx-proxy
Last synced: about 2 months ago
JSON representation
Companion to Docker: A Minimalist's Choice
- Host: GitHub
- URL: https://github.com/bezhermoso/jekyll-nginx-proxy-with-docker-demo
- Owner: bezhermoso
- Created: 2015-10-15T14:29:31.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2015-10-29T20:38:21.000Z (about 9 years ago)
- Last Synced: 2023-08-02T04:57:03.168Z (over 1 year ago)
- Topics: docker, jekyll, nginx, nginx-proxy
- Language: JavaScript
- Homepage: http://activelamp.com/blog/devops/docker-a-minimalists-choice/
- Size: 289 KB
- Stars: 1
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Demo: Jekyll + nginx proxy via Docker
> This has been tried and tested on __Mac OS X__. It _should_ work on __Linux__ as well. However, Windows is not guranteed, as Jekyll does not
officially support it.### Prerequisites
* Ruby 2.0+
* Python 2.7+
* NodeJS v0.12.* with `npm` v2.0+
* [Bower](http://bower.io/). (get via `npm install -g bower`)
* Docker (you can get it through [Docker Toolbox](https://www.docker.com/toolbox))### Getting Started
Run the following commands on the project root:
```
> bundle install --path vendor/bundle
> npm install && bower install
```Get your local IP address and set it as the `LOCAL_IP` environment variable:
```
> export LOCAL_IP=192.168.99.1
```> This IP address should be what Docker can use to talk to your host machine. `192.168.99.1` should be what it is for a default
install of Docker.### Serving the static site
Run:
```
> grunt serve
```Once complete, a browser window should eventually open up pointing to `http://localhost:8080`.
__To hit the proxy, you will have to access the site through `http://192.168.99.1`.__
Test the following redirects to see it in action:
`http://192.168.99.1/activelamp => http://activelamp.com`
`http://182.168.99.1/bienvenue => http://192.168.99.1/jekyll/update/2015/10/15/welcome-to-jekyll/`
The first redirect is configured in `_config.yml`. The second one is in `app/_posts/2016-10-15-welcome-to-jekyll.md`.
### Grunt config & tasks
The `grunt proxy` task is the entry task that orchestrates the building and running of the nginx proxy. Checkout
the [`Gruntfile.js`](https://github.com/bezhermoso/jekyll-nginx-proxy-with-docker-demo/blob/master/Gruntfile.js) file for how it is done. Its a rather long file (~300 lines), so I added `@notes` in comments preceeding all pertinent parts.Majority of the implementation can be found in [`grunt/tasks/nginx-proxy/index.js`](https://github.com/bezhermoso/jekyll-nginx-proxy-with-docker-demo/blob/master/grunt/tasks/nginx-proxy/index.js).
### Jekyll::NginxConfig
You can find more info about this module here: https://github.com/activelamp/jekyll-nginx-config
## Questions?
For questions, comments, and feedbacks, you can shoot me an email at [[email protected]](mailto:[email protected]).