您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

使用 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@

提供了众多高质量的镜像和使用文档,生态也非常活跃。这种简单的部署方式更接近是一种软件的方式,相信大家都有体会,在平时的开发测试中,个人的开发机上安装这些服务经常费时费力,到时寻找安装包,甚至可能还要编译源码,结果出现一些意想不到的问题。熟练掌握这种部署应用服务,可以且高效地一致的开发部署环境。


联系我
置顶