使用Artifactory部署私有化软件源

本文最后更新于 1567 天前, 如有失效请评论区留言.

趁着节前,需要折(dao)腾(shi)一下去年部署的 artifactory 镜像源,并将升级到 7.x 版本。

场景

部署私有化软件源,对内提供服务。这里只作为软件源测试使用,其他场景自行琢磨。

部署服务

部署很简单,这里使用 docker-compose 方式部署

# docker-compose.yaml
version: '2.1'
services:
  ossv2:
    image: registry.cn-beijing.aliyuncs.com/k7scn/artifactory-pro:7.6.1
    container_name: ossv2
    volumes:
    - /data/ossv2:/var/opt/jfrog/artifactory
    network_mode: host
    restart: always
  nginx:
    image: registry.cn-beijing.aliyuncs.com/k7scn/nginx:1.17.3
    container_name: nginx
    volumes:
    - /var/log/nginx:/var/log/nginx:rw
    - ./config:/etc/nginx/conf.d:rw
    - ./nginxconfig.io:/etc/nginx/nginxconfig.io:rw
    - ./ssl:/etc/nginx/ssl:rw
    - ./wwwroot:/var/www:rw
    network_mode: host
    restart: always

注意事项

  • artifactory 持久化数据目录可用空间最好稍微大些(>500GB),具体看镜像源数目多少。
  • 使用 nginx 进行反向代理。

配置源

7.x 和 6.x 版本差别还挺大的。

docker-compose up -d 启动服务后,访问 <ip>:8082 进行初始化服务配置,基本默认配置即可或者 SKIP 跳过。

在此过程中有一步比较坑,就是创建默认的 Repositories,这个跳过跳过,否则后面在使用过程中就要踩坑了,如配置 Debian 或者源后 Alpine 后,如果文件路径里有**.**就会导致文件无法下载 404

artifactory 源

简单介绍一下,

  • Local 本地 (通常放一些内部的二进制文件或者其他,当 oss 用)
  • Remote 远程 (常用,默认就基本使用这个 通常镜像 aliyun 或者 tuna)
  • Virtual 虚拟 (local + remote)

这里我截取部分软件源示例,基本傻瓜式操作

示例配置 Debian 源

正常 Debian 源如下:

deb https://mirrors.ysicing.me/debian/ buster main contrib non-free
deb https://mirrors.ysicing.me/debian/ buster-updates main contrib non-free
deb https://mirrors.ysicing.me/debian/ buster-backports main contrib non-free
deb https://mirrors.ysicing.me/debian-security buster/updates main contrib non-free

如果想达成如上,需要做两件事

  • 镜像 Debian 源
  • 配置域名

镜像 Debian 源

  • 创建 Remote Repositories debiandebian-security

  • 配置 debian Remote Repositories

同理 debian-security 类似

  • 配置完成后访问 <ip>:8082/artifactory/debian/ 或者 <ip>:8081/artifactory/debian/

到这里,我们已经实现了

deb http://172.16.72.42:8082/artifactory/debian/ buster main contrib non-free
....

ip+ 端口的方式终究不太好记,是时候拖出 nginx 大杀器了

配置 nginx

这里不具体说 nginx 配置了,直接上配置

# mirrors.conf
server {
    listen 80;
    listen [::]:80;
    listen 443 ssl http2;
    listen [::]:443 ssl http2;

    server_name mirrors.ysicing.me;
    if ($http_x_forwarded_proto = '') {
        set $http_x_forwarded_proto  $scheme;
    }
    index index.html;
    root /var/www/mirrors.ysicing.me/public;

    # SSL
    ssl_certificate /etc/nginx/ssl/ysicing.me.crt;
    ssl_certificate_key /etc/nginx/ssl/ysicing.me.key;

    # security
    # include security.conf;

    location = / {
	    root /var/www/mirrors.ysicing.me/public;
    }

    location ~ .*\.(html|htm|reponew)$ {
	    root /var/www/mirrors.ysicing.me/public;
    }

    location ~ (docker.sh|func.sh|data.json)$ {
	   root /var/www/mirrors.ysicing.me/public;
    }

    # location ~ ^/$ {
    #     root /var/www/mirrors.ysicing.me/public;
    # }

    location /pypi/ {
	proxy_pass http://127.0.0.1:8081/artifactory/api/pypi/pypi/;
   	include nginxconfig.io/proxy.conf;
    }

    # chunked_transfer_encoding on;
    # client_max_body_size 0;

    # reverse proxy
    location / {

	proxy_buffering    off;
	proxy_buffer_size  128k;
	proxy_buffers 100  128k;
	client_max_body_size 100m;

        proxy_pass http://127.0.0.1:8081/artifactory/;
        include nginxconfig.io/proxy.conf;

        location ~ ^/artifactory/ {
            proxy_pass    http://127.0.0.1:8081;
            include nginxconfig.io/proxy.conf;
        }
    }

    # additional config
    include nginxconfig.io/general.conf;
}

类似两个配置拿自 nginxconfig.io

# proxy.conf
proxy_http_version    1.1;
proxy_cache_bypass    $http_upgrade;
proxy_read_timeout  2400s;
proxy_pass_header   Server;
proxy_next_upstream error timeout non_idempotent;
proxy_next_upstream_tries    1;
proxy_set_header Upgrade            $http_upgrade;
proxy_set_header Connection         "upgrade";
proxy_set_header Host                $host;
proxy_set_header X-Real-IP            $remote_addr;
proxy_set_header X-Forwarded-For    $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto    $scheme;
proxy_set_header X-Forwarded-Host    $host;
proxy_set_header X-Forwarded-Port    $server_port;

# general.conf
# favicon.ico
location = /favicon.ico {
    log_not_found off;
    access_log off;
}

# robots.txt
location = /robots.txt {
    log_not_found off;
    access_log off;
}

# assets, media
location ~* \.(?:css(\.map)?|js(\.map)?|jpe?g|png|gif|ico|cur|heic|webp|tiff?|mp3|m4a|aac|ogg|midi?|wav|mp4|mov|webm|mpe?g|avi|ogv|flv|wmv)$ {
    expires 7d;
    access_log on;
}

# svg, fonts
location ~* \.(?:svgz?|ttf|ttc|otf|eot|woff2?)$ {
    add_header Access-Control-Allow-Origin "*";
    expires 7d;
    access_log off;
}

# gzip
gzip on;
gzip_vary on;
gzip_proxied any;
gzip_comp_level 6;
gzip_types text/plain text/css text/xml application/json application/javascript application/rss+xml application/atom+xml image/svg+xml;

到这里软件源配置就基本完成了。

效果图如下:

UI 借鉴了网易开源镜像站

踩的 pypi 坑,小记备忘

pypi 源不同于其他,需要额外配置 nginx 规则

location /pypi/ {
	proxy_pass http://127.0.0.1:8081/artifactory/api/pypi/pypi/;
   	include nginxconfig.io/proxy.conf;
    }

使用

~/.pip/pip.conf
[global]
index-url = https://mirrors.ysicing.me/pypi/simple

# 测试
git clone https://gitee.com/ysbot/CTFd.git --depth 1
cd CTFd
pip3 install -r requirements.txt

Go 代理

新版本对 Go 代理做了优化,使用很流程,创建远程 Go,源使用 https://goproxy.cn

go env -w GO111MODULE=on
go env -w GOPROXY=https://mirrors.ysicing.me/go/,direct

Sponsor

Like this article? $1 reward

Comments