服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

Linux|Centos|Ubuntu|系统进程|Fedora|注册表|Bios|Solaris|Windows7|Windows10|Windows11|windows server|

服务器之家 - 服务器系统 - Linux - Linux系统Docker harbor使用http的解决办法

Linux系统Docker harbor使用http的解决办法

2024-01-05 14:57微技术之家 Linux

harbor 最新版本都默认使用https,但是如果是内网服务器也没必要假设一个https,当然为了安全也可以使用,但是操作比较复杂。这里提供一个配置http的方案。

harbor 最新版本都默认使用https,但是如果是内网服务器也没必要假设一个https,当然为了安全也可以使用,但是操作比较复杂。这里提供一个配置http的方案。

首先在harbor服务器里面修改harbor.cfg

[root@vv harbor]# vi harbor.cfg

修改 ui_url_protocol = http

在 目标机器上(项目部署的docker所在服务器) /etc/docker添加一个daemon.json文件。

vi /etc/docker/daemon.json

内容如下:

{ 
  "insecure-registries":["harbor server ip"]
}

harbor server ip :harbor的内网IP

添加完之后可以测试一下

echo <harbor_password> | docker login -u <harbor_user> --password-stdin <harbor_server_ip>

Linux系统Docker harbor使用http的解决办法

<harbor_password> : 在harbor上注册的密码

<harbor_user> :在harbor上注册的用户

<harbor_server_ip> :harbor的内网IP

如果现实能正常登陆即可

当然也可以通过修改harbor服务配置的方式来实现。

在harbor设置http的方式

对于在内网环境中的 Harbor 实例,默认使用 HTTPS 可能并不是必需的,而且可能会增加配置和管理的复杂性。如果你希望配置 Harbor 以使用 HTTP(不是 HTTPS),你可以按照以下步骤操作:

修改 Harbor 的配置文件:找到 Harbor 的配置文件,一遍是 /etc/harbor/harbor.yml。可以使用文本编辑器打开,在文件中找到以下部分:

ui:  
  ssl:  
    enabled: true

将 enabled 的值改为 false,如下所示:

ui:  
  ssl:  
    enabled: false

重启 Harbor 服务:保存更改并重启 Harbor 服务以使配置生效。

sudo systemctl restart harbor

配置 Nginx(如果使用的话):如果你在内网环境中使用了 Nginx 作为反向代理,还需要确保 Nginx 的配置也是使用 HTTP。查找 Nginx 配置文件中关于 Harbor 的部分,并进行相应的更改。

附上配置harbor仓库的方法,供大家参考

## 使用docker镜像启动镜像仓库服务
$ docker run -d -p 5000:5000 --restart always --name registry registry:2
 
## 默认仓库不带认证,若需要认证,参考https://docs.docker.com/registry/deploying/#restricting-access

推送镜像至仓库

$ docker tag nginx:alpine localhost:5000/nginx:alpine
$ docker push localhost:5000/nginx:alpine
 
## 查看仓库内元数据
$ curl -X GET http://172.21.51.143:5000/v2/_catalog
$ curl -X GET http://172.21.51.143:5000/v2/nginx/tags/list
 
## 镜像仓库给外部访问,不能通过localhost,尝试使用内网地址172.21.51.143:5000/nginx:alpine
$ docker tag nginx:alpine 172.21.51.143:5000/nginx:alpine
$ docker push 172.21.51.143:5000/nginx:alpine
The push refers to repository [172.21.51.143:5000/nginx]
Get https://172.21.51.143:5000/v2/: http: server gave HTTP response to HTTPS client
## docker默认不允许向http的仓库地址推送,如何做成https的,参考:https://docs.docker.com/registry/deploying/#run-an-externally-accessible-registry
## 我们没有可信证书机构颁发的证书和域名,自签名证书需要在每个节点中拷贝证书文件,比较麻烦,因此我们通过配置daemon的方式,来跳过证书的验证:
$ cat /etc/docker/daemon.json
{
  "insecure-registries": [
     "172.21.51.143:5000"
  ]
}
$ systemctl restart docker
$ docker push 172.21.51.143:5000/nginx:alpine

原文地址:https://mp.weixin.qq.com/s?__biz=MzkzNjQzOTE3Nw==&mid=2247489621&idx=1&sn=571479c15e79230fbba0d6c249cc3ca3

延伸 · 阅读

精彩推荐
  • Linux阐述Linux操作系统之rpm五种基本操作

    阐述Linux操作系统之rpm五种基本操作

    Linux操作系统现在已经成为流行的操作系统,很多的人都开始学习,Linux操作系统包括了很多的专业知识,今天和大家讲讲Linux操作系统中的rpm基本操作。希...

    Linux教程网10932021-11-04
  • Linuxlinux云主机安装pdo详细教程

    linux云主机安装pdo详细教程

    这篇文章主要介绍了linux云主机安装pdo详细教程,网上搜到一个几个还算清晰的教程,但是没加说明,很多站长按照做了,中途出现错误,便不知如何解决...

    Linux教程网5372022-02-15
  • Linuxlinux安装vsftpd和vsftpd配置步骤

    linux安装vsftpd和vsftpd配置步骤

    这篇文章主要介绍了linux安装vsftpd和vsftpd配置步骤,需要的朋友可以参考下 ...

    linux教程网14352019-11-15
  • LinuxIO多路复用之poll全面总结(必看篇)

    IO多路复用之poll全面总结(必看篇)

    下面小编就为大家带来一篇IO多路复用之poll全面总结(必看篇)。小编觉得挺不错的。现在就分享给大家。也给大家做个参考。一起跟随小编过来看看吧...

    Linux教程网10462021-12-13
  • Linux在 Linux 使用 systemd-udevd 管理你的接入硬件

    在 Linux 使用 systemd-udevd 管理你的接入硬件

    Linux 能够出色地自动识别、加载、并公开接入的无数厂商的硬件设备。在这篇文章中,我会讨论为何有人想要使用这样的名称。在这个过程中,我会探索剖...

    Linux中国9442021-08-17
  • LinuxLinux tar 压缩档案管理命令学习

    Linux tar 压缩档案管理命令学习

    tar主要进行档案的压缩与解压缩,是比较常用的命令 ...

    linux命令大全2252019-12-28
  • LinuxLinux环境中远程开启ssh端口和更改ssh用户根目录

    Linux环境中远程开启ssh端口和更改ssh用户根目录

    这篇文章主要介绍了Linux环境中远程开启ssh端口和更改ssh用户根目录的方法,其中更改ssh用户根目录使用到了jailkit chroot软件,需要的朋友可以参考下...

    Linux服务器运维日志4432019-07-07
  • Linuxlinux下system函数的简单分析

    linux下system函数的简单分析

    这篇文章主要简单分析了linux下system函数,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    1oner4042022-01-19