本篇博文主要讲解Docker下使用RQ队列的通信配置,主要是网上的部分文章写的不太清楚,特写一篇

作者使用docker-compose.yml文件调度各部分文件Dockerfile,起初是这样写的

version: '3'
services:
redis:
  image: "redis"
  restart: always
  environment:
    - TZ=Asia/Shanghai
mysql:
  build: ./mysql
  environment:
    - TZ=Asia/Shanghai
    - MYSQL_DATABASE=SZheScan
    - MYSQL_ROOT_PASSWORD=root
  ports:
    - "3306:3306"
  restart: always
  command: [
     '--character-set-server=utf8mb4',
     '--collation-server=utf8mb4_unicode_ci',
   ]

web:
  build: .
  ports:
    - "5000:5000"
  links:
    - mysql:mysql
    - redis:redis
  depends_on:
    - mysql
  restart: always
  environment:
    - TZ=Asia/Shanghai
rq:
  build: .
  depends_on:
    - redis
    - web
  command: "rq worker"
  restart: always
  environment:
    - TZ=Asia/Shanghai

关键点在于rq部分:

  rq:
  build: .
  depends_on:
    - redis
    - web
  command: "rq worker"
  restart: always
  environment:
    - TZ=Asia/Shanghai

使用command命令启动RQ队列:

command: "rq worker"

在Flask的配置文件config.py中如下编写:

import os
import redis
from rq import Queue '''
配置文件:
debug=true
secret_key,session中的24位随机盐值
MySQL数据库配置
数据库名为SZheScan
python3:https://blog.csdn.net/qq562029186/article/details/81325074
'''
DEBUG = False
SECRET_KEY = os.urandom(24) HOSTNAME='mysql'
# HOSTNAME='127.0.0.1'
PORT = '3306'
DATABASE = 'SZheScan'
USERNAME = 'root'
PASSWORD = 'root'
# SQLALCHEMY_DATABASE_URI = 'mysql+pymysql://root:root@127.0.0.1/tushare?charset=utf8'
SQLALCHEMY_DATABASE_URI = 'mysql+pymysql://{}:{}@{}:{}/{}?charset=utf8'.format(USERNAME, PASSWORD, HOSTNAME, PORT,
DATABASE) SQLALCHEMY_TRACK_MODIFICATIONS = False HOST = 'redis'
# HOST = '127.0.0.1'
redisPool = redis.ConnectionPool(host=HOST, port=6379, db=0, decode_responses=True)
db = redis.Redis(host=HOST, port=6379, db=0, decode_responses=True)
queue = Queue(connection=db)

除了引入关键的库文件之外,RQ队列关键代码在:

db = redis.Redis(host=HOST, port=6379, db=0, decode_responses=True)
queue = Queue(connection=db)

注意,这里链接的HOST不能是本地127.0.0.1,而是redis,而redis实际上是docker-compose.yaml文件里面redis的服务名,也就是redis服务,这样才能正常通信。

接着使用docker-compose up 启动服务,但是出现了报错为:

Error 99 connecting to localhost:6379. Cannot assign requested address

虽然国内部分人给出了解决方案,但是并不太具体,在stackoverflow社区上找到了其中一个解决方案:https://stackoverflow.com/questions/54965291/error-99-connecting-to-localhost6379-cannot-assign-requested-address

事实上,这个解决方案,解决的问题是前面我们提到的,HOST主机修改为redis服务名的问题,但是当我这样修改了之后,并且重新建立了镜像,还是会出现同样的报错。

在查阅了相关的资料之后,作者才发现,原来RQ队列默认链接的就是本地的Redis数据库,即localhost:6379,虽然我们在配置文件,即config.py里面写了:

db = redis.Redis(host=HOST, port=6379, db=0, decode_responses=True)

但是RQ队列并不会智能到自动链接redis Docker服务,最终还是一次又一次去尝试链接localhost:6379,这也是为什么Docker的报错里面会出现localhost:6379的原因。

解决方法为,docker-compose.yml启动文件中,RQ队列启动command命令指定配置文件启动

简单介绍一下咋编写配置文件及启动服务,更详细的可以去查看其他博主的RQ队列配置文件编写

首先编写一个rqsettings.py文件:


