docker各种报错解决

目录

【问题1】Get “https://registry-1.docker.io/v2/“: context deadline exceeded

解决方法

问题反思

【问题2】Error response from daemon: Get "https://index.docker.io/v1/search?q=mysql&n=25": dial tcp: lookup index.docker.io on 192.168.1.2:53: read udp 192.168.10.143:57022->192.168.1.2:53: i/o timeout

解决方法

【问题3】IPv4 forwarding is disabled. Networking will not work

解决方法


【问题1】Get “https://registry-1.docker.io/v2/“: context deadline exceeded

在docker pull redis 时显示:Get “https://registry-1.docker.io/v2/“: context deadline exceeded

解决方法

修改DNS服务器

vim /etc/resolv.conf

在文件内修改如下

nameserver 8.8.8.8

重启

sudo systemctl restart docker

问题反思

看到原文件内容为

nameserver 192.168.1.1

想起这是之前连接xshell的时候顺带配置的,没想到现在影响了redis的pull。

【问题2】Error response from daemon: Get "https://index.docker.io/v1/search?q=mysql&n=25": dial tcp: lookup index.docker.io on 192.168.1.2:53: read udp 192.168.10.143:57022->192.168.1.2:53: i/o timeout

Error response from daemon: Get "https://index.docker.io/v1/search?q=mysql&n=25": dial tcp: lookup index.docker.io on 192.168.1.2:53: read udp 192.168.10.143:57022->192.168.1.2:53: i/o timeout

解决方法

 /etc/docker/daemon.json内修改过期的镜像

"registry-mirrors": ["https://registry.docker-cn.com"]

【问题3】IPv4 forwarding is disabled. Networking will not work

IPv4 forwarding is disabled. Networking will not work

解决方法

vim /etc/sysctl.conf

在文件内添加net.ipv4.ip_forward=1

systemctl restart network && systemctl restart docker
sysctl net.ipv4.ip_forward 返回1,问题解决

手写Redis分布式锁的一个常见方法是使用Redis的SETNX命令和EXPIRE命令。SETNX用于设置一个键值对,只有在键不存在的情况下才能设置成功,用于表示获取锁的操作。EXPIRE用于设置键的过期时间,确保在获取锁的客户端崩溃或网络故障的情况下,锁最终会被释放。 下面是一个用C语言手写Redis分布式锁的简单示例代码: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <sys/types.h> #include <sys/time.h> #include <sys/wait.h> #include <signal.h> #include <errno.h> #include <hiredis/hiredis.h> #define REDIS_HOST "localhost" #define REDIS_PORT 6379 #define LOCK_KEY "my_lock" #define LOCK_EXPIRE_TIME 10 int main() { pid_t child_pid; int status; // 创建子进程 child_pid = fork(); if (child_pid == 0) { // 子进程获取锁 redisContext *redis_conn = redisConnect(REDIS_HOST, REDIS_PORT); if (redis_conn == NULL || redis_conn->err) { printf("连接Redis失败\n"); exit(1); } // 设置锁 redisReply *reply = redisCommand(redis_conn, "SETNX %s 1", LOCK_KEY); if (reply == NULL || reply->type == REDIS_REPLY_ERROR || reply->integer != 1) { printf("获取锁失败\n"); exit(1); } // 设置锁的过期时间 reply = redisCommand(redis_conn, "EXPIRE %s %d", LOCK_KEY, LOCK_EXPIRE_TIME); if (reply == NULL || reply->type == REDIS_REPLY_ERROR || reply->integer != 1) { printf("设置锁的过期时间失败\n"); exit(1); } printf("获取锁成功\n"); // 模拟业务操作 sleep(5); // 释放锁 reply = redisCommand(redis_conn, "DEL %s", LOCK_KEY); if (reply == NULL || reply->type == REDIS_REPLY_ERROR || reply->integer != 1) { printf("释放锁失败\n"); exit(1); } printf("释放锁成功\n"); // 关闭Redis连接 redisFree(redis_conn); exit(0); } else if (child_pid > 0) { // 等待子进程结束 waitpid(child_pid, &status, 0); if (WIFEXITED(status)) { printf("子进程正常结束\n"); } else if (WIFSIGNALED(status)) { printf("子进程异常结束\n"); } } else { printf("创建子进程失败\n"); exit(1); } return 0; } ``` 在这个示例中,使用了 hiredis 库来连接 Redis,并通过 SETNX 和 EXPIRE 命令实现分布式锁的获取和释放。主进程创建一个子进程,子进程尝试获取锁并进行业务操作,然后释放锁。主进程等待子进程的结束并打印相应信息。 注意:这只是一个简单的示例,实际应用中可能需要考虑更多的场景,比如锁的重入、超时处理等。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [分布式锁_Redis分布式锁+Redisson分布式锁+Zookeeper分布式锁+Mysql分布式锁(原版)](https://blog.csdn.net/guan1843036360/article/details/127827270)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

coleak

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值