使用 Docker 部署运行常用服务
经过上面几节的积累,我们对 Docker 各个方面都有了大致的了解,这一节,我们将常用的 Redis,, 等服务部署到 Docker 上来。
Tips:这里部署时认使用最新稳定的官方镜像版本,如有版本要求自行在镜像名后标注 :tag
即可。
Redis 是使用 ANSI C 编写的开源、网络、基于内存、可选持久性的键值对存储。
# 使用 Docker 启动 redis 服务,端口认,使用host网络模式保障。
docker run --restart=always --network host -d -it --name myredis redis
将 redis 数据保存到宿主机目录:
mkdir -p ~/docker/redis/data # 新建宿主机目录
docker run --restart=always --network host -d -it -v ~/docker/redis/data:/data --name myredis redis
指定自己的
# 先将放到 ~/docker/redis/redis.conf
docker run --restart=always --network host -d -it -v ~/docker/redis/redis.conf:/usr/local/etc/redis/redis.conf --name myredis redis redis-server /usr/local/etc/redis/redis.conf
是异步框架的网页服务器,也可以用作反向代理、平衡器和HTTP缓存:
# 使用 Docker 启动 redis 服务,端口认,使用host网络模式保障。
# 使用自己的html目录,ro设定宿主机目录挂载到容器后,容器对此目录只读
docker run --restart=always --network host -d -it -v ~/docker//html:/usr/share//html:ro --name my
指定自己的
# 先将放到 ~/docker//etc/ 目录下
docker run --restart=always --network host -d -it -v ~/docker//html:/usr/share//html:ro -v ~/docker//etc/:/etc/ --name my
是开放源码的关系管理系统。
# 使用 Docker 启动 redis 服务,端口认,使用host网络模式保障。
# my-secret-pw 指定的root密码
docker run --restart=always --network host -d -it --name my -e _ROOT_PASSWORD=my-secret-pw
将数据保存到宿主机目录:
mkdir -p ~/docker//data # 新建宿主机目录
docker run --restart=always --network host -d -it -v ~/docker//data:/var/lib/ --name my -e _ROOT_PASSWORD=my-secret-pw
指定自己的
# 将放入 ~/docker//conf.d/
docker run --restart=always --network host -d -it -v ~/docker//conf.d/:/etc//conf.d --name my -e _ROOT_PASSWORD=my-secret-pw
接下来我们将通过flask web应用,实现主页访问计数,我们使用 redis 服务帮助我们实现计数。这个 redis 服务运行在我们的 Docker 容器中。
Tips: 这里使用 flask
只是想借助简单的 web 框架来演示使用 docker 容器运行的 redis,不了解也没有关系,这里只是小例子。
首先,我们在 CentOS 中安装 和flask框架,以及 Python 的 redis 客户端库。
# 安装
sudo dnf install -y
# 安装flask与redis python客户端
pip3 install redis flask --user
接下来,将下面的保存到~/test/app.py
import flask
from flask import Flask
app = Flask()
from redis import StrictRedis
from redis import ConnectionPool
# 指定redis服务地址
REDIS_HOST = os.getenv('REDIS_HOST','127.0.0.1')
# 指定redis端口号
REDIS_PORT = os.getenv('REDIS_PORT', '6379')
# 指定redis的
REDIS_DB = os.getenv('REDIS_DB', '0')
# 指定redis的密码
REDIS_PASSWORD = os.getenv('REDIS_PASSWORD', '12345678')
class Redis:
def (self):
self.cli = None
def connect(self):
pool = ConnectionPool(host=REDIS_HOST,
port=REDIS_PORT,
db=REDIS_DB,
password=REDIS_PASSWORD)
return StrictRedis(connection_pool=pool)
def add_pv(self):
self.connection.incr('pv', )
def get_pv(self):
count = self.connection.get('pv')
return int(count)
@property
def connection(self):
if self.cli:
return self.cli
else:
self.cli = self.connect()
return self.cli
redis = Redis()
@app.route('/')
def index():
redis.add_pv()
return "<h1>Hello World, 本页已访问{}次。</h1>".format(redis.get_pv())
在 ~/docker/redis/
目录下,配置 redis.conf
cd ~/docker/redis
# 官方提供的redis模板
wget http://download.redis.io/redis-stable/redis.conf
# redis密码
echo "requirepass 12345678" >> redis.conf
好后,用它来配置 Docker 的 redis 容器应用。
docker run --restart=always --network host -d -it -v ~/docker/redis/redis.conf:/usr/local/etc/redis/redis.conf --name myredis redis redis-server /usr/local/etc/redis/redis.conf
redis容器启动完成后,在 ~/test/
目录下执行 -m flask run
,打开Linux系统中的浏览器,输入127.0.0.1:5000
访问这个 web 应用的主页,多次刷新查看。
@H__553@
提供了众多高质量的镜像和使用文档,生态也非常活跃。这种简单的部署方式更接近是一种软件的方式,相信大家都有体会,在平时的开发测试中,个人的开发机上安装这些服务经常费时费力,到时寻找安装包,甚至可能还要编译源码,结果出现一些意想不到的问题。熟练掌握这种部署应用服务,可以且高效地一致的开发部署环境。