# 你也可以指定使用的redis数据库
REDIS_HOST = 'redis'
REDIS_PORT = 6379
REDIS_DB = 0
# REDIS_PASSWORD = 'very secret' # 监听的队列
QUEUES = ['high', 'default', 'low']

可以看到在这里我们指定的是redis主机,即docker-compose.yml文件中redis docker的服务名,在stackoverflow解决方案上,也是想表达改为docker redis的服务名。

接着在config.py中,还是象征性改一下:

import os
import redis
from rq import Queue
import rqsettings '''
配置文件:
debug=true
secret_key,session中的24位随机盐值
MySQL数据库配置
数据库名为SZheScan
python3:https://blog.csdn.net/qq562029186/article/details/81325074
'''
DEBUG = False
SECRET_KEY = os.urandom(24) HOSTNAME='mysql'
# HOSTNAME='127.0.0.1'
PORT = '3306'
DATABASE = 'SZheScan'
USERNAME = 'root'
PASSWORD = 'root'
# SQLALCHEMY_DATABASE_URI = 'mysql+pymysql://root:root@127.0.0.1/tushare?charset=utf8'
SQLALCHEMY_DATABASE_URI = 'mysql+pymysql://{}:{}@{}:{}/{}?charset=utf8'.format(USERNAME, PASSWORD, HOSTNAME, PORT,
DATABASE) SQLALCHEMY_TRACK_MODIFICATIONS = False HOST = 'redis'
# HOST = '127.0.0.1'
redisPool = redis.ConnectionPool(host=HOST, port=6379, db=0, decode_responses=True)
db = redis.Redis(host=rqsettings.REDIS_HOST, port=rqsettings.REDIS_PORT, db=rqsettings.REDIS_DB, decode_responses=True)
queue = Queue(connection=db)

其实这个改不改都行,RQ指定host和端口改为了调用rqsettings文件而已。

最关键的在于指定配置文件启动,修改docker-compose.yml文件为

version: '3'
services:
 redis:
   image: "redis"
   restart: always
   environment:
     - TZ=Asia/Shanghai
 mysql:
   build: ./mysql
   environment:
     - TZ=Asia/Shanghai
     - MYSQL_DATABASE=SZheScan
     - MYSQL_ROOT_PASSWORD=root
   ports:
     - "3306:3306"
   restart: always
   command: [
     '--character-set-server=utf8mb4',
     '--collation-server=utf8mb4_unicode_ci',
  ]

 web:
   build: .
   ports:
    - "5000:5000"
   links:
    - mysql:mysql
    - redis:redis
   depends_on:
    - mysql
   restart: always
   environment:
     - TZ=Asia/Shanghai
 rq:
   build: .
   depends_on:
     - redis
     - web
   command: "rq worker -c rqsettings"
   restart: always
   environment:
     - TZ=Asia/Shanghai

关键代码为:

command: "rq worker -c rqsettings"

即使用

rq worker -c rqsettings

-c 参数指定配置文件

需要注意的是,配置文件实际上为rqsettings.py,是存在.py后缀的,但是在-c指定的时候,是不需要加上.py后缀指定的。

然后删除掉之前错误建立的镜像,重新更新一下本地的docker,对于这个问题,即:

Error 99 connecting to localhost:6379. Cannot assign requested address

应该就可以正常解决了。

祝好

