mirror of https://github.com/docker/docs.git
Formatting
This commit is contained in:
parent
be3e860fa1
commit
34e383c602
|
@ -2,9 +2,6 @@
|
|||
description: Installing and running a redis service
|
||||
keywords:
|
||||
- docker, example, package installation, networking, redis
|
||||
menu:
|
||||
main:
|
||||
parent: engine_dockerize
|
||||
title: Dockerizing a Redis service
|
||||
---
|
||||
|
||||
|
@ -18,15 +15,19 @@ using a link.
|
|||
Firstly, we create a `Dockerfile` for our new Redis
|
||||
image.
|
||||
|
||||
FROM ubuntu:14.04
|
||||
RUN apt-get update && apt-get install -y redis-server
|
||||
EXPOSE 6379
|
||||
ENTRYPOINT ["/usr/bin/redis-server"]
|
||||
```dockerfile
|
||||
FROM ubuntu:14.04
|
||||
RUN apt-get update && apt-get install -y redis-server
|
||||
EXPOSE 6379
|
||||
ENTRYPOINT ["/usr/bin/redis-server"]
|
||||
```
|
||||
|
||||
Next we build an image from our `Dockerfile`.
|
||||
Replace `<your username>` with your own user name.
|
||||
|
||||
$ docker build -t <your username>/redis .
|
||||
```bash
|
||||
$ docker build -t <your username>/redis .
|
||||
```
|
||||
|
||||
## Run the service
|
||||
|
||||
|
@ -39,7 +40,9 @@ Importantly, we're not exposing any ports on our container. Instead
|
|||
we're going to use a container link to provide access to our Redis
|
||||
database.
|
||||
|
||||
$ docker run --name redis -d <your username>/redis
|
||||
```bash
|
||||
$ docker run --name redis -d <your username>/redis
|
||||
```
|
||||
|
||||
## Create your web application container
|
||||
|
||||
|
@ -49,41 +52,53 @@ created with an alias of `db`. This will create a secure tunnel to the
|
|||
`redis` container and expose the Redis instance running inside that
|
||||
container to only this container.
|
||||
|
||||
$ docker run --link redis:db -i -t ubuntu:14.04 /bin/bash
|
||||
```bash
|
||||
$ docker run --link redis:db -i -t ubuntu:14.04 /bin/bash
|
||||
```
|
||||
|
||||
Once inside our freshly created container we need to install Redis to
|
||||
get the `redis-cli` binary to test our connection.
|
||||
|
||||
$ sudo apt-get update
|
||||
$ sudo apt-get install redis-server
|
||||
$ sudo service redis-server stop
|
||||
```bash
|
||||
$ sudo apt-get update
|
||||
$ sudo apt-get install redis-server
|
||||
$ sudo service redis-server stop
|
||||
```
|
||||
|
||||
As we've used the `--link redis:db` option, Docker
|
||||
has created some environment variables in our web application container.
|
||||
|
||||
$ env | grep DB_
|
||||
```bash
|
||||
$ env | grep DB_
|
||||
|
||||
# Should return something similar to this with your values
|
||||
DB_NAME=/violet_wolf/db
|
||||
DB_PORT_6379_TCP_PORT=6379
|
||||
DB_PORT=tcp://172.17.0.33:6379
|
||||
DB_PORT_6379_TCP=tcp://172.17.0.33:6379
|
||||
DB_PORT_6379_TCP_ADDR=172.17.0.33
|
||||
DB_PORT_6379_TCP_PROTO=tcp
|
||||
# Should return something similar to this with your values
|
||||
DB_NAME=/violet_wolf/db
|
||||
DB_PORT_6379_TCP_PORT=6379
|
||||
DB_PORT=tcp://172.17.0.33:6379
|
||||
DB_PORT_6379_TCP=tcp://172.17.0.33:6379
|
||||
DB_PORT_6379_TCP_ADDR=172.17.0.33
|
||||
DB_PORT_6379_TCP_PROTO=tcp
|
||||
```
|
||||
|
||||
We can see that we've got a small list of environment variables prefixed
|
||||
with `DB`. The `DB` comes from the link alias specified when we launched
|
||||
the container. Let's use the `DB_PORT_6379_TCP_ADDR` variable to connect to
|
||||
our Redis container.
|
||||
|
||||
$ redis-cli -h $DB_PORT_6379_TCP_ADDR
|
||||
$ redis 172.17.0.33:6379>
|
||||
$ redis 172.17.0.33:6379> set docker awesome
|
||||
OK
|
||||
$ redis 172.17.0.33:6379> get docker
|
||||
"awesome"
|
||||
$ redis 172.17.0.33:6379> exit
|
||||
```bash
|
||||
$ redis-cli -h $DB_PORT_6379_TCP_ADDR
|
||||
|
||||
$ redis 172.17.0.33:6379>
|
||||
$ redis 172.17.0.33:6379> set docker awesome
|
||||
|
||||
OK
|
||||
|
||||
$ redis 172.17.0.33:6379> get docker
|
||||
|
||||
"awesome"
|
||||
|
||||
$ redis 172.17.0.33:6379> exit
|
||||
```
|
||||
We could easily use this or other environment variables in our web
|
||||
application to make a connection to our `redis`
|
||||
container.
|
||||
|
|
Loading…
Reference in New Issue