zoukankan      html  css  js  c++  java
  • docker镜像仓库搭建-Harbor

    一、Harbor简介

    Harbor是一个用于存储和分发Docker镜像的企业级Registry服务器。
    
    作为一个企业级私有 Registry 服务器,Harbor 提供了更好的性能和安全。提升用户使用 Registry 构建和运行环境传输镜像的效率。Harbor 支持安装在多个 Registry 节点的镜像资源复制,镜像全部保存在私有 Registry 中, 确保数据和知识产权在公司内部网络中管控。另外,Harbor 也提供了高级的安全特性,诸如用户管理,访问控制和活动审计等。
    
    基于角色的访问控制 - 用户与 Docker 镜像仓库通过“项目”进行组织管理,一个用户可以对多个镜像仓库在同一命名空间(project)里有不同的权限。
    镜像复制 - 镜像可以在多个 Registry 实例中复制(同步)。尤其适合于负载均衡,高可用,混合云和多云的场景。
    图形化用户界面 - 用户可以通过浏览器来浏览,检索当前 Docker 镜像仓库,管理项目和命名空间。
    AD/LDAP 支持 - Harbor 可以集成企业内部已有的 AD/LDAP,用于鉴权认证管理。
    审计管理 - 所有针对镜像仓库的操作都可以被记录追溯,用于审计管理。
    国际化 - 已拥有英文、中文、德文、日文和俄文的本地化版本。更多的语言将会添加进来。
    RESTful API - RESTful API 提供给管理员对于 Harbor 更多的操控, 使得与其它管理软件集成变得更容易。
    部署简单 - 提供在线和离线两种安装工具, 也可以安装到 vSphere 平台(OVA 方式)虚拟设备。

    二、Harbor安装

    # 请先安装docker和docker-compose
    systemctl restart docker
    
    # docker 版本不能太低,如果低了请升级
    卸载 docker docker-client docker-common
    curl -fsSL https://get.docker.com/ | sh
    
    # 安装完成提示
    ✔ ----Harbor has been installed and started successfully.----
    
    # 下载harbor安装包:https://github.com/goharbor/harbor/releases
    tar -xzvf harbor-offline-installer-v2.3.3.tgz
    cd harbor
    cp  harbor.yml.tmpl  harbor.yml
    # 修改 harbor.yml
    修改hostname为域名或ip
    修改harbor_admin_password  web登录页面密码
    https如果不适用可以注销
    data_volume 根据实际情况处理
    
    # 页面访问 http://192.168.0111   admin/Harbor12345

     设置开机启动

    vi /usr/lib/systemd/system/harbor.service
    
    [Unit]
    Description=Harbor
    After=docker.service systemd-networkd.service systemd-resolved.service
    Requires=docker.service
    Documentation=http://github.com/vmware/harbor
     
    [Service]
    Type=simple
    Restart=on-failure
    RestartSec=5
    ExecStart=/usr/bin/docker-compose -f  /usr/local/harbor/docker-compose.yml up
    ExecStop=/usr/bin/docker-compose -f /usr/local/harbor/docker-compose.yml down
     
    [Install]
    WantedBy=multi-user.target
    # 设置开机启动
    systemctl enable harbor
    systemctl start harbor

    三、将docker镜像上传到docker仓库

    docker tag 87a94228f133 192.168.0.111/library/nginx:v1
    docker login 192.168.0.111
    docker push 192.168.0.111/library/nginx:v1
    
    # 遇到的问题
    Error response from daemon: Get "https://192.168.0.111/v2/": dial tcp 192.168.0.111:443: connect: connection refused
    # 解决方法:在客户端本机/etc/docker/daemon.json中添加insecure-registries就可以了
    {
      "registry-mirrors": ["https://pft7f97f.mirror.aliyuncs.com"],
      "insecure-registries": ["192.168.0.110"]
    }

     四、镜像仓库复制以及分布式分发

     

  • 相关阅读:
    获取请求浏览器信息
    (转)获取页面 鼠标位置
    (转)location.href 用法
    (转)异常的处理
    (转载)提高ASP.NET Web应用性能的技巧
    赶集网二手数据.py
    豆瓣top250.py
    爬取58二手数据.py
    使用类和实例.py
    爬取小猪短租房.py文件
  • 原文地址:https://www.cnblogs.com/yangmeichong/p/15450921.html
Copyright © 2011-2022 走看看