以下为你显现在Ubuntu 18.04系统中设置docker加速(18.06.0-ce),共有两种方案,一是使用使用阿里云加速器,二是使用设置docker代理的方法。
一、使用阿里云加速器 在不同的系统下面,配置加速器的方式有一些不同,这里适用于Ubuntu 18.04系统。关于加速器的地址,你只需要登录容器Hub服务的控制台,左侧的加速器帮助页面就会显示为你独立分配的加速地址。 例如: 公网Mirror:[系统分配前缀].mirror.aliyuncs.com 当你下载安装的Docker Version不低于1.10时,建议直接通过daemon config进行配置。 使用配置文件 /etc/docker/daemon.json(没有时新建该文件) { "registry-mirrors": ["<your accelerate address>"] } 重启Docker Daemon就可以了。[更多信息可以参考附1]
注意:我使用上面的方法后Docker就起不来了,看网上有人说好像是因为配置间有冲突,所以我选择了下一种方法,那就是设置docker代理的方法。
二、设置docker代理 这里你首先要有一个HTTP代理可用。[更多信息可以参考附2] 1.创建目录/etc/systemd/system/docker.service.d cd /etc/systemd/system/ sudo mkdir docker.service.d 2.在该目录下创建文件 http-proxy.conf,在文件中添加配置: [Service] Environment="HTTP_PROXY=http://192.168.8.186:8087/" Environment="HTTPS_PROXY=http://192.168.8.186:8087/" 3.刷新配置 sudo systemctl daemon-reload 4.重启docker服务 sudo systemctl restart docker
附1:Docker 镜像加速器 我们使用Docker的第一步,应该是获取一个官方的镜像,例如mysql、wordpress,基于这些基础镜像我们可以开发自己个性化的应用。我们可以使用Docker命令行工具来下载官方镜像。 但是因为网络原因,我们下载一个300M的镜像需要很长的时间,甚至下载失败。因为这个原因,阿里云容器Hub服务提供了官方的镜像站点加速官方镜像的下载速度。 1.使用镜像加速器: 在不同的系统下面,配置加速器的方式有一些不同,所以我们介绍主要的几个操作系统的配置方法。 关于加速器的地址,你只需要登录容器Hub服务的控制台,左侧的加速器帮助页面就会显示为你独立分配的加速地址。 例如: 公网Mirror:[系统分配前缀].mirror.aliyuncs.com 2.当你的docker版本较新时: 当你下载安装的Docker Version不低于1.10时,建议直接通过daemon config进行配置。 使用配置文件 /etc/docker/daemon.json(没有时新建该文件) { "registry-mirrors": ["<your accelerate address>"] } 重启Docker Daemon就可以了。 3.当你的docker版本较旧时 只能根据系统的不同修改对应的配置文件了。 1].Ubuntu 12.04 14.04: Ubuntu的配置文件的位置在 /etc/default/docker 你只需要在这个配置文件,添加加速器的配置项,重启Docker就可以了 echo "DOCKER_OPTS=\"\$DOCKER_OPTS --registry-mirror=<your accelerate address>\"" | sudo tee -a /etc/default/docker sudo service docker restart 2].Ubuntu 15.04 15.10: Ubuntu 15.04 之后的加速器配置方式有了一些变化 Ubuntu的配置文件的位置在 /etc/systemd/system/docker.service.d/目录下 在这个目录下创建任意的*.conf文件就可以作为配置文件。然后在这个配置文件,添加加速器的配置项,重启Docker就可以了 sudo mkdir -p /etc/systemd/system/docker.service.d sudo tee /etc/systemd/system/docker.service.d/mirror.conf <<-'EOF' [Service] ExecStart= ExecStart=/usr/bin/docker daemon -H fd:// --registry-mirror=<your accelerate address> EOF sudo systemctl daemon-reload sudo systemctl restart docker 3].CentOS 7: CentOS的配置方式略微复杂,需要先将默认的配置文件复制出来 /lib/systemd/system/docker.service -> /etc/systemd/system/docker.service 然后再将加速器地址添加到配置文件的启动命令 重启Docker就可以了。 sudo cp -n /lib/systemd/system/docker.service /etc/systemd/system/docker.service sudo sed -i "s|ExecStart=/usr/bin/docker daemon|ExecStart=/usr/bin/docker daemon --registry-mirror=<your accelerate address>|g" /etc/systemd/system/docker.service sudo sed -i "s|ExecStart=/usr/bin/dockerd|ExecStart=/usr/bin/dockerd --registry-mirror=<your accelerate address>|g" /etc/systemd/system/docker.service sudo systemctl daemon-reload sudo service docker restart 4].Redhat 7: Redhat 7配置加速器的方式与其他系统都不一样,需要编辑/etc/sysconfig/docker配置文件。 在OPTIONS配置项中添加加速器配置--registry-mirror=<your accelerate address> 最后sudo service docker restart重启docker daemon。 5].Redhat 6、CentOS 6 在这两个系统上没有办法直接安装Docker,需要升级内核。 配置加速器的方式和上一个配置类似,也是通过编辑/etc/sysconfig/docker配置文件。 在other_args配置项中添加加速器配置--registry-mirror=<your accelerate address> 最后sudo service docker restart重启docker daemon。 6].Docker Toolbox 在Windows、Mac系统上使用Docker Toolbox使用Docker的话 推荐做法是在创建Linux虚拟机的时候,就将加速器的地址配置进去 docker-machine create --engine-registry-mirror=<your accelerate address> -d virtualbox default docker-machine env default eval "$(docker-machine env default)" docker info 如果你已经通过docker-machine创建了虚拟机的话,则需要通过登录机器修改配置了 首先通过docker-machine ssh <machine-name>登录虚拟机 然后修改/var/lib/boot2docker/profile文件,将--registry-mirror=<your accelerate address>添加到EXTRA_ARGS中 最后sudo /etc/init.d/docker restart重启Docker服务就可以了 注意: 文中的加速器地址<your accelerate address>,请到容器Hub服务控制台查看。
附2:Shadowsocks + privoxy 搭建 http 代理服务步骤 整体架构如下图所示,我们需要找一台机器将 SS Server 搭建好,然后在局域网内的任何一台 Linux 服务器安装 SS Local 和 Privoxy,Privoxy 暴露 8118 端口作为 http 代理的端口:
1.安装配置 Shadowsocks Server 端(ssserver) Shadowsocks 是用 Python 编写的,因此可以通过如下命令直接安装(sslocal 和 ssserver 均已安装): sudo pip install shadowsocks 接下来编写 Shadowsocks Server 端的配置文件,配置监听端口,加密方式,密码等,新建 /etc/shadowsocks.json 文件,填入如下内容: { "server":"0.0.0.0", "server_port":1851, # SS Server 端口 "local_address": "127.0.0.1", #SS Local 端配置,不影响Server端使用 "local_port":1080, #SS Local 端配置,不影响Server端使用 "password":"xxxxx", "timeout":300, "method":"aes-256-cfb", "fast_open": false } 使用配置文件启动 SS Server: ssserver -c /etc/shadowsocks.json -d start 2.安装配置 Shadowsocks 客户端(sslocal) 第一步已将 SS Server 安装并配置完成,服务端口为 1851 ,接下来在需要安装 http 代理的机器上安装配置 shadowsocks 客户端,安装方法和第一步一样: sudo pip install shadowsocks 编写 SS Local 客户端配置文件,配置远程连接 SS Server 的 IP,端口,密码,加密方式等,新建 /etc/shadowsocks.json 文件,填入如下内容: { "server":"xxx.xxx.xxx.xxx", # SS Server 端服务器公网 IP "server_port":1851, # SS Server 端口 "local_address": "127.0.0.1", # SS Local 本地监听 IP "local_port:":1080, # SS Local 本地监听端口 "password":"xxxxxx", "timeout":300, "method":"aes-256-cfb", "fast_open": false } 使用配置文件启动 SS Local: sslocal -c /etc/shadowsocks.json -d start 3.安装并配置 Privoxy Privoxy 是一款代理软件,我们这里用该代理软件实现 HTTP 到 Socks5 的转换,所有来自 Privoxy 的请求被转发到 SS Local,从而实现了一个 HTTP 代理服务,Privoxy 的安装非常简单,直接 yum 一键搞定: sudo yum install privoxy 编辑 Privoxy 配置文件 /etc/privoxy/config,搜索关键字 listen-address 找到这一句,改成 listen-address 0.0.0.0:8118,表示该代理可以对外访问。 接下来在该配置该文件末尾添加 HTTP 请求转发到 SS Local Socks5 的配置: forward-socks5t / 127.0.0.1:1080 . forward-socks5t: 表示 Privoxy 转发请求到 Socks5 协议; 127.0.0.1: 第二步中启动 SS Local 本地绑定 IP; 1080: 第二步中启动 SS Local 本地监听端口; 启动 Privoxy: systemctl restart privoxy systemctl enable privoxy 4.测试代理是否可用 curl -x privoxy_ip:8118 https://www.google.com
相关主题 |