婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > golang實踐-第三方包為私有庫的配置方案

golang實踐-第三方包為私有庫的配置方案

熱門標簽:百度地圖標注后傳給手機 excel地圖標注分布數據 阿克蘇地圖標注 評價高的400電話辦理 外呼系統用什么卡 外呼系統顯本地手機號 電話機器人軟件免費 壽光微信地圖標注 涿州代理外呼系統

正常使用了go 1.8一段時間沒有發現異常,為了發布便捷,以及后期引入plug-in,開始將大項目分解。涉及到通過vendor引入私有庫保存的第三方包。

參考網上那些反復轉帖的材料,始終無法成功,總是都會出現類似以下的錯誤:

package git.oschina.net/xxx/yyy: unrecognized import path "git.oschina.net/xxx/yyy" (parse https://git.oschina.net/xxx/yyy?go-get=1: no go-import meta tags ())

反復折騰后,終于搞定,這里整理一下,備查。

整個過程三個步驟:生成公鑰、git配置、第三方包調用

公鑰生成

使用私有庫,是必須要通過公鑰的,而公鑰是由客戶端生成,然后上傳到oschina上。網上資料比較多,相對容易解決.

1.生成公鑰文件

//-f 參數:指定鑰匙文件名稱;不設置,則默認為id_rsa(已經存在則會有覆蓋提示)。
//-C 參數:注釋描述,這里隨便寫了個郵箱地址。
//-t 參數:指定加密格式,默認為dsa
$ssh-keygen -t rsa -C "aaa@bbb.com" -f ~/.ssh/ccc_rsa
//連續回車,忽略密碼設置
Generating public/private rsa key pair.
Enter passphrase (empty for no passphrase): 
Enter same passphrase again: 
Your identification has been saved in /Users/apple/.ssh/ccc_rsa.
Your public key has been saved in /Users/apple/.ssh/ccc_rsa.pub.
The key fingerprint is:
SHA256:FBG/a3Ed4KFYjVITwRiwPKj+HjCKiBxu10D/K2wVPE8 aaa@bbb.com
The key's randomart image is:
+---[RSA 2048]----+
|      ..=B*=o    |
|     o .o=o+.o   |
|   .. = o.o . .  |
|  ...  * E . . . |
| .+. .  S o . .  |
|*o.oo .. . +     |
|=+..o...  o      |
|. .. =  ..       |
|   .+ ..         |
+----[SHA256]-----+

可以查看到增加了ccc_rsa與ccc_rsa.pub兩個文件,可以很容易查看:

$ ls ~/.ssh/
ccc_rsa     ccc_rsa.pub

2.添加密鑰到ssh-agent

添加SSH key 到 ssh-agent很簡單,添加前確保ssh-agent可用即可:

 $ ssh-add ~/.ssh/ccc_rsa

3.查看公鑰

輸入cat ~/.ssh/ccc_rsa.pub,可以查看到公鑰信息,后面需要將其拷入到git服務器進行設置。

ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCm4HVLb19i2jp10Sv9zs9ifmfAB8r3dhSZ3ZuHmAr7oOBG01TqNsArJf5GpbtNc4aEhqZoHfE1tEgPkqMiSkCW6w+m7rfCjCykZ7U2IjxUvcDOqbHPylpdWzTRFq+jcvqeFyHqMv0B0ORqWvHqBwzDWwyBbCWTDhrTpAfykfAqVSb62JEnaj84MELoOIoSnkuAXcA+EnkG+3HxUqt+3TFq/p9xLfc2NqZG4wZg00fIlS6b+yoRkvVE8fx9V1K4ATbiVmLk+wjk4C7NC3V71UyyCD5knMa0Dd54re1gaZJOl8K7ukc9IgKAQwOcYde0nyN7kVZtNt/G+VhpAibY/7Wv aaa@bbb.com

4.通過config指定鑰匙

如果項目涉及到多個私有庫,或者指定了rsa文件名,就需要設置ssh config文件。執行vi ~/.ssh/config命令,填寫以下內容:

#Host 別名
Host ccc-oschina     
        #HostName  主機名
        HostName git.oschina.net
        #驗證方式
        PreferredAuthentications publickey
        #IdentityFile 指定文件的路徑
        IdentityFile ~/.ssh/ccc_rsa

git服務的公鑰配置

git服務器,是能夠面向賬戶或者項目進行公鑰設置。由于oschina平臺提供了靈活的組織管理,建議為賬戶配置公鑰。

相對賬戶設置,大家比較熟悉,這里簡單描述一下項目的公鑰設置。登錄平臺->選擇項目->進入“管理”->點擊左側的“公鑰管理”->點擊“添加部署公鑰”,將剛剛生成的公鑰填寫到“公鑰”欄,并為它起一個名稱,保存即可。

配置保存后,可以通過ssh -T測試

$ssh -T git@git.oschina.net
#成功后,會顯示歡迎信息。因為配置的項目公鑰,所以顯示為匿名用戶。如果是在成員的配置信息中設置的公鑰,則會顯示出成員昵稱。
Welcome to Git@OSC, Anonymous!

但是,以上是自己生成了密鑰,如果是第三方訪問使用,則需要做添加公鑰的配置。

將gitserver上的公鑰,拷貝下來(不要有前后空格),寫入ssh默認的authorized_keys文件中,并放入~/.ssh/目錄下。如果不采用默認文件名,則需要調整配置,具體可查度娘。

第三方調用

配置成功后,就可以在項目中引入第三方包,按照平時用法會提示錯誤:

$go get git.oschina.net/xxx/yyy
Fetching https://git.oschina.net/xxx/yyy?go-get=1
Parsing meta tags from https://git.oschina.net/xxx/yyy?go-get=1 (status code 404)
package git.oschina.net/xxx/yyy: unrecognized import path "git.oschina.net/xxx/yyy" (parse https://git.oschina.net/xxx/yyy?go-get=1: no go-import meta tags ())

其原因是因為包路徑需要改為.git文件的路徑,只需要增加.git就會正常,需要特別注意:

//包路徑的后邊需要增加.git
$go get git.oschina.net/xxx/yyy.git

這樣,就可以在代碼中引入第三方的私有庫了。當然,我們采用glide、godep等第三方包管理工具也可以,只要注意包路徑后邊增加.git就好。

補充:athens 搭建golang私有gitlab倉庫 (踩了git和https的坑)

環境:

gitlab: gitlab需要配置可信任https。

nginx:兩個

git:最新版,!!!重要,不是最新版go get會出現問題

athens

golang

原理:

通過nginx轉發,實現外網請求和內網請求路由。配置https://goproxy.io 下載golang等被墻的包。

注意事項:

1、git一定要是最新版

2、gitlab一定要配置https。目前athens使用http代理我試了不行,有會配置的同學歡迎指教。

3、location ~* ^/[^/]+/[^/]+$ 這個表達式固定匹配兩級path,類似/aa/bb nginx并不完全支持正則。想要匹配三級路徑等需要另外加location ~* ^/[^/]+/[^/]+/[^/]+$

4、return 200 "!DOCTYPE html>head>meta content='$host$uri git ssh://git@$host:$uri.git' name='go-import'>/head>/html>"; 這個配置注意ssh端口根據情況修改,比如ssh端口為8080,則該為:return 200 "!DOCTYPE html>head>meta content='$host$uri git ssh://git@$host:8080$uri.git' name='go-import'>/head>/html>";

網絡流程圖:

準備:

1.機器3個:(也可以在一個機器上,修改對應端口即可)

private.gitlab.com: 部署私有倉庫機器

athens.com: athens倉庫入口機器(可以不用,但是這樣外網的包就不會緩存在本地)

athens.private.com: 私有gitlab代理。

2.在阿里云上申請可信任的免費CA證書。

private.gitlab.com 部署和相關配置:

1.在該機器上部署gitlab倉庫

2.配置nginx https,配置如下:

#user  nobody;
worker_processes  1;
 
error_log  logs/error.log;
error_log  logs/error.log  notice;
error_log  logs/error.log  info;
 
#pid        logs/nginx.pid;
 
 
events {
    worker_connections  1024;
}
 
 
http {
    # gitlab 服務地址和端口
    upstream gitlab {
        server 10.53.1.234:8081;
    }
 
    server {
        listen 10.53.1.234:80;
        server_name private.gitlab.com;
 
        # 這里選擇重定向到https去
        rewrite ^(.*)$ https://${server_name}$1 permanent;
    }
    server {
        listen    443;
        server_name  private.gitlab.com;
 
        ssl on;
        ssl_session_cache        shared:SSL:10m;
        ssl_session_timeout      20m;
        ssl_session_tickets       on;
        ssl_certificate /etc/nginx/server/2650770_private.gitlab.com.pem;      # 自己ca簽發的
        ssl_certificate_key /etc/nginx/server/2650770_private.gitlab.com.key;  # 自己的私鑰
 
        location / {
            proxy_cache off;
            proxy_pass http://gitlab;
            access_log /var/log/nginx_access.log;
        }
        # GOPROXY,vgo download protocol協商軟件包的規范
        # 第一步就是獲取軟件包元數據,格式如下,gitlab暫時不支持,所以需要nginx代理
        location ~* ^/[^/]+/[^/]+$ {
            if ($http_user_agent ~* '^go.*') {
                return 200 "!DOCTYPE html>head>meta content='$host$uri git ssh://git@$host:$uri.git' name='go-import'>/head>/html>";
            }
            proxy_cache off;
            proxy_pass http://gitlab;
        }
        # 具體協議原理請看這篇文章:http://www.bubuko.com/infodetail-3045365.html
        location ~* ^/(?holder>[^/]+)/(?project>[^/]+)/.*$ {
            set $goRedirect 'https://$host/$holder/$project?$args';
            access_log /var/log/nginx_access1.log;
            if ($http_user_agent ~* '^go.*') {
                return 301 $goRedirect;
            }
            proxy_cache off;
            proxy_pass http://gitlab;
        }
    }
 
}

athens.com (代理倉庫總入口)部署和相關配置:

1、安裝golang環境

2、設置go環境,export GO111MODULE=on,export GOPROXY=http://private.athens.com

3、安裝athens

private.athens.com (私有倉庫代理)部署和相關配置:

1、安裝golang環境 和 git客戶端并配置免登陸

2、設置go環境,export GO111MODULE=on,export GOPROXY=direct

3、安裝athens

4、安裝nginx并配置nginx,相關配置如下:

#user  nobody;
worker_processes  1;
 
events {
    worker_connections  1024;
}
 
http {
    server {
        listen 80;
    
        # 外部的依賴轉發到外面的go proxy
        location / {
            proxy_pass https://goproxy.io;
            #proxy_pass https://athens.azurefd.net;
        }
        # 內部依賴的go proxy,也就是上面啟動的athens
        # github的依賴也可以走本地的go proxy,可以做緩存
        location ~ /(private\.gitlab\.com)/ {
            # 私有倉庫跳轉到私有athens 服務
            proxy_pass http://localhost:3000;
            access_log /var/log/nginx_access.log;
        }
    }
}

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • Golang中switch語句和select語句的用法教程
  • Golang 編譯成DLL文件的操作
  • golang調用c實現的dll接口細節分享
  • Golang如何調用windows下的dll動態庫中的函數
  • 完美解決golang go get私有倉庫的問題
  • golang gopm get -g -v 無法獲取第三方庫的解決方案
  • Golang: 內建容器的用法
  • golang switch語句的靈活寫法介紹

標簽:吐魯番 雞西 蘭州 汕頭 重慶 銅川 欽州 梅河口

巨人網絡通訊聲明:本文標題《golang實踐-第三方包為私有庫的配置方案》,本文關鍵詞  golang,實踐,第三方,包,為,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《golang實踐-第三方包為私有庫的配置方案》相關的同類信息!
  • 本頁收集關于golang實踐-第三方包為私有庫的配置方案的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    日本女人一区二区三区| 91精品国产丝袜白色高跟鞋| 蜜臂av日日欢夜夜爽一区| 亚洲国产精品久久不卡毛片| 亚洲精品视频免费看| 亚洲欧美激情视频在线观看一区二区三区 | 欧美性视频一区二区三区| 91丝袜美腿高跟国产极品老师| 欧美日韩在线亚洲一区蜜芽| 色视频欧美一区二区三区| 色天天综合色天天久久| 欧美日韩一级片在线观看| 69堂国产成人免费视频| 精品少妇一区二区| 久久九九国产精品| 亚洲视频在线一区| 日韩国产欧美在线视频| 国产麻豆精品视频| 91免费版pro下载短视频| 欧美日韩久久久久久| 精品国产青草久久久久福利| 欧美国产精品久久| 亚洲成人av免费| 国产一区二区伦理片| 91欧美一区二区| 91麻豆精品国产91久久久久 | 婷婷激情综合网| 狠狠久久亚洲欧美| 99re这里只有精品6| 日韩欧美在线影院| 中文字幕av资源一区| 亚洲成av人**亚洲成av**| 国产成人亚洲精品青草天美 | 久久夜色精品国产欧美乱极品| 中文字幕电影一区| 日韩精品电影在线| 成人免费av在线| 日韩欧美精品三级| 亚洲自拍都市欧美小说| 国产夫妻精品视频| 亚洲美女免费视频| 日本特黄久久久高潮| 99精品欧美一区| 亚洲精品一区在线观看| 亚洲国产你懂的| 成人精品免费看| 精品99一区二区| 无码av免费一区二区三区试看 | 激情成人综合网| 欧洲一区二区三区在线| 国产精品久久看| 国产一区二区视频在线| 在线不卡欧美精品一区二区三区| 国产精品丝袜久久久久久app| 美女视频网站久久| 欧美日韩免费在线视频| 亚洲色图欧美偷拍| 成人福利在线看| 久久精品一区二区三区不卡牛牛| 免费在线观看视频一区| 欧美日韩一本到| 亚洲一区二区视频在线观看| 成人午夜私人影院| 国产欧美精品一区aⅴ影院 | 91一区二区在线| 国产午夜精品一区二区| 久久成人麻豆午夜电影| 日韩欧美国产不卡| 美洲天堂一区二卡三卡四卡视频 | 激情丁香综合五月| 精品91自产拍在线观看一区| 精品亚洲成a人| 亚洲精品在线观看网站| 国产酒店精品激情| 欧美激情中文字幕| 国产99久久久国产精品潘金| 欧美高清在线精品一区| 成人午夜伦理影院| 136国产福利精品导航| 日本国产一区二区| 亚洲成av人片www| 日韩视频免费观看高清完整版 | 国产一区二区伦理| 久久精品视频在线免费观看| 丁香激情综合国产| 亚洲男人的天堂av| 911国产精品| 国产精品一品视频| 国产精品久久久久久亚洲毛片| 99九九99九九九视频精品| 亚洲人xxxx| 在线电影国产精品| 国产成人午夜精品5599 | 美腿丝袜在线亚洲一区| 日韩三级.com| 国产91精品露脸国语对白| 综合色中文字幕| 精品视频1区2区| 激情欧美一区二区三区在线观看| 国产三级三级三级精品8ⅰ区| 色综合久久久久网| 丝袜国产日韩另类美女| 久久久久国产精品免费免费搜索| 91年精品国产| 日本午夜一区二区| 1024国产精品| 精品欧美久久久| 97se亚洲国产综合自在线观| 日韩在线一二三区| 欧美经典一区二区| 91精品国产91久久综合桃花| 成人高清免费观看| 久久精品国产亚洲aⅴ| 国产精品二三区| 日韩欧美精品在线视频| 99精品热视频| 国产一区视频网站| 日韩不卡一区二区| 一区二区三区.www| 欧美国产日本韩| 欧美电影免费观看高清完整版| 色综合久久久网| jlzzjlzz亚洲女人18| 九九视频精品免费| 五月天婷婷综合| 一区二区在线观看视频| 国产精品久久久久精k8| 久久嫩草精品久久久久| 日韩欧美另类在线| 制服丝袜亚洲精品中文字幕| 欧美影院午夜播放| 一本高清dvd不卡在线观看| 国产东北露脸精品视频| 国模一区二区三区白浆| 日本视频一区二区三区| 午夜精品免费在线| 香蕉加勒比综合久久| 亚洲一区精品在线| 亚洲一区二区三区美女| 亚洲激情综合网| 亚洲日韩欧美一区二区在线| 国产精品久99| 亚洲欧美日韩国产手机在线| 国产精品乱码一区二区三区软件| 国产校园另类小说区| 久久久久久免费毛片精品| 欧美大胆一级视频| 日韩女优av电影在线观看| 日韩欧美不卡在线观看视频| 欧美xxxxxxxxx| 日韩一级大片在线| 久久亚洲综合色| 国产亚洲欧美日韩在线一区| 国产精品天美传媒| 亚洲精品免费一二三区| 亚洲欧美经典视频| 亚洲午夜激情网站| 视频在线在亚洲| 精品一二三四区| 国产一区二区三区观看| 成人黄色av电影| 91福利国产成人精品照片| 欧美体内she精高潮| 日韩免费视频一区二区| 国产丝袜美腿一区二区三区| 中文一区一区三区高中清不卡| 国产精品久久久久久久久久久免费看| 日韩理论片在线| 日韩中文欧美在线| 国产一区二区伦理片| gogo大胆日本视频一区| 欧美日韩日日骚| 久久久国产精品麻豆 | 欧美日韩久久久一区| 日韩欧美成人激情| 中文字幕中文乱码欧美一区二区| 一区二区三区欧美久久| 久久精品99国产精品| 99视频热这里只有精品免费| 欧美日韩一区二区三区高清| 亚洲精品在线免费播放| 亚洲精品高清在线观看| 久久99国产精品麻豆| 日本精品裸体写真集在线观看| 日韩欧美国产三级电影视频| 亚洲色图清纯唯美| 久久av老司机精品网站导航| 日本电影欧美片| 国产欧美视频一区二区三区| 天堂资源在线中文精品| 成人黄色777网| 欧美一区二区三区啪啪| 亚洲欧美日韩一区二区| 国产在线一区二区| 欧美精品一级二级| 亚洲精品欧美激情| 成人av免费网站| 亚洲精品在线电影| 蜜臀av一区二区在线免费观看 | 欧美不卡在线视频|