Docker下Python Flask+Redis+MySQL+RQ队列简单配置的更多相关文章

  1. ubuntu下python flask环境搭建

    ubuntu下python flask环境搭建 1. 安装pip sudo apt-get install python-dev pyhton-pip 2. 安装virtualenv sudo apt ...

  2. [评测]低配环境下,PostgresQL和Mysql读写性能简单对比(欢迎大家提出Mysql优化意见)

    [评测]低配环境下,PostgresQL和Mysql读写性能简单对比 原文链接:https://www.cnblogs.com/blog5277/p/10658426.html 原文作者:博客园--曲 ...

  3. python——flask常见接口开发(简单案例)

    python——flask常见接口开发(简单案例)原创 大蛇王 发布于2019-01-24 11:34:06 阅读数 5208 收藏展开 版本:python3.5+ 模块:flask 目标:开发一个只 ...

  4. Linux安装MariaDB(Mysql)和简单配置 mariadb

    Linux安装MariaDB(Mysql)和简单配置 1.安装MariaDB 安装命令 yum -y install mariadb mariadb-server 安装完成MariaDB,首先启动Ma ...

  5. Laravel5.4 队列简单配置与使用

    概述 什么是队列? 百度百科是这样说的 “队列”是在传输过程中保存数据的容器. 举几个生活中例子: * iphone手机新款发布,三里屯iphone进的新货.大家要排队买,不能说一大堆人一起冲进去,那 ...

  6. windows下python+flask环境配置详细图文教程

    本帖是本人在安装配置python和flask环境时所用到的资源下载及相关的教程进行了整理罗列,来方便后面的人员,省去搜索的时间.如果你在安装配置是存在问题可留言给我. 首先罗列一下python+fla ...

  7. docker下tomcat连redis

    之前已经讲了然后通过Maven 项目管理工具创建Web项目, 最后打包成War包 讲了docker 配置 Tomcat , Redis 现在讲如何使用War包,以及在docker下, 让jsp连上re ...

  8. Linux安装MariaDB(Mysql)和简单配置

    1.安装MariaDB 安装命令 yum -y install mariadb mariadb-server 安装完成MariaDB,首先启动MariaDB systemctl start maria ...

  9. python的IDE(pycharm)安装以及简单配置

    使用IDE的好处 界面更友好,看起来更舒服 智能提示功能很赞,大大提高开发效率 pycharm的安装过程 去pycharm官网下载安装包,请下载专业版,建议不要去网上下载汉化版 点击安装包一直下一步即 ...

随机推荐

  1. C++ 基础 2:C++ 对 C 语言的拓展

    1 引用 1.1 定义及编程实践 引用,是某个已存在变量的另一个名字. 一旦把引用初始化为某个变量,就可以使用该引用名称或变量名称来指向变量. 注意: 引用没有定义,是一种关系型声明.声明它和原有某一 ...

  2. 程序员注意【自verycd.com的JavaAmg77 】

    展望未来,总结过去10年的程序员生涯,给程序员小弟弟小妹妹们的一些总结性忠告 走过的路,回忆起来是那么曲折,把自己的一些心得体会分享给程序员兄弟姐妹们,虽然时代在变化,但是很可能你也会走我已经做过的1 ...

  3. X-Height

    术语x-height是指给定字体中,任何给定尺寸下小写字母x的高度. 它提供了一种描述任意字体一般比例的方法. 在印刷中,x-height是一行文字的基线与小写字母(即不包括上升笔画或下降笔画)的主体 ...

  4. 关于ThreadLocal的那些事

    这篇文章(看完了再看下面的)很好地解释了ThreadLocal是什么,怎么用,是否能解决线程安全问题,非常nice.但个人认为讲解存在遗漏,进行如下示例补充: InheritableThreadLoc ...

  5. python + appium 执行报错整理

    1.driver.find_element_by_id("com.taobao.taobao:id/searchEdit").send_keys("adidas" ...

  6. 07 . 前端工程化(ES6模块化和webpack打包)

    模块化规范 传统开发模式主要问题 /* 1. 命名冲突 2. 文件依赖 */ 通过模块化解决上述问题 /* 模块化就是把单独的一个功能封装在一个模块(文件)中,模块之间相互隔离, 但是可以通过特定的接 ...

  7. 重闯Sqli-labs关卡第三天(6-10关)

    第六关(双注入GET双引号字符型注) 核心代码: 1 $id = '"'.$id.'"'; 2 $sql="SELECT * FROM users WHERE id=$i ...

  8. cdh中jps显示process information unavailable问题的解决

    百度的方法有两种: 第一种 1.进入/tmp 2.删除该目录下的hsperfdata_${username} 文件夹 3.再执行jps 第二种 做软连接 或者修改权限hsperfdata_${user ...

  9. vulnhub: DC 3

    通过nmap扫描,只开放了80端口,并且该web服务是基于Joomla搭建: root@kali:~# nmap -A 192.168.74.140 Starting Nmap 7.80 ( http ...

  10. Java命令行启动jar包更改默认端口以及配置文件的几种方式

    Java命令行启动jar包更改默认端口以及配置文件的几种方式 java -jar xxx.jar --server.port=8081 默认如果jar包没有启动文件,可以采用这种方式进行启动 java ...