This is a first experimental release of the ultra-fast image server that automatically resizes images taken from S3.
Clone the repo:
git clone git@github.com:ChrisCinelli/image-server.git
cd image-server
Create a bucket on S3 if you want to use S3 for caching (this is recommended) Make sure you copy and edit run-docker-template.sh with the your AWS keys and bucket name.
Now you should be able to run it. The server will be reachable at your dockerhost IP. Try http://dockerhost:8081/w200/h100/for/http://images.dailytech.com/nimage/Nyan_Cat_Wide.jpg
(Tested on Ubuntu 13.04). The image server relies on graphicsmagick. You should install the latest version available. You can find it on sourceforge at: http://sourceforge.net/projects/graphicsmagick/files/graphicsmagick/
Then you need to install also the jpeg and png extensions, otherwise it won't convert the images. You can find them here: http://www.imagemagick.org/download/delegates/
Every packet should be installed with the usual procedure:
.\configure
make
make test
sudo make -n install
sudo make install
After that, try to type "gm version" at the console. If you get:
gm: error while loading shared libraries: libjpeg.so.9: cannot open shared object file: No such file or directory
Try with:
sudo ranlib /usr/local/lib/libjpeg.a
sudo ldconfig /usr/local/lib
This image server is configured by environment variables, you should set them like these:
export AWS_KEY=YOUR_AWS_KEY_HERE
export AWS_SECRET=YOUR_AWS_SECRET_HERE
export S3_BUCKET=YOUR_BUCKET_HERE
Execute the following commands in your terminal:
git clone git@github.com:ChrisCinelli/image-server.git
cd image-server
npm install
node ./image-server.js
Execute the following commands in your terminal:
git clone https://github.com/njvitto/blomming-image-server
cd blomming-image-server
gem install heroku
heroku create <YOUR_APP_NAME>
git push heroku
This image server is configured by environment variables, you should set them like these:
heroku config:set AWS_KEY=YOUR_AWS_KEY_HERE
heroku config:set AWS_SECRET=YOUR_AWS_SECRET_HERE
heroku config:set S3_BUCKET=YOUR_BUCKET_HERE
Once started, resizing image is really easy, it's just needed to call a specific URL.
Creates an image whose sizes are at max the ones specified.
curl http://<YOUR_URL>/w<WIDTH>/h<HEIGHT>/for/<PATH_ON_S3_OF_THE_IMAGE>
curl http://<YOUR_URL>/w<WIDTH>/for/<PATH_ON_S3_OF_THE_IMAGE>
Creates an image whose sizes are exactly the ones specified. The reduced image is obtained "cutting out" the exceding part of the image to fit the new aspect ratio.
curl http://<YOUR_URL>/cover/w<WIDTH>/h<HEIGHT>/for/<PATH_ON_S3_OF_THE_IMAGE>
Creates an image whose sizes are exactly the ones specified. The reduced image is obtained picking it from a rectangle of the same sizes from the center of the image.
curl http://<YOUR_URL>/crop/w<WIDTH>/h<HEIGHT>/for/<PATH_ON_S3_OF_THE_IMAGE>
This server operates in the following manner:
- tries to get the resized image, if so it returns it to the user;
- if there is no resized image, it resizes it using the
convert
utility from imagemagick; - it forwards the resized image to the user;
- it loads the resized image to S3 for later usage.