问题描述:
-
[Redis报错:WRONGTYPE Operation against a key holding the wrong kind of value 解决处理]
存储时的数据类型和获取时的方法不一致。
ref: Redis报错:WRONGTYPE Operation against a key holding the wrong kind of value 解决处理 -
consumer: Cannot connect to redis://awifi%25%[email protected]:6379/6: Authentication required..
不是密码特殊字符问题,是celery使用redis密码范式书写不对;
密码在celery界面显示应该是密文,不是明文;显示明文是因为在redis密码书写时没有加冒号;broker_url = 'redis://:{pwd}@{ip}:{port}/{db}'.format(pwd=rds_pwd,ip=rds_ip,port=rds_port,db=rds_db) result_backend = 'redis://:{pwd}@{ip}:{port}/{db}'.format(pwd=rds_pwd,ip=rds_ip,port=rds_port,db=rds_db)
-
Cannot connect to redis://:**@192.168.1.xxx:xxx/x: invalid username-password pair or user is disabled..
对于这个问题网络上都是一致性的复制这个答案:
python3 连接redis密码中特殊字符问题
没有加任何的解释说明,因为自己连接redis不是基于url,通过参考的答案可知urllib.parse.quote(text)
是将一些特殊符号进行特殊编码,参考知乎回答:假如你的 name 或者 value 值中有『&』或者『=』等符号,就当然会有问题。所以URL中的参数字符串也需要把『&=』等符号进行编码。URL编码的方式是把需要编码的字符转化为 %xx 的形式。通常 URL 编码是基于 UTF-8 的(当然这和浏览器平台有关)。
解决方案
因此考虑将密码先进行
urllib.parse.quote()
输出,然后将结果替换成原密码即可;
之前考虑直接使用\\
转义无果。
以下代码中原密码是:1234@2022
;替换后成1234%402022
;redis_host = "192.168.1.111" redis_port = 20379 redis_password = "1234%402022" #redis_password = "1234\\@2022" broker_url = f"redis://:{ redis_password}@{ redis_host}:{ redis_port}/7" result_backend = f"redis://::{ redis_password}@{ redis_host}:{ redis_port}/8"